MySQL数据库持久层是指负责将应用程序中的数据持久化到MySQL数据库中的一层。它通常由一组数据访问对象(DAO)组成,这些对象负责与数据库进行交互,执行CRUD(创建、读取、更新、删除)操作。持久层的主要目的是将数据访问逻辑与业务逻辑分离,从而提高代码的可维护性和可重用性。
假设我们有一个用户表(user),包含id、name和age字段。我们可以使用MyBatis来实现持久层。
User.java(实体类)
public class User {
private int id;
private String name;
private int age;
// 省略getter和setter方法
}
UserMapper.xml(映射文件)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper">
<select id="getUserById" resultType="com.example.entity.User">
SELECT id, name, age FROM user WHERE id = #{id}
</select>
<insert id="insertUser" parameterType="com.example.entity.User">
INSERT INTO user (name, age) VALUES (#{name}, #{age})
</insert>
</mapper>
UserMapper.java(接口)
public interface UserMapper {
User getUserById(int id);
void insertUser(User user);
}
MyBatis配置文件(mybatis-config.xml)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mydb"/>
<property name="username" value="root"/>
<property name="password" value="password"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>
参考链接
领取专属 10元无门槛券
手把手带您无忧上云