程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Mybatis框架搭建與簡單查詢詳解

Mybatis框架搭建與簡單查詢詳解

編輯:關於JAVA

Mybatis框架搭建與簡單查詢詳解。本站提示廣大學習愛好者:(Mybatis框架搭建與簡單查詢詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是Mybatis框架搭建與簡單查詢詳解正文


JAVA中,操作數據庫有JDBC、hibernate、Mybatis等技術,今天整理了下,來講一講下Mybatis。也為自己整理下文檔;

hibernate是一個完全的ORM框架,是完全面向對象的。但是由於全部都是以對象的形式來操作數據庫,sql代碼都是由框架自動生成,可操作性和靈活性比較Mybatis都要差一些。所以,Mybatis慢慢的變成多數開發的標准配置;

一、myBatis框架建設

myBatis的整體框架結構如下圖所示,按照下圖的工程原樣建立即可(其中jar包在文章末尾提供)

二、編寫數據庫表對應的實體類

首先,數據庫表結構如下(mysql數據庫):

1、實體類User.java中寫入如下代碼:

public class User {
 @Override
 public String toString() {
 return "User [id=" + id + ", username=" + username + ", sex=" + sex
 + ", address=" + address + ", birthday=" + birthday + "]";
 }
 private int id;
 private String username;
 private String sex;
 private String address;
 private Date birthday;
 public int getId() {
 return id;
 }
 public void setId(int id) {
 this.id = id;
 }
 public String getUsername() {
 return username;
 }
 public void setUsername(String username) {
 this.username = username;
 }
 public String getSex() {
 return sex;
 }
 public void setSex(String sex) {
 this.sex = sex;
 }
 public String getAddress() {
 return address;
 }
 public void setAddress(String address) {
 this.address = address;
 }
 public Date getBirthday() {
 return birthday;
 }
 public void setBirthday(Date birthday) {
 this.birthday = birthday;
 }
}

2、向SqlMapConfig.xml中寫入配置文件

<!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="123456" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="sqlmap/User.xml"></mapper>
</mappers>
</configuration>

注意:SqlMapConfig中的mysql賬戶與密碼需要改成你自己的賬號密碼

三、在config包下建立log4j.properties(公用文件)

在文件中寫入默認參數:

# Global logging configuration,建議開發環境中要用debug
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

四、開始編寫User.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace命名空間,為了對sql語句進行隔離,方便管理 ,mapper開發dao方式,使用namespace有特殊作用 -->
<mapper namespace="test">
<!-- 在mapper.xml文件中配置很多的sql語句,執行每個sql語句時,封裝為MappedStatement對象
mapper.xml以statement為單位管理sql語句
 -->
 <!-- 根據id查詢用戶信息 -->
 <!-- 
 id:唯一標識 一個statement
 #{}:表示 一個占位符,如果#{}中傳入簡單類型的參數,#{}中的名稱隨意
 parameterType:輸入 參數的類型,通過#{}接收parameterType輸入 的參數
 resultType:輸出結果 類型,不管返回是多條還是單條,指定單條記錄映射的pojo類型
 -->
 <select id="findUserById" parameterType="int" resultType="cn.qkp.mybatis.po.User"> 
 SELECT * FROM USER WHERE id=#{id}
 </select>
</mapper>

以上配置完成,整個Mybatis基礎框架就算是搭建完畢了。我們就可以使用代碼來操作數據庫了。我們先對數據庫進行簡單的查詢操作;

=========================使用Mybatis!===============================

一、在first包中建立測試類(MybatisFrist.java)

內容代碼為:

private SqlSessionFactory sqlsessionfactory;//存儲SqlSessionFactory 對象
@Before
 public void star() throws Exception{
 //設置配置路徑,mybitis是以SqlMapConfig.xml為主路徑。因為SqlMapConfig中的mapper關聯了user.xml
 //因為在config根目錄下,所以可以直接引用而不用帶config
 String resource = "SqlMapConfig.xml";
 //SqlMapConfig.xml讀給輸入流,使用mybitis的Resources類下的getResourceAsStream實現
 InputStream inputStream = Resources.getResourceAsStream(resource);
 //創建Mybitis的SqlSessionFactory工廠類
 sqlsessionfactory = new SqlSessionFactoryBuilder().build(inputStream);
 }
 @Test
 public void test(){
 //通過工廠類打開數據接口
 SqlSession sqlsession = sqlsessionfactory.openSession();
 //設置接收對象
 User user = null;
 try {
 //查詢數據selectOne為查詢一條的方法第一個參數是user.xml中的namespace.id;第二個參數是user配置文件中的#{id}
 user = sqlsession.selectOne("test.findUserById", 1);
 } catch (Exception e) {
 // TODO: handle exception
 }finally{
 sqlsession.close();//讀完要關閉sqlsession
 }
 System.out.println(user);//打印輸出
 }

運行上述代碼,結果為:

以上便成功連通數據庫,並獲取到指定數據!

ps:以上是查詢單一數值的查詢方法,如果要查詢一組數據使用SqlSession的selectList方法,接收一個List;代碼如下:

在User.xml中:

<select id="selectByName" parameterType="String" resultType="cn.qkp.po.User">
select * from User where username like '%${value}%'
</select>

PS:在xml中,使用#{}占位符表示系統自動會進行java類型和jdbc類型自動轉換;而${}表示原樣輸出,使用${}會造成sql注入漏洞攻擊,慎用;

在myBatisRun代碼中:

@Test
 public void star2(){
 SqlSession sqlsession = sqlsessionfactory.openSession();
 List<User> user = sqlsession.selectList("test.selectByName", "小明");
 sqlsession.close();
 System.out.println(user.get(0));
 }

結果為:

相關的jar包連接:http://pan.baidu.com/s/1i4TiJD7

以上就是基本的框架搭建和簡單的查詢操作,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved