在abator中可生成iBatis的代码。其中,Sql_map中带有的两个函数是:
updateByPrimaryKeySelective
updateByPrimaryKey
前者只是更新新的model中不为空的字段。
后者则会将为空的字段在数据库中置为NULL。
例如:Action
- Labor labor = new Labor();
- labor.setIdentitycard(identitycard);
- labor.setName(name);
- labor.setDepartmentid(Integer.parseInt("1"));
- labor.setEmployeenumber(Integer.parseInt("1006"));
- labor.setLeadernumberid(Integer.parseInt("1001"));
- result = laborAO.doSave(labor, "updateByIdentitycard");
- if (!result.isSuccess()) {
- return INPUT;
- } else {
- System.out.println("message : insert " + name + " . \n");
- return SUCCESS;
- }
如果DAO中使用的是updateByPrimaryKeySelective,则按照不为空的labor值去更新。
如果使用updateByPrimaryKey,这在labor中未定义的字段更新后就没有了。
从SQL语句上分析,二者的不同:
- <update id="updateByPrimaryKeySelective" parameterClass="com.sk.maxdrive.dal.model.Labor" >
- <!--
- WARNING - @ibatorgenerated
- This element is automatically generated by Apache iBATIS Ibator, do not modify.
- This element was generated on Thu Sep 01 13:55:37 CST 2011.
- -->
- update labor
- <dynamic prepend="set" >
- <isNotNull prepend="," property="name" >
- NAME = #name:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="tagid" >
- TAGID = #tagid:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="departmentid" >
- DEPARTMENTID = #departmentid:INTEGER#
- </isNotNull>
- <isNotNull prepend="," property="duty" >
- DUTY = #duty:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="employeenumber" >
- EMPLOYEENUMBER = #employeenumber:INTEGER#
- </isNotNull>
- <isNotNull prepend="," property="leadernumberid" >
- LEADERNUMBERID = #leadernumberid:INTEGER#
- </isNotNull>
- <isNotNull prepend="," property="home" >
- HOME = #home:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="address" >
- ADDRESS = #address:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="emergencynumber" >
- EMERGENCYNUMBER = #emergencynumber:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="emergencycontact" >
- EMERGENCYCONTACT = #emergencycontact:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="hoursetel" >
- HOURSETEL = #hoursetel:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="postcode" >
- POSTCODE = #postcode:INTEGER#
- </isNotNull>
- <isNotNull prepend="," property="cellphone" >
- CELLPHONE = #cellphone:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="email" >
- EMAIL = #email:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="resume" >
- RESUME = #resume:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="employeedate" >
- EMPLOYEEDATE = #employeedate:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="headpic" >
- HEADPIC = #headpic:VARCHAR#
- </isNotNull>
- <isNotNull prepend="," property="bankaccount" >
- BANKACCOUNT = #bankaccount:VARCHAR#
- </isNotNull>
- </dynamic>
- where IDENTITYCARD = #identitycard:VARCHAR#
- </update>
一系列的isNull判断
- <update id="updateByPrimaryKey" parameterClass="com.sk.maxdrive.dal.model.Labor" >
- <!--
- WARNING - @ibatorgenerated
- This element is automatically generated by Apache iBATIS Ibator, do not modify.
- This element was generated on Thu Sep 01 13:55:37 CST 2011.
- -->
- update labor
- set NAME = #name:VARCHAR#,
- TAGID = #tagid:VARCHAR#,
- DEPARTMENTID = #departmentid:INTEGER#,
- DUTY = #duty:VARCHAR#,
- EMPLOYEENUMBER = #employeenumber:INTEGER#,
- LEADERNUMBERID = #leadernumberid:INTEGER#,
- HOME = #home:VARCHAR#,
- ADDRESS = #address:VARCHAR#,
- EMERGENCYNUMBER = #emergencynumber:VARCHAR#,
- EMERGENCYCONTACT = #emergencycontact:VARCHAR#,
- HOURSETEL = #hoursetel:VARCHAR#,
- POSTCODE = #postcode:INTEGER#,
- CELLPHONE = #cellphone:VARCHAR#,
- EMAIL = #email:VARCHAR#,
- RESUME = #resume:VARCHAR#,
- EMPLOYEEDATE = #employeedate:VARCHAR#,
- HEADPIC = #headpic:VARCHAR#,
- BANKACCOUNT = #bankaccount:VARCHAR#
- where IDENTITYCARD = #identitycard:VARCHAR#
- </update>
没有判断,直接加载
相关推荐
updateByPrimaryKeySelective 按主键更新所选字段 updateByPrimaryKey 按主键更新 selectOne 查询一个 selectList 查询列表 selectAll 查询所有记录 insertBatch 批插入 deleteBatchIds 按多个ID批量删除 ...
如果要操作的表没有主键字段,则生成的xml中只有insert,没有select、update、delete,因为这三种操作都与主键有关,如deleteByPrimaryKey(Long id)、selectByPrimaryKey(Long id)、updateByPrimaryKey...
micro-hcnet-website-1_1 | ### The error may involve cn.hcnet2006.blog.hcnetwebsite.mapper.SysArticleMapper.updateByPrimaryKey micro-hcnet-website-1_1 | ### The error occurred while executing an
用来标识实体类中属性与数据表中字段的对应关系 name 定义了被标注字段在数据库表中所对应字段的名称; mapper service Controller 测试 报错500 实体类@table路径写错 新增 Controller @RequestBody ...
基于matlab实现实现了基于项目的协同过滤代码,MATLAB实现.rar
数据来源:中国劳动统计NJ-2023版
企业固定资产信息管理系统设计与实现.doc
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
【作品名称】:基于VB实现的学生成绩管理系统(源代码+系统+开题报告+答辩PPT) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
银行信贷管理系统设计与实现-(毕业设计)1.docx
【作品名称】:基于VB实现的银行代扣代发工资系统(源代码+系统+开题报告) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
数据来源:中国人口与就业统计NJ-2023版
java,大学课后作业
数据来源:中国电力统计NJ-2021版
【作品名称】:基于VB实现的网上餐饮管理系统设计(论文+源代码+开题报告+英文文献) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
基于matlab实现烟花算法进行函数最小_最大值寻优,对十多个测试函数进行了寻优,效果良好,代码附带详细说明.rar
数据来源:中国电力统计NJ-2021版
【作品名称】:基于VB实现的商场管理系统设计(源代码+系统) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。