MyBatis入門案例(一)
需求
實現以下功能:
根據用戶id查詢一個用戶信息
根據用戶名稱模糊查詢用戶信息列表
添加用戶
更新用戶
刪除用戶
需求分析:
根據用戶id查詢一個用戶信息:
SELECT * FROM USER WHERE id=1
根據用戶名稱模糊查詢用戶信息列表:
SELECT * FROM USER WHERE username LIKE '%張%'
根據用戶id查詢一個用戶信息
SqlMapConfig.xml
此方法爲mybatis的全局配置文件,配置了數據源、事務等運行環境,加載配置mapper.xml映射。
使用mybatis-3-config.dtd約束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>
<!-- 和spring整合後 environments配置將廢除 -->
<environments default="development">
<environment id="development">
<!-- 使用jdbc事務管理 -->
<transactionManager type="JDBC" />
<!-- 數據庫連接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url"
value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
<property name="username" value="root" />
<property name="password" value="123" />
</dataSource>
</environment>
</environments>
<!-- 加載mapper.xml -->
<!-- <mappers></mappers> -->
</configuration>
mapper.xml映射文件
早期ibatis的映射文件以表名命名,後期mybatis 映射文件命名方式爲:表名Mapper.xml。。
命名方式是不固定的。映射文件使用mybatis-3-mapper.dtd
pojo
resultType:將sql查詢結果集映射成java對象
將多個列的值映射到一個對象中,需要定義的pojo,resultType映射規則是sql查詢列名和pojo的屬性名必須一致方可完成映射。
mapper.xml
在SqlMapConfig.xml加載映射文件
編輯SqlMapConfig.xml,加載User.xml映射文件
代碼實現
@Test
public void testFindUserById()throws Exception{
//mybatis全局配置文件
String resource = "SqlMapConfig.xml";
//根據mybatis的全局配置文件構造 一個流
InputStream inputStream = Resources.getResourceAsStream(resource);
//創建SqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//創建SqlSession會話
SqlSession sqlSession = sqlSessionFactory.openSession();
//使用sqlSession查詢用戶
//第一個參數:statement的id,前邊要加namespace
//第二個參數:輸入的參數對象值
//selectOne用於返回單個對象,如果sql查詢返回一個列表(多個對象),如果使用selectOne報錯
User user = sqlSession.selectOne("test.findUserById", 1);
System.out.println(user);
//關閉sqlsession
sqlSession.close();
}
調試控制檯結果顯示
想看後續,請看 MyBatis入門案例(二)