MyBatis框架学习(2)(kuangshen):CRUD操作及配置解析及解决属性名和字段名不一致的问题

namespace

1、将上面案例中的UserMapper接口改名为 UserDao;
2、将UserMapper.xml中的namespace改为为UserDao的路径 .
3、再次测试

结论:
配置文件中namespace中的名称为对应Mapper接口或者Dao接口的完整包名,必须一致!

select

  • select标签是mybatis中最常用的标签之一
  • select语句有很多属性可以详细配置每一条SQL语句
    • SQL语句返回值类型。【完整的类名或者别名】
    • 传入SQL语句的参数类型 。【万能的Map,可以多尝试使用】
    • 命名空间中唯一的标识符
    • 接口中的方法名与映射文件中的SQL语句ID 一一对应
    • id
    • parameterType
    • resultType

需求:根据id查询用户

1、在UserMapper中添加对应方法

public interface UserMapper {
   
    // 查询全部用户
    List<User> getUserList();
    // 根据ID查询用户
    User getUserById(int id);
}

2、在UserMapper.xml中添加Select语句

<!--这里要加上mybatis这个数据库的名称是因为在IDEA中连接了数据库-->
<select id="getUserById"  resultType="com.fan.pojo.User">
        select * from mybatis.user where id = #{id}
</select>

3、测试类中测试

@Test
    public void getUserById() {
   
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        User user = mapper.getUserById(1);
        System.out.println(user);
        sqlSession.close();
    }

insert

我们一般使用insert标签进行插入操作,它的配置和select标签差不多!

需求:给数据库增加一个用户

1、在UserMapper接口中增加对应的方法

// insert一个用户
    int addUser(User user);

2、在UserMapper.xml中添加insert语句

	<!--对象中的属性,可以直接取出来-->
    <insert id="addUser" parameterType="com.fan.pojo.User">
        insert into mybatis.user (id, name, pwd) values (#{id}, #{name}, #{pwd});
    </insert>

3、测试

// 增删改需要提交事务
    @Test
    public void addUser() {
   
        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        int res = mapper.addUser(new User(5, "哈哈", "123333"));
        if (res > 0) {
   
            System.out.println("插入成功!");
        }

        // 提交事务
        sqlSession.commit();
        sq
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值