mybatis連接mysql的實現(xiàn)過程
mybatis連接數(shù)據(jù)庫
配置Maven的pom文件,導(dǎo)入依賴的工具包
配置pom文件可以免去下載和導(dǎo)入各種依賴包(jar)的操作,具體可以去看之前的Maven的相關(guān)文章。
<dependencies>
<!--junit單元測試坐標(biāo)-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<!--mysql連接數(shù)據(jù)庫的依賴坐標(biāo)坐標(biāo)-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.11</version>
</dependency>
<!--導(dǎo)入mybatis坐標(biāo)-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.5</version>
</dependency>
<!--導(dǎo)入druid連接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.24</version>
</dependency>
<!--導(dǎo)入dbutils坐標(biāo)-->
<dependency>
<groupId>commons-dbutils</groupId>
<artifactId>commons-dbutils</artifactId>
<version>1.6</version>
</dependency>
</dependencies>- junit單元測試,可以方便我們測試每個sql語句的函數(shù)。
- mysql-connect-xxx時jdbc的連接驅(qū)動的jar包,是連接數(shù)據(jù)庫的必要條件
- mybatis坐標(biāo)是數(shù)據(jù)庫操作框架,簡化jdbc的操作,當(dāng)然如果你習(xí)慣jdbc操作的化可以導(dǎo)入jdbc的坐標(biāo)
- druid連接池,連接池是一個容器,優(yōu)化線程的工具,不必為每個操作創(chuàng)建單個的數(shù)據(jù)庫連接。
- dbutil也是jdbc的簡化工具包,使查詢和更新變得更簡單,并能處理查詢的結(jié)果集。
定義mybatis框架的配置文件mybatis-config.xml
該文件在maven項目目錄結(jié)構(gòu)的resoueces目錄下,主要實現(xiàn)數(shù)據(jù)庫連接和配置sql語句簡化數(shù)據(jù)庫操作的。

IDEA實現(xiàn)Maven項目創(chuàng)建并連接Tomcat
<?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>
<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>
<mappers>
<!--mappper映射路徑-->
<mapper resource="UserMapper.xml"/>
</mappers>
</configuration>需要修改的有兩個部分:
連接配置(配置mysql連接的信息和jdbc差不多)${driver}修改為jdbc配置使的Driver對象的內(nèi)容。${url}也是jdbc連接數(shù)據(jù)時的配置,下面兩個username和password是數(shù)據(jù)庫的登錄名(root)和密碼。其實這些和jdbc一樣。
mapper映射路徑(將sql語句封裝為一個帶參方法的配置文件的路徑)標(biāo)簽中的resource的內(nèi)容要修改,改為對象映射文件(如UserMapper)的路徑。有幾個文件就要重寫幾個路徑。
- 注意帶$的要修改,和jdbc的一樣mysql的8.0以上的driver=“com.mysql.cj.jdbc.Driver”;url=“jdbc:mysql://localhost:3306/db1?useSSL=false&serverTimezone=UTC”。db1是數(shù)據(jù)庫的名稱,相當(dāng)于”use db1”的sql語句后面要有問號分割,數(shù)據(jù)庫密碼要正確。
- mappers下的mapper的resource路徑要修改成對象映射的xml路徑。即下面的UserMapper.xml路徑
配置對象映射文件UserMapper.xml
該文件的作用時將數(shù)據(jù)的表映射為javabean的對象。
<?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">
<mapper namespace="test">
<select id="selectAll" resultType="model.User">
select * from Blog where id = #{id}
</select>
</mapper>該文件就是將sql語句封裝為一個帶參方法,操作數(shù)據(jù)庫是直接調(diào)用。mapper標(biāo)簽就是sql語句id就是被封裝的方法。
需要修改的有三個地方:namespace,id,resultType,sql語句。
- namespace屬性,如果你熟悉mybatis你就知道使用mapper代理開發(fā)時這里需要修改為映射對象的路徑(否則隨便命名test即可,也可以直接使用默認(rèn)的)。
- id是sql封裝后的方法名自己定義。
- resultType定義查詢結(jié)果的返回的數(shù)據(jù)類型MyBatis查詢結(jié)果resultType返回值類型詳細(xì)介紹
有string,list,javabean,map等類型。我們直接返回javabean即可(返回javabean時要填寫javabean的路徑)即model.User。
sql語句中的#{}是占位符,和jdbc的?一樣傳遞參數(shù)的。Blog改為對應(yīng)的數(shù)據(jù)庫表名,這個sql語句要能在mysql命令框運(yùn)行的(帶參數(shù)的話)
- 看一下我的javabean路徑:

namespace可以隨便命名,select的id要唯一,resulttype為對應(yīng)javabean的User類即model.User。該文件的名稱為UserMapper.xml。
編寫數(shù)據(jù)庫連接代碼
package mybatis;
import model.User;
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 java.io.IOException;
import java.io.InputStream;
import java.util.List;
public class MybatisTest {
@Test
public void method() throws IOException { //單元測試不能要static
//mybatis框架都在xml配置文件中加載配置文件
//從 XML 文件中構(gòu)建 SqlSessionFactory 的實例
String resource = "mybatis-config.xml";
InputStream inputStream = null;
inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//從 SqlSessionFactory 中獲取 SqlSession
SqlSession session = sqlSessionFactory.openSession();
//執(zhí)行sql
List<User> users=session.selectList("test.selectAll",2);
System.out.println(users);
//釋放資源
session.close();
}
}
測試代碼中只有執(zhí)行sql的步驟需要修改,在前面的配置文件中test時namespace隨便名命名的,selectAll是id(封裝的方法)selectList是sqlsession的處理查詢結(jié)果集的方法,將查詢對象存儲到list集合中。并用List的泛型類接收。
我先演示一個不帶參數(shù)的查詢:將sql語句改為:select * from user,刪除執(zhí)行sql中的1(查詢所有)
- 如圖所示運(yùn)行結(jié)果:

- 對應(yīng)數(shù)據(jù)中的user表:

原樣運(yùn)行的話是有參數(shù)的,在方法后面直接添加一個參數(shù)就可以了,如圖上的提示paramter為參數(shù)。
- 填入一個數(shù)字2.

- 如圖運(yùn)行結(jié)果:

由上上個圖可以看出,第三個參數(shù)變?yōu)榱藃owBounds,有興趣的可以了解一下,但是我們知道的是,肯定不是傳遞第二個參數(shù)的對象。那么封裝sql語句是有多個參數(shù)該怎么辦呢?
就需要使用mybatis的mapper代理開發(fā)了。用于解決傳遞多個參數(shù)的問題。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot+hutool批量生成二維碼壓縮導(dǎo)出功能
這篇文章主要介紹了springboot+hutool批量生成二維碼壓縮導(dǎo)出功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10
基于spring+hibernate+JQuery開發(fā)之電子相冊(附源碼下載)
本篇文章介紹了,基于spring+hibernate+JQuery開發(fā)之電子相冊(附源碼下載)。需要的朋友參考下2013-05-05

