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);
    }
相关推荐
言慢行善17 小时前
sqlserver模糊查询问题
java·数据库·sqlserver
专吃海绵宝宝菠萝屋的派大星17 小时前
使用Dify对接自己开发的mcp
java·服务器·前端
大数据新鸟18 小时前
操作系统之虚拟内存
java·服务器·网络
Tong Z18 小时前
常见的限流算法和实现原理
java·开发语言
凭君语未可18 小时前
Java 中的实现类是什么
java·开发语言
He少年18 小时前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
克里斯蒂亚诺更新18 小时前
myeclipse的pojie
java·ide·myeclipse
迷藏49418 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
迷藏49418 小时前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链
qq_4335021818 小时前
Codex cli 飞书文档创建进阶实用命令 + Skill 创建&使用 小白完整教程
java·前端·飞书