Mybatis框架搭建與簡單查詢詳解
JAVA中,操作數(shù)據(jù)庫有JDBC、hibernate、Mybatis等技術,今天整理了下,來講一講下Mybatis。也為自己整理下文檔;
hibernate是一個完全的ORM框架,是完全面向對象的。但是由于全部都是以對象的形式來操作數(shù)據(jù)庫,sql代碼都是由框架自動生成,可操作性和靈活性比較Mybatis都要差一些。所以,Mybatis慢慢的變成多數(shù)開發(fā)的標準配置;
一、myBatis框架建設
myBatis的整體框架結構如下圖所示,按照下圖的工程原樣建立即可(其中jar包在文章末尾提供)
二、編寫數(shù)據(jù)庫表對應的實體類
首先,數(shù)據(jù)庫表結構如下(mysql數(shù)據(jù)庫):
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" /> <!-- 數(shù)據(jù)庫連接池--> <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(公用文件)
在文件中寫入默認參數(shù):
# Global logging configuration,建議開發(fā)環(huán)境中要用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開發(fā)dao方式,使用namespace有特殊作用 --> <mapper namespace="test"> <!-- 在mapper.xml文件中配置很多的sql語句,執(zhí)行每個sql語句時,封裝為MappedStatement對象 mapper.xml以statement為單位管理sql語句 --> <!-- 根據(jù)id查詢用戶信息 --> <!-- id:唯一標識 一個statement #{}:表示 一個占位符,如果#{}中傳入簡單類型的參數(shù),#{}中的名稱隨意 parameterType:輸入 參數(shù)的類型,通過#{}接收parameterType輸入 的參數(shù) resultType:輸出結果 類型,不管返回是多條還是單條,指定單條記錄映射的pojo類型 --> <select id="findUserById" parameterType="int" resultType="cn.qkp.mybatis.po.User"> SELECT * FROM USER WHERE id=#{id} </select> </mapper>
以上配置完成,整個Mybatis基礎框架就算是搭建完畢了。我們就可以使用代碼來操作數(shù)據(jù)庫了。我們先對數(shù)據(jù)庫進行簡單的查詢操作;
=========================使用Mybatis!===============================
一、在first包中建立測試類(MybatisFrist.java)
內容代碼為:
private SqlSessionFactory sqlsessionfactory;//存儲SqlSessionFactory 對象 @Before public void star() throws Exception{ //設置配置路徑,mybitis是以SqlMapConfig.xml為主路徑。因為SqlMapConfig中的mapper關聯(lián)了user.xml //因為在config根目錄下,所以可以直接引用而不用帶config String resource = "SqlMapConfig.xml"; //SqlMapConfig.xml讀給輸入流,使用mybitis的Resources類下的getResourceAsStream實現(xiàn) InputStream inputStream = Resources.getResourceAsStream(resource); //創(chuàng)建Mybitis的SqlSessionFactory工廠類 sqlsessionfactory = new SqlSessionFactoryBuilder().build(inputStream); } @Test public void test(){ //通過工廠類打開數(shù)據(jù)接口 SqlSession sqlsession = sqlsessionfactory.openSession(); //設置接收對象 User user = null; try { //查詢數(shù)據(jù)selectOne為查詢一條的方法第一個參數(shù)是user.xml中的namespace.id;第二個參數(shù)是user配置文件中的#{id} user = sqlsession.selectOne("test.findUserById", 1); } catch (Exception e) { // TODO: handle exception }finally{ sqlsession.close();//讀完要關閉sqlsession } System.out.println(user);//打印輸出 }
運行上述代碼,結果為:
以上便成功連通數(shù)據(jù)庫,并獲取到指定數(shù)據(jù)!
ps:以上是查詢單一數(shù)值的查詢方法,如果要查詢一組數(shù)據(jù)使用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中,使用#{}占位符表示系統(tǒng)自動會進行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
以上就是基本的框架搭建和簡單的查詢操作,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
- Java的MyBatis框架項目搭建與hellow world示例
- Windows下Java+MyBatis框架+MySQL的開發(fā)環(huán)境搭建教程
- Mybatis查不到數(shù)據(jù)查詢返回Null問題
- Mybatis傳遞多個參數(shù)進行SQL查詢的用法
- Java的MyBatis框架中實現(xiàn)多表連接查詢和查詢結果分頁
- 詳解MyBatis直接執(zhí)行SQL查詢及數(shù)據(jù)批量插入
- MyBatis實踐之動態(tài)SQL及關聯(lián)查詢
- 實例講解Java的MyBatis框架對MySQL中數(shù)據(jù)的關聯(lián)查詢
- Java的MyBatis框架中Mapper映射配置的使用及原理解析
- 詳解Java的MyBatis框架中的事務處理
相關文章
SpringBoot項目使用mybatis-plus逆向自動生成全套代碼
在JavaWeb工程中,每一個SSM新項目或者說是SpringBoot項目也好,都少不了model、controller、service、dao等層次的構建。使用mybatis-plus逆向可以自動生成,感興趣的可以了解一下2021-09-09Java調用SSE流式接口并流式返回給前端實現(xiàn)打字輸出效果
在Web開發(fā)中,有時我們需要將文件以流的形式返回給前端,下面這篇文章主要給大家介紹了關于Java調用SSE流式接口并流式返回給前端實現(xiàn)打字輸出效果的相關資料,需要的朋友可以參考下2024-08-08關于弱引用WeakReference所引用的對象的回收規(guī)則
這篇文章主要介紹了關于弱引用WeakReference所引用的對象的回收規(guī)則,如果一個弱引用實例的成員變量referent引用了一個對象obj,那么就稱這個弱引用實例對obj的引用是弱引用,被一個弱引用實例引用的對象,稱為弱引用對象,需要的朋友可以參考下2023-09-09Java實現(xiàn)發(fā)送手機短信語音驗證功能代碼實例
這篇文章主要介紹了Java實現(xiàn)發(fā)送手機短信語音驗證功能代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-09-09