MyBatis原始Dao层开发:增删查改实战
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层的实现和管理。
2016-12-05 上传
2013-12-20 上传
2018-11-15 上传
2020-08-30 上传
2016-09-06 上传
2018-03-05 上传
2016-03-24 上传
2019-01-22 上传
weixin_38621365
- 粉丝: 7
- 资源: 906
最新资源
- Oracle Form觸發器、系統變量精解2
- Oracle Form屬性、內置子程序、觸發器、系統變量精解
- SMSCOM开发手册
- PIC C语言编程实例
- ubuntu命令参考卡片
- How to Write Program in Visual C++
- SVN权限控制全面解析
- apache+svn+MySQL+PHP+svnmanager+bugfree完全安装手册
- Thinking In Java 第三版目录版中文版PDF
- SNMP-简单网络管理协议(PDF)
- 10720路由器信息
- Apache+SVN+Trac配置详解
- 硬盘数据恢复教程 PDF格式
- 软件工程详细设计说明书
- JSON教程.pdf
- wince中文版(部分章节)