@Test单元测试--CRUD模块

本文详细介绍了如何使用MyBatis进行CRUD操作的单元测试,包括根据ID查询记录、模糊查询、创建用户、删除和更新记录等步骤,帮助开发者掌握MyBatis的测试实践。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.R  根据id查询一条记录结果

表设计

CREATE TABLE `user` (
  `id`       int(11)       NOT NULL AUTO_INCREMENT,
  `username` varchar(32)   NOT NULL COMMENT '用户名称',
  `birthday` date          DEFAULT NULL COMMENT '生日',
  `sex`      char(1)       DEFAULT NULL COMMENT '性别',
  `address`  varchar(256)  DEFAULT NULL COMMENT '地址',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=27 DEFAULT CHARSET=utf8;
insert  into `user`(`id`,`username`,`birthday`,`sex`,`address`) 
values (1, '王五',  NULL,'2',NULL),
       (10,'张三', '2014-07-10','1','北京市'),
       (16,'张小明',NULL,'1','河南郑州'),
       (22,'陈小明',NULL,'1','河南郑州'),
       (24,'张三丰',NULL,'1','河南郑州'),
       (25,'陈小明',NULL,'1','河南郑州'),
       (26,'王五',  NULL,NULL,NULL);



id:标识 映射文件中的 sql
将sql语句封装到mappedStatement对象中,所以将id称为statement的id
parameterType:指定输入 参数的类型,这里指定int型 
#{}表示一个占位符号
#{id}:其中的id表示接收输入 的参数,参数名称就是id,如果输入 参数是简单类型,#{}中的参数名可以任意,可以value或其它名称
#{value}
*是所有的字段

模板:
<select id="方法名" parameterType="数据类型" resultType="POJO对象类名">
	SELECT * FROM USER WHERE id=一个占位符
</select>
如下:
<select id="findUserById" parameterType="int" resultType="com.app.mybatis.po.User">
	SELECT * FROM USER WHERE id=#{value}
</select>




类名:MyBatisFirst 代码单元测试

// mybatis配置文件
String resource = "SqlMapConfig.xml";
// 得到配置文件流
InputStream inputStream = Resources.getResourceAsStream(resource);

// 创建会话工厂,传入mybatis的配置文件信息
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
	.build(inputStream);

// 通过工厂得到SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();

CRUD模块//User user = sqlSession.selectOne("test.findUserById", 1);

System.out.println(自定义);

// 释放资源
sqlSession.close();


2.R  模糊查询并且列表

<select id="findUserByName" parameterType="java.lang.String" resultType="com.app.mybatis.po.User">
	SELECT * FROM USER WHERE username LIKE #{value}
</select>


R-->字段的username的模糊%${value}%

List<User> list = sqlSession.selectList("test.findUserByName", "%小明%");    //   #{value}     注意:selectList方法名调用
List<User> list = sqlSession.selectList("test.findUserByName", "小明");      // '%${value}%'


3.C  创建一个用户

<!-- C  创建一个用户 -->
<insert id="insertUser" parameterType="com.app.mybatis.po.User">
	<!-- 
	将插入数据的主键返回,返回到user对象中
		
	SELECT LAST_INSERT_ID():得到刚insert进去记录的主键值,只适用与自增主键
		
	keyProperty:将查询到主键值设置到parameterType指定的对象的哪个属性
	order:SELECT LAST_INSERT_ID()执行顺序,相对于insert语句来说它的执行顺序
	resultType:指定SELECT LAST_INSERT_ID()的结果类型
	 -->
	<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
		SELECT LAST_INSERT_ID()
	</selectKey>
	insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address})
	<!-- 
	使用mysql的uuid()生成主键
	执行过程:
	首先通过uuid()得到主键,将主键设置到user对象的id属性中
	其次在insert执行时,从user对象中取出id属性值
	 -->
	<!--  <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">
		SELECT uuid()
	</selectKey>
	insert into user(id,username,birthday,sex,address) value(#{id},#{username},#{birthday},#{sex},#{address}) -->
		
		
</insert>


        // 创建用户对象
	User user = new User();
	user.setUsername("王小军");
	user.setBirthday(new Date());
	user.setSex("2");
	user.setAddress("河南郑州");

	sqlSession.insert("test.insertUser", user);  // 创建一个用户,insert方法名调用

	// 提交事务
	sqlSession.commit();

	// 获取用户信息主键
	System.out.println(user.getId());
	// 关闭会话
	sqlSession.close();


4.D  根据id删除一条记录

<!-- D  删除 用户
根据id删除用户,需要输入 id值
 -->
<delete id="deleteUser" parameterType="java.lang.Integer">
	delete from user where id=#{id}
</delete>


        // 传入id删除 用户
	sqlSession.delete("test.deleteUser", 27);  // delete方法名调用

	// 提交事务
	sqlSession.commit();




5.U  根据id更新一条记录

<!-- U
根据id更新用户,需要输入id值
 -->
<update id="updateUser" parameterType="com.app.mybatis.po.User">
	update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address} 
	 where id=#{id}
</update>

        // 创建用户对象
	User user = new User();
	//必须设置id
	user.setId(25);
	user.setUsername("王海兴");
	user.setBirthday(new Date());
	user.setSex("2");
	user.setAddress("河南郑州");

	sqlSession.update("test.updateUser", user);  // update方法名调用
		
	// 提交事务
	sqlSession.commit();


6


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值