标签:span before 情况 core 默认 没有 需要 嵌套 轻量级
简言:这个地方我就草草过了,NBA圣诞大战,偷偷看比赛,真香~
第五章映射器
5.2select元素
自动映射和驼峰映射:MyBatis提供了自动映射功能,在默认的情况下自动映射功能是开启的。
在setting元素中,
autoMappingBehavior控制自动映射,取值范围:
mapUnderscoreToCamelCase控制驼峰映射,驼峰映射是按照驼峰命名的方式自动映射,例如数据库字段为role_name,则POJO属性名为roleName。
传递多个参数的方式:
resultMap映射结果集:
为了支持复杂映射,select元素提供了resultMap属性。先定义resultMap属性。
<resultMap type="role" id="roleMap"> <id property="id" column="id"/> <result property="roleName" column="role_name"/> </resultMap> <select id="getRole" parameterType="Long" resultMap="roleMap"> select id,role_name from t_role where id = #{id} </select>
resultMap的子元素id代表组件,而result代表其属性,id和result元素的属性property代表POJO的属性名称,而column代表SQL的列名。
5.3insert元素
主键回填,JDBC中的Statement对象在执行插入的SQL后,可以通过getGennerateKeys方法获得数据库生成的主键(需要数据库驱动支持),还要配置其属性keyProperty或keyColumn,告诉系统把生成的组件放入哪个属性中。
<insert id="insertRole" parameterType="role" useGeneratedKeys="true" keyProperty="id"> insert into t_role(role_name,note) values(#{roleName},#{note}) </insert>
自定义主键:
<insert id="insertRole" parameterType="role" > <selectKey keyProperty="id" resultType="long" order="BEFORE"> select if(max(id)=null,1,max(id)+3) from t_role </selectKey> insert into t_role(role_name,note) values(#{roleName},#{note}) </insert>
order设置为BEFORE,说明它将于当前定义的SQL前执行,这样就可以自定义主键的规则了,也可以设置为AFTER这样它就会在插入语句之后执行了。
5.7 resultMap元素
resultMap的作用是定义映射规则、级联的更新、定制类型转换器等。(有一些子元素,用到说的时候再说把)
标签:span before 情况 core 默认 没有 需要 嵌套 轻量级
原文地址:https://www.cnblogs.com/shiboinfo/p/10178896.html