mybatis新增语句_mybatis的insert语句参数说明以及部分操作
⽅法
mybatis的insert语句参数说明以及部分操作⽅法
数据库操作⼀般情况都是少不了insert语句的,下⾯介绍了通过mybatis操作insert语句的部分常⽤内容:
⼀、insert属性
其属性如下:
parameterType ,⼊参的全限定类名或类型别名
keyColumn ,设置数据表⾃动⽣成的主键名。对特定数据库(如PostgreSQL),若⾃动⽣成的主键不是第⼀个字段则必须设置keyProperty ,默认值unset,⽤于设置getGeneratedKeys⽅法或selectKey⼦元素返回值将赋值到领域模型的哪个属性中
useGeneratedKeys ,取值范围true|false(默认值),设置是否使⽤JDBC的getGenereatedKeys⽅法获取主键并赋值到keyProperty设置的领域模型属性中。MySQL和SQLServer执⾏auto-generated key field,
因此当数据库设置好⾃增长主键后,可通过JDBC的getGeneratedKeys⽅法获取。但像Oralce等不⽀持auto-generated key field的数据库就不能⽤这种⽅法获取主键了
statementType ,取值范围STATEMENT,PREPARED(默认值),CALLABLE
flushCache ,取值范围true(默认值)|false,设置执⾏该操作后是否会清空⼆级缓存和本地缓存
timeout ,默认为unset(依赖jdbc驱动器的设置),设置执⾏该操作的最⼤时限,超时将抛异常
databaseId ,取值范围oracle|mysql等,表⽰数据库⼚家,元素内部可通过``来为特定数据库指定不同的sql语句
⼆、INSERT操作——返回值为插⼊的记录数⽬
mapper接⼝代码:
/**
* @param student 学⽣实例
* @return 成功操作的记录数⽬*/ int add(EStudent student);
insert into TStudent(name, age) values(#{name}, #{age})
三、INSERT后返回主键
mapper接⼝代码:
/**
* @param student 学⽣实例
* @return 成功操作的记录数⽬*/ int add(EStudent student);
⾄于l则分为两种情况了,⼀种是数据库(如MySQL,SQLServer)⽀持auto-generated key field,另⼀种是数据库(如Oracle)不⽀持auto-generated key field的。
1. 数据库(如MySQL,SQLServer)⽀持auto-generated key field的情况
⽅式①(推荐做法):
insert into TStudent(name, age) values(#{name}, #{age})
⽅式②:
//下⾯是SQLServer获取最近⼀次插⼊记录的主键值的⽅式 select @@IDENTITY asidinsert into TStudent(name, age) values(# {name}, #{age})
由于⼿段②获取主键的⽅式依赖数据库本⾝,因此推荐使⽤⼿段①。
2. 数据库(如Oracle)不⽀持auto-generated key field的情况
select CAST(RANDOM * 100000 asINTEGER) a FROM SYSTEM.SYSDUMMY1insert into TStudent(id, name, age) values(# {id}, #{name}, #{age})
注意:mapper接⼝返回值依然是成功插⼊的记录数,但不同的是主键值已经赋值到领域模型实体的id中了。
四、selectKey⼦元素
作⽤:在insert元素和update元素中插⼊查询语句。
其属性如下:
keyProperty ,默认值unset,⽤于设置getGeneratedKeys⽅法或selectKey⼦元素返回值将赋值到领域模型的哪个属性中
resultType ,keyPropety所指向的属性类全限定类名或类型别名
order属性 ,取值范围BEFORE|AFTER,指定是在insert语句前还是后执⾏selectKey操作
statementType ,取值范围STATEMENT,PREPARED(默认值),CALLABLE
注意:selectKey操作会将操作查询结果赋值到insert元素的parameterType的⼊参实例下对应的属性中。并提供给insert语句使⽤
五、批量插⼊
WITH R AS
SELECT #{item.name} as a, #{item.age} as b
insert语句字段顺序INSERT INTO TStudent(name,age) SELECT a, b FROM R
若为Oracle则采⽤
INSERT INTO TStudent(name,age)
SELECT #{item.name} as a, #{item.age} as b FROM DUAL