欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis連接mysql的實(shí)現(xiàn)過程

 更新時(shí)間:2024年10月19日 10:04:07   作者:xvwen  
通過配置Maven的pom文件,可以簡化MyBatis連接數(shù)據(jù)庫的過程,免去手動(dòng)下載和導(dǎo)入各種依賴包的麻煩,本文介紹了如何利用Maven導(dǎo)入MyBatis及其他相關(guān)依賴,如Junit、MySQL連接驅(qū)動(dòng)、Druid連接池和Dbutil等,以簡化數(shù)據(jù)庫操作和測試

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單元測試,可以方便我們測試每個(gè)sql語句的函數(shù)。
  • mysql-connect-xxx時(shí)jdbc的連接驅(qū)動(dòng)的jar包,是連接數(shù)據(jù)庫的必要條件
  • mybatis坐標(biāo)是數(shù)據(jù)庫操作框架,簡化jdbc的操作,當(dāng)然如果你習(xí)慣jdbc操作的化可以導(dǎo)入jdbc的坐標(biāo)
  • druid連接池,連接池是一個(gè)容器,優(yōu)化線程的工具,不必為每個(gè)操作創(chuàng)建單個(gè)的數(shù)據(jù)庫連接。
  • dbutil也是jdbc的簡化工具包,使查詢和更新變得更簡單,并能處理查詢的結(jié)果集。

定義mybatis框架的配置文件mybatis-config.xml

該文件在maven項(xiàng)目目錄結(jié)構(gòu)的resoueces目錄下,主要實(shí)現(xiàn)數(shù)據(jù)庫連接和配置sql語句簡化數(shù)據(jù)庫操作的。

IDEA實(shí)現(xiàn)Maven項(xiàng)目創(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>

需要修改的有兩個(gè)部分: 

連接配置(配置mysql連接的信息和jdbc差不多)${driver}修改為jdbc配置使的Driver對象的內(nèi)容。${url}也是jdbc連接數(shù)據(jù)時(shí)的配置,下面兩個(gè)username和password是數(shù)據(jù)庫的登錄名(root)和密碼。其實(shí)這些和jdbc一樣。 

mapper映射路徑(將sql語句封裝為一個(gè)帶參方法的配置文件的路徑)標(biāo)簽中的resource的內(nèi)容要修改,改為對象映射文件(如UserMapper)的路徑。有幾個(gè)文件就要重寫幾個(gè)路徑。

  • 注意帶$的要修改,和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í)將數(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語句封裝為一個(gè)帶參方法,操作數(shù)據(jù)庫是直接調(diào)用。mapper標(biāo)簽就是sql語句id就是被封裝的方法。

需要修改的有三個(gè)地方:namespace,id,resultType,sql語句

有string,list,javabean,map等類型。我們直接返回javabean即可(返回javabean時(shí)要填寫javabean的路徑)即model.User。 

sql語句中的#{}是占位符,和jdbc的?一樣傳遞參數(shù)的。Blog改為對應(yīng)的數(shù)據(jù)庫表名,這個(gè)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 的實(shí)例
        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時(shí)namespace隨便名命名的,selectAll是id(封裝的方法)selectList是sqlsession的處理查詢結(jié)果集的方法,將查詢對象存儲到list集合中。并用List的泛型類接收。

我先演示一個(gè)不帶參數(shù)的查詢:將sql語句改為:select * from user,刪除執(zhí)行sql中的1(查詢所有)

  • 如圖所示運(yùn)行結(jié)果:

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

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

  • 填入一個(gè)數(shù)字2.

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

由上上個(gè)圖可以看出,第三個(gè)參數(shù)變?yōu)榱藃owBounds,有興趣的可以了解一下,但是我們知道的是,肯定不是傳遞第二個(gè)參數(shù)的對象。那么封裝sql語句是有多個(gè)參數(shù)該怎么辦呢?

就需要使用mybatis的mapper代理開發(fā)了。用于解決傳遞多個(gè)參數(shù)的問題。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring實(shí)現(xiàn)處理跨域請求代碼詳解

    Spring實(shí)現(xiàn)處理跨域請求代碼詳解

    這篇文章主要介紹了Spring實(shí)現(xiàn)處理跨域請求代碼詳解,具有一定借鑒價(jià)值,需要的朋友可以了解下。
    2017-12-12
  • 兩種Eclipse部署動(dòng)態(tài)web項(xiàng)目方法

    兩種Eclipse部署動(dòng)態(tài)web項(xiàng)目方法

    這篇文章主要介紹了兩種Eclipse部署動(dòng)態(tài)web項(xiàng)目方法,需要的朋友可以參考下
    2015-11-11
  • springboot+hutool批量生成二維碼壓縮導(dǎo)出功能

    springboot+hutool批量生成二維碼壓縮導(dǎo)出功能

    這篇文章主要介紹了springboot+hutool批量生成二維碼壓縮導(dǎo)出功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10
  • 淺談JAVA工作流的優(yōu)雅實(shí)現(xiàn)方式

    淺談JAVA工作流的優(yōu)雅實(shí)現(xiàn)方式

    這篇文章主要介紹了淺談JAVA工作流的優(yōu)雅實(shí)現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • Java GZIPOutputStream流壓縮文件的操作

    Java GZIPOutputStream流壓縮文件的操作

    這篇文章主要介紹了Java GZIPOutputStream流壓縮文件的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • K均值聚類算法的Java版實(shí)現(xiàn)代碼示例

    K均值聚類算法的Java版實(shí)現(xiàn)代碼示例

    這篇文章主要介紹了K均值聚類算法的Java版實(shí)現(xiàn)代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • 基于spring+hibernate+JQuery開發(fā)之電子相冊(附源碼下載)

    基于spring+hibernate+JQuery開發(fā)之電子相冊(附源碼下載)

    本篇文章介紹了,基于spring+hibernate+JQuery開發(fā)之電子相冊(附源碼下載)。需要的朋友參考下
    2013-05-05
  • Java并發(fā)編程之StampedLock鎖介紹

    Java并發(fā)編程之StampedLock鎖介紹

    這篇文章主要介紹了Java并發(fā)編程之StampedLock鎖,StampedLock是并發(fā)包里面JDK8版本新增的一個(gè)鎖,下文更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-04-04
  • Sentinel整合Feign流程詳細(xì)講解

    Sentinel整合Feign流程詳細(xì)講解

    要想整合Feign,首先要了解Feign的使用以及執(zhí)行過程,然后看?Sentinel如何整合進(jìn)去,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 一文梳理Java?8后的新功能

    一文梳理Java?8后的新功能

    Java 8是Java自Java 5(發(fā)布于2004年)之后的最重要的版本,下面這篇文章主要給大家介紹了關(guān)于Java8后新功能的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-02-02

最新評論