ibatis插入数据库时返回主键(sqlserver数据库)

ibatis插入数据后立即返回主键值,sqlserver数据库,一开始采用如下:

<insert id="insertEvalutionComment" parameterClass="com.dt.jxhd.domain.evalution_teacher_comment">
    	insert into evalution_comment (grade, comment)
    	values (#grade:VARCHAR#, #comment:VARCHAR#)
    	<selectKey resultClass="int" keyProperty="id" >     
        	select SCOPE_IDENTITY() as id  
    	</selectKey>
	</insert>
SELECT SCOPE_IDENTITY()会报错,报如下错误:

[java.sql.PreparedStatement]-[DEBUG]  {pstm-100073} PreparedStatement:       insert into evalution_comment (grade, comment)      values (?, ?)        
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100073} Parameters: [10, 20000]
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100073} Types: [java.lang.String, java.lang.String]
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100074} PreparedStatement:                SELECT SCOPE_IDENTITY() as id        
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100074} Parameters: []
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100074} Types: []
[java.sql.ResultSet]-[DEBUG]  {rset-100075} ResultSet
[java.sql.ResultSet]-[DEBUG]  {rset-100075} Header: [id]
[java.sql.ResultSet]-[DEBUG]  {rset-100075} Result: [0]
[org.apache.struts2.dispatcher.Dispatcher]-[ERROR]  Could not find action or result
No result defined for action com.dt.jxhd.action.PjglAction and result Exception - action - file:/D:/Program%20Files/Apache%20Software%20Foundation/Tomcat%208.0/webapps/jxhd/WEB-INF/classes/strutsConfig.xml:549:86

后来换成“SELECT @@IDENTITY AS ID”

<insert id="insertEvalutionComment" parameterClass="com.dt.jxhd.domain.evalution_teacher_comment">
    	insert into evalution_comment (grade, comment)
    	values (#grade:VARCHAR#, #comment:VARCHAR#)
    	<selectKey resultClass="int" keyProperty="id" >
    		SELECT @@IDENTITY AS ID
    	</selectKey>
 	</insert>
java代码是:

return ((Integer)getSqlMapClientTemplate().insert("evalution_comment.insertEvalutionComment",t_teacher_comment)).intValue();
测试可以通过

打印日志:

[java.sql.PreparedStatement]-[DEBUG]  {pstm-100025} PreparedStatement:       insert into evalution_comment (grade, comment)      values (?, ?)         
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100025} Parameters: [10, 该生难教]
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100025} Types: [java.lang.String, java.lang.String]
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100026} PreparedStatement:        SELECT @@IDENTITY AS ID      
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100026} Parameters: []
[java.sql.PreparedStatement]-[DEBUG]  {pstm-100026} Types: []
[java.sql.ResultSet]-[DEBUG]  {rset-100027} ResultSet
[java.sql.ResultSet]-[DEBUG]  {rset-100027} Header: [ID]
[java.sql.ResultSet]-[DEBUG]  {rset-100027} Result: [43]





















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用MyBatis和SQL Server数据库进行批量插入去重的详细代码: 1. 创建数据库表 首先,我们需要在SQL Server数据库中创建一个表,用于存储数据。假设我们要插入的表名为“user”,包含三个字段:id、name和age。 CREATE TABLE user ( id INT PRIMARY KEY, name VARCHAR(50), age INT ); 2. 创建Java实体类 接下来,我们需要创建一个Java实体类,用于映射数据库表中的数据。假设我们的实体类名为User,包含三个属性:id、name和age。 public class User { private int id; private String name; private int age; // 省略getter和setter方法 } 3. 创建MyBatis映射文件 然后,我们需要创建一个MyBatis映射文件,用于定义SQL语句和Java实体类之间的映射关系。假设我们的映射文件名为UserMapper.xml,包含一个insertUsers方法,用于批量插入用户数据。 <?xml version="1." encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.mapper.UserMapper"> <insert id="insertUsers" parameterType="java.util.List"> INSERT INTO user (id, name, age) SELECT #{id}, #{name}, #{age} WHERE NOT EXISTS ( SELECT 1 FROM user WHERE id = #{id} ) </insert> </mapper> 4. 创建MyBatis接口 接着,我们需要创建一个MyBatis接口,用于调用映射文件中定义的SQL语句。假设我们的接口名为UserMapper,包含一个insertUsers方法,用于批量插入用户数据。 public interface UserMapper { void insertUsers(List<User> users); } 5. 编写Java代码 最后,我们需要编写Java代码,调用MyBatis接口中定义的方法,实现批量插入去重的功能。 首先,我们需要创建一个SqlSessionFactory对象,用于创建SqlSession对象。 String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); 然后,我们需要创建一个SqlSession对象,用于执行SQL语句。 SqlSession sqlSession = sqlSessionFactory.openSession(); 接着,我们需要获取UserMapper接口的实现类对象。 UserMapper userMapper = sqlSession.getMapper(UserMapper.class); 最后,我们可以调用insertUsers方法,将用户数据批量插入数据库中。 List<User> users = new ArrayList<>(); users.add(new User(1, "张三", 20)); users.add(new User(2, "李四", 25)); users.add(new User(3, "王五", 30)); userMapper.insertUsers(users); 完整的Java代码如下: import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.List; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class Main { public static void main(String[] args) throws IOException { String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); List<User> users = new ArrayList<>(); users.add(new User(1, "张三", 20)); users.add(new User(2, "李四", 25)); users.add(new User(3, "王五", 30)); userMapper.insertUsers(users); sqlSession.commit(); sqlSession.close(); } } 注意:在执行完SQL语句后,需要调用SqlSession对象的commit方法提交事务,并调用close方法关闭SqlSession对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值