基于代理 Dao 实现 CRUD 操作

基于代理 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);
    }

猜你喜欢

转载自blog.csdn.net/weixin_44883727/article/details/106994342