Mybatis——CRUD

昌山
2023-12-01

namespace

namespace中的包名要和 Dao/mapper 接口的包名一致

select选择,查询语句;

  • id : 就是对应的namespace中的方法名;
  • resultType:Sql语句执行的返回值!
  • parameterType : 参数类型!

1.编写接口

//根据ID查询用户
User getUserById(int id);

2.编写对应的mapper中的sql语句

<select id="getUserById" parameterType="int" resultType="com.kuang.pojo.User">
        select * from mybatis.user where id = #{id}
</select>
​

3.测试


```java
  @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 id="addUser" parameterType="com.kuang.pojo.User">
    insert into mybatis.user (id, name, pwd) values (#{id},#{name},#{pwd});
</insert>

update

<update id="updateUser" parameterType="com.kuang.pojo.User">
        update mybatis.user set name=#{name},pwd=#{pwd}  where id = #{id} ;
    </update>
​

Delete

<delete id="deleteUser" parameterType="int">
        delete from mybatis.user where id = #{id};
    </delete>

注意点:增删改需要提交事务!

分析错误

  • 标签不要匹配错
  • resource 绑定mapper,需要使用路径!
  • 程序配置文件必须符合规范!
  • NullPointerException,没有注册到资源!输出的xml文件中存在中文乱码问题!
  • maven资源没有导出问题!

万能Map

假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们应当考虑使用Map!

 //万能的Map
    int addUser2(Map<String,Object> map);
​​
 
   <!--对象中的属性,可以直接取出来    传递map的key-->
    <insert id="addUser" parameterType="map">
        insert into mybatis.user (id, pwd) values (#{userid},#{passWord});
    </insert>  
  
 @Test
    public void addUser2(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
​
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
​
​
        Map<String, Object> map = new HashMap<String, Object>();
​
        map.put("userid",5);
        map.put("passWord","2222333");
​
        mapper.addUser2(map);
​
        sqlSession.close();
    }
​

Map传递参数,直接在sql中取出key即可【parameterType=“map”】
对象传递参数,直接在sql中取对象的属性即可!【parameterType=“Object”】
只有一个基本类型参数的情况下,可以直接在sql中取到!
多个参数用Map,或者注解!

 类似资料: