Mybatis面试系列五

1、如何执行批量插入?

首先,创建一个简单的insert语句:

复制代码
 <insert id="insertname">
 insert into names(name) values(#{value})
 </insert>

然后在java代码中像下面这样执行批处理插入:

复制代码
 list <string> names=new arraylist();
 names.add("fred");
 names.add("barney");
 names.add("betty");
 names.add("wilma");
 //注意这里executortype.batch
 sqlsession sqlsession=
 sqlsessionfactory.opensession(executortype.batch);
 try{
 namemapper mapper=sqlsession.getmapper(namemapper.class);
 for(string name:names){
 mapper.insertname(name);
 }
 sqlsession.commit();
 }catch(Exceptione){
 e.printStackTrace();
 sqlSession.rollback();
throw e;
 }
 finally {
 sqlsession.close();
 }

2、如何获取自动生成的(主)键值?

insert 方法总是返回一个 int 值 ,这个值代表的是插入的行数。

如果采用自增长策略,自动生成的键值在 insert 方法执行完后可以被设置到传入

的参数对象中。

示例:

复制代码
<insert id="insertname" usegeneratedkeys="true" keyproperty="
 id">
 insert into names (name) values (#{name})
 </insert>
 name name =newname();
 name.setname("fred");
 int rows = mapper.insertname(name);
 // 完成后,id已经被设置到对象中
system.out.println("rows inserted = " + rows);
 system.out.println("generated key value = " + name.getid());

3、在mapper中如何传递多个参数?

1、第一种:

DAO层的函数

复制代码
public UserselectUser(Stringname,Stringarea);

对应的xml,#{0}代表接收的是dao层中的第一个参数,#{1}代表dao层中第二

参数,更多参数一致往后加即可。

复制代码
<select id="selectUser" resultMap="BaseResultMap">
 select * from user_user_t  where user_name=#{0}
 and user_area=#{1}
 </select>

2、第二种:使用@param注解:

复制代码
 public interface usermapper{
 user selectuser(@param("username") string
 username,@param("hashedpassword") string hashedpassword);
 }

然后,就可以在xml像下面这样使用(推荐封装为一个map,作为单个参数传递给

mapper):

复制代码
<select id="selectuser" resulttype="user">
 selec tid,username,hashedpassword
 from some_table
 where username=#{username}
 and hashedpassword=#{hashedpassword}
 </select>

3、第三种:多个参数封装成map

复制代码
try {
 //映射文件的命名空间.SQL片段的ID,就可以调用对应的映射文件中的
SQL
 //由于我们的参数超过了两个,而方法中只有一个Object参数收集,因此
我们使用Map集合来装载我们的参数
Map <String, Object > map = new HashMap();
 map.put("start", start);
 map.put("end", end);
 return sqlSession.selectList("StudentID.pagination", map);
 } catch (Exception e) {
 e.printStackTrace();
 sqlSession.rollback();
 throw e;
 } finally {
 MybatisUtil.closeSqlSession();
 }

阿里云新用户专享特惠,上云优惠聚集地!

相关推荐
脸大是真的好~4 分钟前
黑马JAVAWeb-03 SpringBootWeb-分层解耦-三层架构-@SpringBootApplication注解-IOC控制反转-DI依赖注入
java
XiaoYu20028 分钟前
第1章 核心竞争力和职业规划
前端·面试·程序员
微露清风17 分钟前
系统性学习C++-第十讲-stack 和 quene
java·c++·学习
一蓑烟雨任平生√21 分钟前
两种上传图片的方式——91张先生
java·ossinsight
凤凰战士芭比Q35 分钟前
部署我的世界-java版服务器-frp内网穿透
java·服务器
小肖爱笑不爱笑36 分钟前
2025/11/5 IO流(字节流、字符流、字节缓冲流、字符缓冲流) 计算机存储规则(ASCII、GBK、Unicode)
java·开发语言·算法
CodeCraft Studio1 小时前
PPT处理控件Aspose.Slides教程:使用Java将PowerPoint笔记导出为PDF
java·笔记·pdf·powerpoint·aspose·ppt转pdf·java将ppt导出pdf
手握风云-1 小时前
Java 数据结构第二十八期:反射、枚举以及 lambda 表达式
java·开发语言
ᐇ9591 小时前
Java Vector集合全面解析:线程安全的动态数组
java·开发语言
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 广州网红点打卡介绍网站为例,包含答辩的问题和答案
java·eclipse