一、導入坐标
要想通過maven建立一個簡單的mybatis項目,首先需要的是要導入相關的坐标。需要導入的坐标如下:
<dependencies>
<!--mysql驅動坐标-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.46</version>
</dependency>
<!-- mybatis坐标 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!--單元測試坐标-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
</dependencies>
建立實體類User和在資料庫中插入建立對應的user表。
二、配置mybatis的核心配置檔案mybtis-config.xml
建立mybatis-config.xml的配置檔案,用于配置連接配接資料庫和注冊Mapper.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>
<properties resource="db.properties" />
<!--資料庫連接配接的環境配置-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!--每一個Mapper.xml都需要在mybatis核心配置檔案中注冊-->
<mappers>
<mapper resource="com/wkx/dao/UserMapper.xml"/>
</mappers>
</configuration>
①properties标簽:可以動态配置屬性。
可以全部在外部進行配置,如下:
<properties resource="db.properties" />
也可以在通過property标簽一部分在外部進行内部配置另一部分在内部進行配置(如下),增加配置的靈活性。
<properties resource="db.properties">
<property name="username" value="root"/>
<property name="password" value="123456"/>
</properties>
②環境配置environments标簽:用于配置資料的環境。可配置多個資料庫環境,但是SqlSessionFactory隻能選擇一個去使用。如下:
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
<environment id="test">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
可以在不同的環境下切換不同的資料環境,隻需要修改environments标簽中的default屬性對應不同環境下的id屬性,比如development和test不同的環境。
③映射器mappers:定義映射的路徑,告訴mybatis去哪裡找對應的語句。除了上述通過類路徑的資源引用方式,也可以通過其它的方式。比如通過包的形式将映射器接口全部注冊為映射器,如下:
<mappers>
<package name="com.wkx.dao"/>
</mappers>
問題:Mapper.xml的配置檔案在mybatis核心配置檔案注冊時找不到對應Mapper.xml,是因為maven讀取配置檔案時隻在resources的檔案目錄下尋找,是以需要在pom.xml檔案中配置過濾器。是以pom.xml中應該添加如下代碼:
<!--在build中配置resources,來防止資源導出失敗的原因-->
<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
三、建立Mapper.xml
完成mybatis-config.xml配置檔案的建立後,接着需要配置相關的Mapper.xml,進而進行SQL語句的編寫。
<mapper namespace="com.wkx.dao.UserMapper">
<select id="getUser" resultType="com.wkx.pojo.User">
select * from user
</select>
<!--使用User類作為輸入類型-->
<update id="updateUser" parameterType="com.wkx.pojo.User">
update user set name=#{name},pwd=#{pwd} where id=#{id}
</update>
<!--map類型(隻需要其中的key對應sql語句中的需要注入的值)-->
<update id="updateUserMap" parameterType="map">
update user set name=#{username} where id=#{uid}
</update>
</mapper>
①namespace命名空間:使用全限定類名對語句進行隔離,以及實作對接口的綁定。
②select、update等标簽中的id屬性對應的是Mapper接口中的方法名。通過id找到對應的方法需要執行的SQL語句。
③使用的Map集合類型對資料的SQL語句進行操作,隻需要将Map集合中key對應SQL語句中的需要注入的值。也就是說SQL注入的值可以不和實體類中屬性一緻。同時,使用Map集合而不是User類作為傳入類型進行傳輸時不需要将User類中所有資料傳輸。
四、編寫工具類
mybatis的使用需要以SqlSessionFactory為核心,使用SqlSessionFactory去生産SqlSession對象。建立一個工具類去生産SqlSession對象,以後使用mybatis便可以從該工具類中拿出SqlSession。
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory;
// 調用該類執行該靜态子產品中的代碼,擷取SqlSessionFactory
static {
try {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
// 通過該方法可以生産SqlSession對象
public SqlSession getSqlSession(){
SqlSession sqlSession = sqlSessionFactory.openSession();
return sqlSession;
}
}
五、測試
接着我們就可以利用mybatisUtils工具類生産的SqlSession對象去調用openSession執行對應的Mapper接口,就可以調用接口中的方法去執行對應的SQL語句。
具體測試類如下:
// 查詢所有使用者資訊
@Test
public void queryUserTest(){
MybatisUtils mybatisUtils = new MybatisUtils();
// 調用mybatisUtils中的getSqlSession方法擷取SqlSession對象
SqlSession sqlSession = mybatisUtils.getSqlSession();
// 執行SqlSession中的getMapper方法,以便後來來執行對應的Mapper接口方法
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
// 執行接口方法,配置完成mybatis會調用的對應的SQL語句執行
List<User> user = mapper.getUser();
sqlSession.close();
System.out.println(user);
}
// 使用Map資料類型對資料進行更新
@Test
public void updateUserMap(){
MybatisUtils mybatisUtils = new MybatisUtils();
SqlSession sqlSession = mybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map<String,Object> map = new HashMap<>();
map.put("username","王三");
// map.put("password","2334op");
map.put("uid","3");
int count = mapper.updateUserMap(map);
/*增删改的資料庫操作需要送出事務*/
sqlSession.commit();
sqlSession.close();
System.out.println(count);
}
注意:① 增删改的SQL語句操作都需要進行事務的送出。
② SqlSession使用完後要記得關閉。