MyBatis XML的方式来实现

使用这种方式的时候我们需要在配置文件中配置 mybatis xml 的文件路径:

这里需要注意的是:resources文件夹之下的这个mapper文件夹的名字要和配置文件中classpath后端mapper的名字要保持一致。

同时以上述的配置信息为例,mapper文件夹之下的xml文件一定是要以Mapper为结尾。

在xml文件中编写SQL语句

java 复制代码
@Mapper
public interface UserInfoMapperXML {
        List<UserInfo> selectAll();
}
java 复制代码
<mapper namespace="com.example.mybatis.mapper.UserInfoMapperXML">
    <select id="selectAll" resultType="com.example.mybatis.model.UserInfo">
        select * from user_info;
    </select>
</mapper>

上面的接口的名字和所在的路径要和xml文件中的相对应,接口中声明的方法名也要和xml文件中的id值相对应。

xml文件中的resultType表示这个方法返回的结果中的数据元素是什么类型,本案例就是UserInfo类型。

测试代码

接下来我们生成测试类来运行一下我们的代码:

java 复制代码
 @Test
    void sellectAll() {
        System.out.println(userInfoMapperXML.selectAll());
    }

新增数据

java 复制代码
        Integer insertUser(UserInfo userInfo);
java 复制代码
<insert id="insertUser">
        insert into user_info (username,password,age) VALUES(#{username},#{password},#{age})
    </insert>

XMl传入参数的方式和用注解的方式是一样的:

java 复制代码
 @Test
    void insertUser() {
        UserInfo userInfo=new UserInfo();
        userInfo.setPassword("12345678");
        userInfo.setUsername("user1");
        userInfo.setAge(18);
        userInfoMapperXML.insertUser(userInfo);
    }

我们也可以获取到自增的id

获取自增id

java 复制代码
        Integer insertUser2( @Param("Userinfo") UserInfo userInfo);
java 复制代码
<insert id="insertUser2" useGeneratedKeys="true" keyProperty="id">
        insert into user_info (username,password,age)
        VALUES(#{Userinfo.username},#{Userinfo.password},#{Userinfo.age})
    </insert>
java 复制代码
 @Test
    void insertUser2() {
        UserInfo userInfo=new UserInfo();
        userInfo.setPassword("12345");
        userInfo.setUsername("user3");
        userInfo.setAge(18);
       Integer result=userInfoMapperXML.insertUser2(userInfo);
       System.out.println("影响行数:"+result+",id:"+userInfo.getId());
    }

更新数据

接下来我们把id为12的用户的密码改为123456:

java 复制代码
        Integer updateUser(String newpassword,Integer id);
java 复制代码
 <update id="updateUser">
        update user_info set password=#{newpassword}
        where id=#{id}
    </update>
java 复制代码
 @Test
    void updateUser() {
        userInfoMapperXML.updateUser("123456",12);
    }

删除数据

我们把以id为12的数据删除为例:

java 复制代码
        Integer deleteUser(Integer id);
java 复制代码
 <delete id="deleteUser">
        delete from user_info where id=#{id}
    </delete>
java 复制代码
@Test
    void deleteUser() {
        userInfoMapperXML.deleteUser(12);
    }
相关推荐
JAVA面经实录9178 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
许彰午10 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
Bat U10 小时前
JavaEE|多线程初阶(七)
java·开发语言
misL NITL11 小时前
idea、mybatis报错Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are required
tomcat·intellij-idea·mybatis
掌心向暖RPA自动化13 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭13 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
TeamDev14 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手14 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
AI人工智能+电脑小能手15 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood15 小时前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven