基于代理 Dao 实现 CRUD 操作
1、根据 ID 查询
1.1在持久层接口中添加 findById 方法
/**
* 根据id查询
*/
User findById( Integer userId);
1.2在用户的映射配置文件中配置
<select id="findById" resultMap="userMap" parameterType="int">
SELECT * FROM USER WHERE id =#{uid}
</select>
细节:
resultType 属性:
用于指定结果集的类型。
parameterType 属性:
用于指定传入参数的类型。
sql 语句中使用#{}字符:
它代表占位符,相当于原来 jdbc 部分所学的?,都是用于执行语句时替换 实际的数据。具体的数据是由#{}里面的内容决定的。
#{}中内容的写法:
由于数据类型是基本类型,所以此处可以随意写。
resultMap后面会讲
1.3在测试类添加测试
/*通过id查询*/
@Test
public void findById() throws IOException {
init();
User u = userDao.findById(45);
System.out.println(u);
destory();
}
具体初始化还有关闭函数封装:
@Before
public void init() throws IOException {
//1、读取配置文件
in = Resources.getResourceAsStream("SqlMapConfig.xml");
//2、创建sqlSessionFactory的构建对象
builder = new SqlSessionFactoryBuilder();
//3、使用构建者创建工厂对象sqlSessionFactory
factory = builder.build(in);
//4、使用sqlSessionFactory生产SqlSession对象
session = factory.openSession();
//5、使用SqlSession创建dao接口的代理对象
userDao = session.getMapper(IUserDao.class);
}
@After
public void destory() throws IOException {
session.commit();
//7、释放资源
session.close();
in.close();
}
2 、保存操作
2.1在持久层接口中添加新增方法
/**
* 保存用户
*/
int saveUser(User user);
2.2在用户的映射配置文件中配置
<!--保存用戶-->
<insert id="saveUser" parameterType="com.yg.domain.User">
<!-- 配置保存時獲取插入的id-->
<selectKey keyColumn="id" keyProperty="userId" resultType="int">
SELECT last_insert_id();
</selectKey>
INSERT INTO USER (username,birthday,sex,address)
VALUE (#{userName},#{userBirthday},#{userSex},#{userAddress})
</insert>
2.3添加测试类中的测试方法
/*保存操作*/
@Test
public void savetest() {
User user = new User();
user.setUserName("yy");
user.setUserAddress("湖南科技大学");
user.setUserBirthday(new Date());
user.setUserSex("男");
System.out.println("保存操作前" + user);
//执行保存操作
userDao.saveUser(user);
System.out.println("保存操作后" + user);
}
问题扩展:新增用户 id 的返回值:
新增用户后,同时还要返回当前新增用户的 id 值,因为 id 是由数据库的自动增长来实现的,所以就相
当于我们要在新增后将自动增长 auto_increment 的值返回。
上面代码已经配置了。
3、用户更新
3.1在持久层接口中添加更新方法
/**
* 更新用戶
*/
int updateUser(User user);
3.2在用户的映射配置文件中配置
<!--更新用戶-->
<update id="updateUser" parameterType="com.yg.domain.User">
UPDATE USER SET username=#{userName},birthday=#{userBirthday},sex=#{userSex}
,address=#{userAddress} WHERE id=#{userId}
</update>
3.3加入更新的测试方法
/*更新操作*/
@Test
public void updateTest() {
//1、根據id查詢
User user = userDao.findById(45);
user.setUserName("英俊");
int res = userDao.updateUser(user);
System.out.println("res");
}
用户删除
4.1在持久层接口中添加删除方法
/**
* 用戶刪除
*/
int deleteUser(Integer id);
4.2、在用户的映射配置文件中配置
<!--刪除操作-->
<delete id="deleteUser" parameterType="int">
DELETE FROM USER WHERE id=#{userId}
</delete>
4.3加入删除的测试方法
/*删除操作*/
@Test
public void deleteTest() {
int res = userDao.deleteUser(52);
System.out.println(res);
}