一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - MyBatis入門初體驗之使用大全(2)

MyBatis入門初體驗之使用大全(2)

2020-05-31 12:52java教程網 JAVA教程

這篇文章主要介紹了MyBatis入門初體驗之使用大全(2)的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

MyBatis簡介

MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,并且改名為MyBatis 。2013年11月遷移到Github。
iBATIS一詞來源于“internet”和“abatis”的組合,是一個基于Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)

1.所需jar包

這里單獨討論MyBatis的使用,只需要放入mybatis-x.x.x.jar包即可。

如果使用maven構建項目,則需要在pom.xml的dependency中放入如下配置:

?
1
2
3
4
5
<dependency>
<groupid>org.mybatis</groupid>
mybatis</artifactid>
<version>3.2.2</version>
</dependency>

公司目前用的3.2.2的,可以根據自己的jar包放入版本號。

如果你是與相應的框架一起集成,則需要放入集成包,比如,我們公司用mybatis與spring集成,

則還需要加入mybatis-spring-xxx.jar包,根據實際情況決定。當然了,數據庫驅動jar包也是少不了的。

2.從XML中構建SqlSessionFactory

每個基于 MyBatis 的應用都是以一個 SqlSessionFactory 的實例為中心的。

SqlSessionFactory 的實例可以通過 SqlSessionFactoryBuilder 獲得。

而 SqlSessionFactoryBuilder 則可以從 XML 配置文件或一個預先定制的 Configuration 的實例構建出 SqlSessionFactory 的實例。

從 XML 文件中構建 SqlSessionFactory 的實例非常簡單,建議使用類路徑下的資源文件進行配置。

但是也可以使用任意的輸入流(InputStream)實例,包括字符串形式的文件路徑或者 file:// 的 URL 形式的文件路徑來配置。

MyBatis 包含一個名叫 Resources 的工具類,它包含一些實用方法,可使從 classpath 或其他位置加載資源文件更加容易。

例如:

?
1
2
3
String resource = "mybatis-config.xml";
InputStream is = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);

XML 配置文件(configuration XML)中包含了對 MyBatis 系統的核心設置,包含獲取數據庫連接實例的數據源(DataSource)

和決定事務范圍和控制方式的事務管理器(TransactionManager)。配置文件詳細往后再說。

例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<!--?xml version="1.0" encoding="UTF-8" ?-->
<configuration>
<environments default="development">
<environment id="development">
<transactionmanager type="JDBC">
<datasource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver">
<property name="url" value="jdbc:mysql://192.168.200.12:3306/test_mybatis">
<property name="username" value="root">
<property name="password" value="root123">
</property></property></property></property></datasource>
</transactionmanager></environment>
</environments>
<mappers>
<!-- 注冊UserMainMapper.xml文件,UserMainMapper.xml位于com.lanhuigu.mybatis.map這個包下,
所以resource寫成com/lanhuigu/mybatis/map/UserMainMapper.xml-->
<mapper resource="com/lanhuigu/mybatis/map/UserMainMapper.xml"></mapper>
</mappers>
</configuration>

environment 元素體中包含了事務管理和連接池的配置。mappers 元素則是包含一組 mapper 映射器(這些 mapper 的 XML 文件包含了 SQL 代碼和映射定義信息)。

3.從SqlSessionFactory中獲取SqlSession

既然有了 SqlSessionFactory ,我們就可以從中獲得 SqlSession 的實例。SqlSession 完全包含了面向數據庫執行 SQL 命令所需的所有方法。

你可以通過 SqlSession 實例來直接執行已映射的 SQL 語句。例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
SqlSessionFactory sqlSessionFactory = null;// XML構建SqlSessionFactory工廠實例
SqlSession session = null;// 從SqlSessionFactory工廠實例中獲取SqlSession對象
try {
String resource = "mybatis-config.xml";
InputStream is = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
session = sqlSessionFactory.openSession();
User user = session.selectOne("com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById", 1);
System.out.println(user.getUsername());
} finally {
session.close();
}

用這種方式執行映射沒什么問題,我們也可以用一種更加簡潔的方式執行映射。
使用對于給定語句能夠合理描述參數和返回值的接口(比如說UserMainMapper.class),

你現在不但可以執行更清晰和類型安全的代碼,而且還不用擔心易錯的字符串字面值以及強制類型轉換。例如:

?
1
2
3
SqlSession session = sqlSessionFactory.openSession();
UserMainMapper userMainMapper = session.getMapper(UserMainMapper.class);
User user = userMainMapper .queryUserMainById(1);

4.實例

光看不練容易迷糊,看看實例,在回去讀文檔,或許效果會更好。

準備jar包:

mybatis-3.2.2.jar(mybatis)

mysql-connector-java-5.1.21.jar(數據庫驅動)

junit-4.4.jar(測試,不想用這個junit,用main方法測試也行)

項目結構:

MyBatis入門初體驗之使用大全(2)

數據庫:

?
1
2
3
4
5
6
7
CREATE TABLE `t_user_main` (
`f_id` int(11) NOT NULL,
`f_username` varchar(20) DEFAULT NULL,
`f_age` int(3) DEFAULT NULL,
PRIMARY KEY (`f_id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
INSERT INTO t_user_main VALUES(1,'testMyBatis',25);

mybatis的xml配置--mybatis-config.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<!--?xml version="1.0" encoding="UTF-8" ?-->
<configuration>
<environments default="development">
<environment id="development">
<transactionmanager type="JDBC">
<datasource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver">
<property name="url" value="jdbc:mysql://192.168.200.12:3306/test_mybatis">
<property name="username" value="root">
<property name="password" value="root123">
</property></property></property></property></datasource>
</transactionmanager></environment>
</environments>
<mappers>
<!-- 注冊UserMainMapper.xml文件,UserMainMapper.xml位于com.lanhuigu.mybatis.map這個包下,
所以resource寫成com/lanhuigu/mybatis/map/UserMainMapper.xml-->
<mapper resource="com/lanhuigu/mybatis/map/UserMainMapper.xml"></mapper>
</mappers>
</configuration>

User.java:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
package com.lanhuigu.mybatis.entity;
import java.io.Serializable;
public class User implements Serializable{
private static final long serialVersionUID = -3412068097348759984L;
private Integer id;
private String username;
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}

UserMainMapper.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<!--?xml version="1.0" encoding="UTF-8" ?-->
<!--
為這個mapper指定一個唯一的namespace,namespace的值習慣上設置成包名+去掉sql映射文件后綴的文件名,
這樣就能夠保證namespace的值是唯一的,例如namespace="com.lanhuigu.mybatis.map.UserMainMapper"
就是com.lanhuigu.mybatis.map(包名)+UserMainMapper(UserMainMapper.xml文件去除后綴)
-->
<mapper namespace="com.lanhuigu.mybatis.map.UserMainMapper">
<!--
在select標簽中編寫查詢的SQL語句, 設置select標簽的id屬性為queryUserMainById,id屬性值必須是唯一的,
不能夠重復使用parameterType屬性指明查詢時使用的參數類型,resultType屬性指明查詢返回的結果集類型
resultType="com.lanhuigu.mybatis.entity.User"就表示將查詢結果封裝成一個User類的對象返回
User類就是users表所對應的實體類
-->
<select id="queryUserMainById" parametertype="int" resulttype="com.lanhuigu.mybatis.entity.User">
select
f_id id,
f_username username,
f_age age
from t_user_main
where f_id = #{id}
</select>
</mapper>

MyBatisTest.java測試代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package com.lanhuigu.mybatis;
import java.io.IOException;
import java.io.InputStream;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
import com.lanhuigu.mybatis.entity.User;
public class MyBatisTest {
@Test
public void testMyBatis() throws IOException {
SqlSessionFactory sqlSessionFactory = null;// XML構建SqlSessionFactory工廠實例
SqlSession session = null;// 從SqlSessionFactory工廠實例中獲取SqlSession對象
try {
//1.mybatis的配置文件路徑,這里放在classpath下,相當于src下
String resource = "mybatis-config.xml";
//2.讀取mybatis配置文件,同時創建SqlSessionFactory工廠實例
//======2.1使用類加載器加載mybatis的配置文件(它也加載關聯的映射文件)
//InputStream is = MyBatisTest.class.getClassLoader().getResourceAsStream(resource);
//構建SqlSessionFactory工廠
//sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//======2.2使用MyBatis提供的Resources類加載mybatis的配置文件(它也加載關聯的映射文件)
//Reader reader = Resources.getResourceAsReader(resource);
//構建SqlSessionFactory工廠
//sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
//======2.3 使用MyBatis提供的Resources類加載mybatis的配置文件
InputStream is = Resources.getResourceAsStream(resource);
//構建SqlSessionFactory工廠
sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.創建能執行映射文件中sql的sqlSession
session = sqlSessionFactory.openSession();
/**
* 映射sql的標識字符串:
* com.lanhuigu.mybatis.map.UserMainMapper是UserMainMapper.xml文件中mapper標簽的namespace屬性的值,
* queryUserMainById是UserMainMapper.xml文件select標簽的id屬性值,通過select標簽的id屬性值,
* 通過這兩個的組合就可以找到要執行的SQL
*/
//執行查詢返回一個唯一user對象的sql,注意:"com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById"為映射sql的標識字符串
User user = session.selectOne("com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById", 1);
System.out.println(user.getUsername());
} finally {
session.close();
}
}
}

控制臺輸出:

MyBatis入門初體驗之使用大全(2)

對于以上實例,在測試代碼中:

?
1
2
User user = session.selectOne("com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById", 1);
System.out.println(user.getUsername());

這段代碼使用起來是不是很不爽,我們說過有種更直接的方式:

在項目結構map下加上一個映射接口:

?
1
2
3
4
5
package com.lanhuigu.mybatis.map;
import com.lanhuigu.mybatis.entity.User;
public interface UserMainMapper {
public User queryUserMainById(int id);
}

同時,將測試的代碼做如下修改:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package com.lanhuigu.mybatis;
import java.io.IOException;
import java.io.InputStream;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
import com.lanhuigu.mybatis.entity.User;
import com.lanhuigu.mybatis.map.UserMainMapper;
public class MyBatisTest {
@Test
public void testMyBatis() throws IOException {
SqlSessionFactory sqlSessionFactory = null;// XML構建SqlSessionFactory工廠實例
SqlSession session = null;// 從SqlSessionFactory工廠實例中獲取SqlSession對象
try {
//1.mybatis的配置文件路徑,這里放在classpath下,相當于src下
String resource = "mybatis-config.xml";
//2.讀取mybatis配置文件,同時創建SqlSessionFactory工廠實例
//======2.1使用類加載器加載mybatis的配置文件(它也加載關聯的映射文件)
//InputStream is = MyBatisTest.class.getClassLoader().getResourceAsStream(resource);
//構建SqlSessionFactory工廠
//sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//======2.2使用MyBatis提供的Resources類加載mybatis的配置文件(它也加載關聯的映射文件)
//Reader reader = Resources.getResourceAsReader(resource);
//構建SqlSessionFactory工廠
//sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
//======2.3 使用MyBatis提供的Resources類加載mybatis的配置文件
InputStream is = Resources.getResourceAsStream(resource);
//構建SqlSessionFactory工廠
sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.創建能執行映射文件中sql的sqlSession
session = sqlSessionFactory.openSession();
/**
* 映射sql的標識字符串:
* com.lanhuigu.mybatis.map.UserMainMapper是UserMainMapper.xml文件中mapper標簽的namespace屬性的值,
* queryUserMainById是UserMainMapper.xml文件select標簽的id屬性值,通過select標簽的id屬性值,
* 通過這兩個的組合就可以找到要執行的SQL
*/
//執行查詢返回一個唯一user對象的sql,注意:"com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById"為映射sql的標識字符串
/*User user = session.selectOne("com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById", 1);
System.out.println(user.getUsername());*/
UserMainMapper userMainMapper = session.getMapper(UserMainMapper.class);
User user = userMainMapper.queryUserMainById(1);
System.out.println(user.getUsername());
} finally {
session.close();
}
}
}

把之前的查詢部分修改成:

?
1
2
UserMainMapper userMainMapper = session.getMapper(UserMainMapper.class);
User user = userMainMapper.queryUserMainById(1);

使用對于給定語句能夠合理描述參數和返回值的接口(比如說UserMainMapper.class),

現在不但可以執行更清晰和類型安全的代碼,而且還不用擔心易錯的字符串字面值以及強制類型轉換。

運行測試代碼,效果一樣。

userMainMapper接口位置:

MyBatis入門初體驗之使用大全(2)

既然我們加完了接口,mybatis-config.xml對于映射器部分可以換一種配置,直接映射UserMainMapper接口所在包文件:

也就是將

修改成

完整配置如下,運行測試代碼即可檢驗,這種做法維護更輕松,統一對map進行管理:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<!--?xml version="1.0" encoding="UTF-8" ?-->
<configuration>
<environments default="development">
<environment id="development">
<transactionmanager type="JDBC">
<datasource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver">
<property name="url" value="jdbc:mysql://192.168.200.12:3306/test_mybatis">
<property name="username" value="root">
<property name="password" value="root123">
</property></property></property></property></datasource>
</transactionmanager></environment>
</environments>
<mappers>
<!-- 注冊UserMainMapper.xml文件,UserMainMapper.xml位于com.lanhuigu.mybatis.map這個包下,
所以resource寫成com/lanhuigu/mybatis/map/UserMainMapper.xml-->
<!-- <mapper resource="com/lanhuigu/mybatis/map/UserMainMapper.xml"></mapper> -->
<package name="com.lanhuigu.mybatis.map">
</package></mappers>
</configuration>

以上我們可以看到不管我們怎么玩,sql是不是還在UserMainMapper.xml中映射?

這種方式實現是唯一的嗎?難道我必須要用xml?

當然不是了,如果以上你的代碼是一路修改下來測試成功的,那么我們再做最后一個修改,

不用UserMainMapper.xml實現映射,我們采用java注解來實現映射。

主要修改的地方是UserMainMapper.java這個接口,新加一個方法queryUserMainByIdNew,用注解實現映射

mybatis自解析接口映射。

修改后的UserMainMapper.java接口:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package com.lanhuigu.mybatis.map;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import com.lanhuigu.mybatis.entity.User;
public interface UserMainMapper {
/**
* xml
*/
public User queryUserMainById(int id);
/**
* java注解
*/
@Select("select f_id id,f_username username,f_age age from t_user_main where f_id = ${id} ")
public User queryUserMainByIdNew(@Param("id") int id);
}

修改后的測試代碼,運行感受下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package com.lanhuigu.mybatis;
import java.io.IOException;
import java.io.InputStream;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
import com.lanhuigu.mybatis.entity.User;
import com.lanhuigu.mybatis.map.UserMainMapper;
public class MyBatisTest {
@Test
public void testMyBatis() throws IOException {
SqlSessionFactory sqlSessionFactory = null;// XML構建SqlSessionFactory工廠實例
SqlSession session = null;// 從SqlSessionFactory工廠實例中獲取SqlSession對象
try {
//1.mybatis的配置文件路徑,這里放在classpath下,相當于src下
String resource = "mybatis-config.xml";
//2.讀取mybatis配置文件,同時創建SqlSessionFactory工廠實例
//======2.1使用類加載器加載mybatis的配置文件(它也加載關聯的映射文件)
//InputStream is = MyBatisTest.class.getClassLoader().getResourceAsStream(resource);
//構建SqlSessionFactory工廠
//sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//======2.2使用MyBatis提供的Resources類加載mybatis的配置文件(它也加載關聯的映射文件)
//Reader reader = Resources.getResourceAsReader(resource);
//構建SqlSessionFactory工廠
//sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
//======2.3 使用MyBatis提供的Resources類加載mybatis的配置文件
InputStream is = Resources.getResourceAsStream(resource);
//構建SqlSessionFactory工廠
sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.創建能執行映射文件中sql的sqlSession
session = sqlSessionFactory.openSession();
/**
* 映射sql的標識字符串:
* com.lanhuigu.mybatis.map.UserMainMapper是UserMainMapper.xml文件中mapper標簽的namespace屬性的值,
* queryUserMainById是UserMainMapper.xml文件select標簽的id屬性值,通過select標簽的id屬性值,
* 通過這兩個的組合就可以找到要執行的SQL
*/
//執行查詢返回一個唯一user對象的sql,注意:"com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById"為映射sql的標識字符串
/*User user = session.selectOne("com.lanhuigu.mybatis.map.UserMainMapper.queryUserMainById", 1);
System.out.println(user.getUsername());*/
/*UserMainMapper userMainMapper = session.getMapper(UserMainMapper.class);
User user = userMainMapper.queryUserMainById(1);
System.out.println(user.getUsername());*/
UserMainMapper userMainMapper = session.getMapper(UserMainMapper.class);
User user = userMainMapper.queryUserMainByIdNew(1);
System.out.println(user.getUsername());
} finally {
session.close();
}
}
}

以上所述是小編給大家介紹的MyBatis入門初體驗之使用大全(2),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美视频一区二区三区在线观看 | 亚洲AV无码A片在线观看蜜桃 | 午夜影院一区二区三区 | 精品一区在线 | 鬼畜重口高h合集长短篇 | 8mav福利视频 | 亚洲国产天堂 | 欧美一区不卡二区不卡三区 | 香蕉精品国产高清自在自线 | 免费国产成人α片 | 欧美人与禽交片在线播放 | 久久精品国产免费播放 | 欧美日韩国内 | 成年性生交大片免费看 | 亚洲成综合人影院在院播放 | 美女和男生搞基 | 成年人福利 | 日本又大又硬又粗的视频 | www日本在线观看 | 精品一区二区三区自拍图片区 | 欧美日韩一区视频 | 欧美sq| 国产小视频免费看 | 91频视| 狠狠色成人综合 | 99精品网站 | 手机看片福利盒子久久 | caoporn国产| 亚洲色图首页 | 欧美撒尿屁股嘘嘘撒尿 | 欧美一级视频在线观看 | 色吊丝每日永久访问网站 | zoofilivideo杂交3d | 日本一区二区三区在线 视频 | 色综合久久久 | 日本一区二区免费在线观看 | 国产高清在线不卡 | 免费稚嫩福利 | 国产一卡2卡3卡四卡精品网站 | 午夜爽喷水无码成人18禁三级 | 91精品综合久久久久m3u8 |