51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1757|回复: 4
打印 上一主题 下一主题

手把手教你写一个java的orm(四)下

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-2-1 16:23:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
实现
首先我们要根据User.java拿到所有的表的字段个名称,和对应的值。就是上一篇写到的:EntityTableRowMapper
  • 拿到字段和class属性的值
    Map<String, Field> columnFieldMapper = entityTableRowMapper.getColumnFieldMapper();insertColumns = new ArrayList(columnFieldMapper.size());for (Map.Entry<String, Field> stringFieldEntry : columnFieldMapper.entrySet()) {    Field field = stringFieldEntry.getValue();    Object value = EntityUtils.getValue(entity, field);    if (value == null) {        continue;    }    insertColumns.add(stringFieldEntry.getKey());    insertColumnValues.add(value);}
    这里有两个变量:
    insertColumns:sql中的字段名。
    insertColumnValues:sql中的字段对应的值。
  • 生成插入的sql:
    StringBuilder builder = new StringBuilder();int size = insertColumns.size();builder.append("INSERT INTO ").append(getTableName()).append(StringUtils.SPACE);builder.append(StringUtils.append("( ", StringUtils.join(insertColumns, ", "), " ) "));builder.append("VALUES ");for (int i = 0; i < insertCount; i++) {    builder.append("( ");    String[] repeat = StringUtils.repeat("?", size);    builder.append(StringUtils.join(Arrays.asList(repeat), ", "));    builder.append(" )");    if (i != insertCount - 1) {        builder.append(StringUtils.COMMA);    }}builder.append(";");
  • 生成的结果:
    //userUser user = new User();user.setId(10);user.setCreateDate(new Date());user.setAge(20);user.setMark("ceshi");user.setName("heiheihei");//sqlINSERT INTO user ( name, id, create_date, age, mark, status ) VALUES ( ?, ?, ?, ?, ?, ? );//value[heiheihei, 10, Tue Jan 22 16:33:00 CST 2019, 20, ceshi, 0]
  • 现在可以拿着生成的sql和值去执行啦~
    jdbcTemplate.update(sql, insertColumnValues.toArray());

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-23 05:05 , Processed in 0.061757 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表