MyBatis原始Dao层开发:增删查改实战
87 浏览量
更新于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层的实现和管理。
点击了解资源详情
点击了解资源详情
点击了解资源详情
2018-11-15 上传
2020-08-30 上传
2016-09-06 上传
2018-03-05 上传
2016-03-24 上传
2019-01-22 上传
weixin_38621365
- 粉丝: 7
- 资源: 906
最新资源
- JHU荣誉单变量微积分课程教案介绍
- Naruto爱好者必备CLI测试应用
- Android应用显示Ignaz-Taschner-Gymnasium取消课程概览
- ASP学生信息档案管理系统毕业设计及完整源码
- Java商城源码解析:酒店管理系统快速开发指南
- 构建可解析文本框:.NET 3.5中实现文本解析与验证
- Java语言打造任天堂红白机模拟器—nes4j解析
- 基于Hadoop和Hive的网络流量分析工具介绍
- Unity实现帝国象棋:从游戏到复刻
- WordPress文档嵌入插件:无需浏览器插件即可上传和显示文档
- Android开源项目精选:优秀项目篇
- 黑色设计商务酷站模板 - 网站构建新选择
- Rollup插件去除JS文件横幅:横扫许可证头
- AngularDart中Hammock服务的使用与REST API集成
- 开源AVR编程器:高效、低成本的微控制器编程解决方案
- Anya Keller 图片组合的开发部署记录