MyBatis原始Dao层开发:增删查改实战

0 下载量 184 浏览量 更新于2024-09-01 收藏 67KB PDF 举报
"这篇文章主要介绍了如何使用MyBatis框架开发Dao层,重点是两种不同的实现方式,即原始Dao层开发。作者将分享一个基于MyBatis的数据库增删查改案例,使用的MyBatis版本为3.2.7,开发环境为Eclipse,数据库为MySQL,JDK版本为1.8.0_151。" 在MyBatis中,开发Dao层(Data Access Object层)是连接业务逻辑和数据库操作的关键。Dao层的主要职责是处理与数据库的交互,包括查询、插入、更新和删除等操作。文章提到了两种开发Dao层的方式: 1. 原始Dao层开发 在原始Dao层开发中,你需要直接编写SQL语句并将其与Java代码集成。这通常涉及到创建一个接口,该接口包含对数据库操作的方法,然后在对应的Java实现类中写入SQL执行逻辑。例如,你可以创建一个UserDao接口,包含`getUserById(int id)`这样的方法,然后在UserDaoImpl类中实现这个方法,内部使用SqlSession执行SQL获取用户。 ```java public interface UserDao { User getUserById(int id); } public class UserDaoImpl implements UserDao { private SqlSessionFactory sqlSessionFactory; // 构造器注入SqlSessionFactory public UserDaoImpl(SqlSessionFactory sqlSessionFactory) { this.sqlSessionFactory = sqlSessionFactory; } @Override public User getUserById(int id) { SqlSession session = sqlSessionFactory.openSession(); try { return session.selectOne("com.example.UserMapper.getUserById", id); } finally { session.close(); } } } ``` 这里,`"com.example.UserMapper.getUserById"`是映射文件中对应SQL的ID,MyBatis会根据这个ID找到对应的SQL并执行。 2. Mapper动态代理开发Dao层 另一种方式是使用Mapper动态代理,这种方式更为简洁和灵活。首先,你需要创建一个Mapper接口,然后在对应的XML文件中编写SQL语句。MyBatis会自动生成Mapper接口的实现类,这样你就可以直接通过接口调用方法来执行数据库操作。这种方式可以避免手动创建实现类,并且SQL和Java代码分离,更易于维护。 ```java public interface UserDaoMapper { User getUserById(int id); } ``` 在对应的UserMapper.xml文件中: ```xml <mapper namespace="com.example.UserMapper"> <select id="getUserById" resultType="com.example.User"> SELECT * FROM user WHERE id = #{id} </select> </mapper> ``` 然后在Service或者Controller中注入UserDaoMapper,直接调用`getUserById()`方法。 MyBatis的核心组件包括SqlSession、SqlSessionFactory和SqlSessionFactoryBuilder: - SqlSessionFactoryBuilder:用于构建SqlSessionFactory,通常只在项目初始化时使用一次,不需要作为单例管理。 - SqlSessionFactory:用于创建SqlSession的工厂,建议使用单例模式管理,因为创建后无需频繁更改配置。 - SqlSession:提供对数据库操作的方法,如`selectOne()`, `selectList()`等。由于SqlSession不是线程安全的,因此每个数据库操作应创建新的SqlSession实例,一般在方法体内声明为局部变量。 在实际开发中,为了更好地管理和控制事务,通常会结合Spring框架,使用Spring的`@Transactional`注解管理事务,以及使用Spring的`@Autowired`注解自动注入Mapper接口,简化Dao层的实现和管理。