Mybatis动态插入数据(使用trim标签)

mybatis 专栏收录该内容
4 篇文章 0 订阅

Mybatis动态插入数据(使用trim标签)

有时我们控制同一张表,但传入的参数不固定,操作表的字段不固定,就要用到mybatis动态插入。.xml如下:

<insert id="insertMessage" parameterType="com.sf.ccsp.member.client.request.MessageReq">
       insert cx_customer_message
       (ID,MEMBERID,
         <if test='messageClassify != null and messageClassify != "" '>
             MESSAGEE_CLASSIFY,
         </if>
         <if test='messageCode != null and messageCode != "" '>
             MESSAGE_CODE,
         </if>
         <if test='messageContent != null and messageContent != "" '>
             MESSAGE_CONTENT
         </if>
        )
       values (
         #{id, jdbcType=VARCHAR},
         #{memberId, jdbcType=VARCHAR},
          <if test='messageClassify != null and messageClassify != "" '>
            #{messageClassify, jdbcType=VARCHAR},
          </if>
          <if test='messageCode != null and messageCode != "" '>
            #{messageCode, jdbcType=VARCHAR},
          </if>
          <if test='messageContent != null and messageContent != "" '>
            #{messageContent, jdbcType=VARCHAR}
          </if>
        )
</insert>

问题来了,当messageClassify !=null,但messageCode 和messageContent 为空时,会多出来逗号,以至于mybatis报错。正确的用法如下.xml:

<insert id="insertMessage" parameterType="com.sf.ccsp.member.client.request.MessageReq">
       insert cx_customer_message
        <trim prefix="(" suffix=")" suffixOverrides="," >
          ID,MEMBERID,
          <if test='messageClassify != null and messageClassify != "" '>
             MESSAGEE_CLASSIFY,
          </if>
          <if test='messageCode != null and messageCode != "" '>
             MESSAGE_CODE,
          </if>
         <if test='messageContent != null and messageContent != "" '>
             MESSAGE_CONTENT,
         </if>
        </trim>

        <trim prefix="values (" suffix=")" suffixOverrides="," >
          #{id, jdbcType=VARCHAR},
          #{memberId, jdbcType=VARCHAR},
          <if test='messageClassify != null and messageClassify != "" '>
            #{messageClassify, jdbcType=VARCHAR},
          </if>
          <if test='messageCode != null and messageCode != "" '>
            #{messageCode, jdbcType=VARCHAR},
          </if>
          <if test='messageContent != null and messageContent != "" '>
            #{messageContent, jdbcType=VARCHAR},
          </if>
        </trim>  
</insert>

trim标签的属性

  1. prefix:前缀覆盖并增加其内容。也就是给中的sql语句加上前缀;
  2. suffix:后缀覆盖并增加其内容。给包裹的sql语句加上后缀;
  3. prefixOverrides:前缀判断的条件。取消指定的前缀,如where;
  4. suffixOverrides:后缀判断的条件。取消指定的后缀,如and | or.,逗号等。
  • 9
    点赞
  • 1
    评论
  • 4
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

《.NET最佳实践》是.NET领域的集大成之作和公认经典。书中总结了大量.NET开发人员公认的最佳实践,并有针对性地阐明了如何恰当地在个人、小组、组织和行业中应用这些最佳实践。书中的最佳实践涵盖.NET开发的方方面面,从基础技术到核心技术,从开发方法到开发流程,从开发工具到团队协作,等等。所有最佳实践都辅之以实际的项目案例,并对案例代码进行了深入分析,实践性和可操作性极强。 全书可分为四个部分。第一部分(第1~5章)着重教授你如何选择和发现这些实践,如何提升团结度,如何量化这些实践等。第二部分(第6~9章)专注于开发人员个人的实践。第6章涵盖.NET规章制度标准和指南,识别并避免“代码异味”的技巧。第7章以非常规的方式来重新审视C#语言,带给你全新体验。第8章分享了多个符合高效开发原则的测试代码改进方法。第9章介绍生成自动化,以消除易错步骤,便于生成和部署。第三部分(第10~12章)重点介绍支持的工具、产品和技术。第10章介绍持续集成的流程和步骤,同时分析持续集成可利用的产品和工具。第11章推荐并分析诸多实用的代码分析(静态和动态)的工具、技术和方法。第12章综合介绍多种商业的及开源的测试框架和工具。第四部分(第13章)告诉你如何说服对采用最佳实践存在反感和偏见的组织和个人。本书还附有评估、跟踪最佳实践的记分卡。 《.NET最佳实践》 译者序 前 言 第1章 冷静待之 1 1.1 实践选择 3 1.1.1 可行性 3 1.1.2 认可度 5 1.1.3 价值 6 1.1.4 原型 6 1.2 关注需要改善的目标领域 7 1.2.1 产品交付 8 1.2.2 软件质量 9 1.2.3 团队关系 10 1.3 整体改善 11 1.3.1 均衡 11 1.3.2 面貌一新 12 1.3.3 可持续性 12 1.4 小结 13 第2章 .NET实践领域 15 2.1 从内部挖掘 17 2.1.1 技术债 17 2.1.2 缺陷跟踪系统 18 2.1.3 反思分析 19 2.1.4 前瞻性分析 20 2.2 应用程序生命周期管理 20 2.3 设计模式和开发指南 22 2.3.1 .NET设计规范 23 2.3.2 微软的模式和实践小组 23 2.3.3 显示界面层设计模式 24 2.3.4 对象–对象映射 25 2.3.5 依赖注入 25 2.4 研究和开发 26 2.4.1 自动化测试生成工具 27 2.4.2 契约式编码 30 2.5 微软安全开发生命周期 30 2.6 小结 32 第3章 实现预期目标 33 3.1 成功要素 34 3.1.1 项目启动阶段 37 3.1.2 超出范围 38 3.1.3 干扰和分心 38 3.1.4 学习与工作之间的平衡 39 3.2 共识 39 3.2.1 线框图 40 3.2.2 文档化架构 41 3.2.3 报表模型 42 3.2.4 细节化示例 42 3.2.5 创建原型 43 3.3 预期目标 44 3.3.1 交付 44 3.3.2 实际成果 44 3.3.3 趋势 46 3.4 小结 47 第4章 量化价值 48 4.1 价值 50 4.1.1 财务回报 50 4.1.2 提高可控性 51 4.1.3 提高质量品质 52 4.1.4 更加高效 53 4.2 数据来源 54 4.2.1 定量数据 54 4.2.2 定性数据 57 4.2.3 业界证据 58 4.3 小结 59 第5章 战略 60 5.1 认知 62 5.1.1 头脑风暴 62 5.1.2 规划 63 5.1.3 监控 64 5.1.4 沟通 64 5.2 个体过程 66 5.2.1 卓越的承诺 67 5.2.2 良性的纪律 67 5.2.3 效力和坚持 68 5.3 杠杆 69 5.3.1 自动化 69 5.3.2 警报系统 70 5.3.3 经验和专业知识 71 5.4 小结 71 第6章 .NET的规章制度 72 6.1 编码标准和指南 73 6.1.1 来源 73 6.1.2 异常 75 6.1.3 disposable模式 78 6.1.4 其他事项 82 6.2 代码异味 86 6.2.1 注释 86 6.2.2 过于复杂 88 6.2.3 未用到的、无法到达的和无效的代码 89 6.3 小结 89 第7章 强大的C#构造 90 7.1 扩展方法 91 7.2 隐式类型的局部变量 94 7.3 可以为null的类型 96 7.4 null合并运算符 98 7.5 可选参数 99 7.6 泛型 102 7.7 LINQ 103 7.8 小结 108 第8章 自动测试 109 8.1 案例研究 111 8.2 棕色地带的应用程序 112 8.3 绿色地带的应用程序 114 8.4 自动测试基础 115 8.5 测试代码的可维护性 115 8.5.1 命名约定 116 8.5.2 测试方法主体 119 8.6 单元测试 131 8.6.1 边界分析 133 8.6.2 无效参数 134 8.6.3 无效的前提条件 136 8.7 伪造、存根和模拟 137 8.7.1 隔离被测试代码 137 8.7.2 测试依赖交互 139 8.8 表面测试 140 8.9 自动集成测试 143 8.10 数据库注意事项 144 8.11 小结 145 第9章 生成自动化 146 9.1 生成工具 147 9.2 MSBuild基础 148 9.2.1 任务和目标 148 9.2.2 PropertyGroup和ItemGroup 150 9.2.3 基本任务 154 9.3 日志 155 9.4 参数和变量 157 9.5 库和扩展 159 9.6 导入和包含 160 9.7 内联任务 161 9.8 常见任务 163 9.8.1 日期和时间 163 9.8.2 程序集信息 164 9.8.3 XML的Peek和Poke 165 9.8.4 zip存档 166 9.9 自动部署 167 9.9.1 生成一次,部署多次 168 9.9.2 打包工具 169 9.9.3 部署工具 169 9.10 小结 170 第10章 持续集成 171 10.1 案例研究 172 10.2 CI服务器 173 10.2.1 CruiseControl.NET 174 10.2.2 Jenkins 175 10.2.3 TeamCity 175 10.2.4 Team Foundation Server 176 10.3 CI生命周期 176 10.3.1 重新生成 177 10.3.2 单元测试 182 10.3.3 分析 184 10.3.4 打包 187 10.3.5 部署 188 10.3.6 稳定性测试 190 10.3.7 生成报告 192 10.4 小结 192 第11章 代码分析 193 11.1 案例研究 195 11.2 静态分析 196 11.2.1 程序集分析 197 11.2.2 源代码分析 205 11.2.3 架构和设计 211 11.2.4 代码度量值 213 11.2.5 质量保证指标 213 11.3 动态分析 214 11.3.1 代码覆盖率 214 11.3.2 性能分析 216 11.3.3 查询分析 217 11.3.4 日志 217 11.4 小结 218 第12章 测试框架 219 12.1 单元测试框架 220 12.2 测试运行器 221 12.2.1 NUnit的GUI和控制台运行器 221 12.2.2 ReSharper测试运行器 224 12.2.3 Visual Studio测试运行器 227 12.2.4 Gallio测试运行器 230 12.2.5 xUnit.net测试运行器 231 12.3 xUnit测试模式 233 12.3.1 标识测试方法 233 12.3.2 标识测试类和夹具 234 12.3.3 断言 239 12.4 模拟对象框架 240 12.4.1 使用Rhino Mocks动态生成伪对象 240 12.4.2 使用Moles进行隔离测试 243 12.5 数据库测试框架 248 12.6 用户界面测试框架 252 12.6.1 Web应用程序测试框架 252 12.6.2 Windows窗体和其他用户界面测试框架 253 12.7 验收测试框架 253 12.7.1 测试规范和行为 254 12.7.2 业务逻辑验收测试 255 12.8 小结 256 第13章 反感和偏见 257 13.1 团体利益偏见 258 13.2 玫瑰色回顾 259 13.3 团体与个人的评价 260 13.4 维持现状和辩解机制 260 13.5 优势错觉 261 13.6 达克效应 261 13.7 鸵鸟效应 262 13.8 赌徒谬误 263 13.9 歧义效应 263 13.10 集中效应 264 13.11 双曲贴现 264 13.12 常态偏见 265 13.13 小结 265 附录A 参考资源 266 附录B 记分卡 279
©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值