Mybatis學習01:利用mybatis查詢資料庫
通過mybatis來操作mysql資料庫的步驟大致可分為以下幾步:
在這裡,我們以對下面這個這個表格進行操作為例:
表名:ssm
1 配置依賴
在pom.xml中添加所需要的的依賴
<!-- mybatis核心依賴 -->
<!-- //mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.1</version>
</dependency>
<!-- mysql驅動 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!--為了方便測試,我們也加上測試單元依賴-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<!--為了便於構造類,添加lomnok依賴-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.10</version>
<scope>provided</scope>
</dependency>
<!--在build中進行以下配置-->
<resources>
<resource>
<directory>src/main/java</directory><!--結果所在的目錄-->
<includes><!--包括目錄下的.properties,.xml 文件都會掃描到-->
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
對於操作資料庫,我們必須在maven中把mybatis.xml這個配置文件進行一些指定
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"//mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--settings:控制mybatis全局行為-->
<settings>
<!--設置mybatis輸出日誌-->
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
<environments default="mydev">
<environment id="mydev">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<!--資料庫的驅動類名-->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<!--連接資料庫的url字元串,具體地址根據自己的資料庫來填-->
<property name="url" value="jdbc:mysql://localhost:3306/springdb"/>
<!--訪問資料庫的用戶名,更具自己的資料庫;來填-->
<property name="username" value="root"/>
<!--密碼,根據自己的資料庫設置來填-->
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<!-- sql mapper(sql映射文件)的位置-->
<mappers>
<mapper resource="com/bjpowernode/dao/StudentDao.xml"/>
<!--<mapper resource="com/bjpowernode/dao/SchoolDao.xml" />-->
</mappers>
</configuration>
注意上面配置的一個小問題,如果資料庫的版本為8以上,那麼在配置資料庫url操作時就應該如下所示:
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT&nullCatalogMeansCurrent = true"/>
如果是8版本以下,url的配置如下
<property name="url" value="jdbc:mysql://localhost:3306/ssm所在的資料庫"/>
接下來在src\main\java\com\bjpowernode\domain下建立一個和表有關的類
@Data
public class Student {
private Integer id;
private String name;
private String email;
private Integer age;
}
之後再在bjpowernode\dao
下新建一個關於操作資料庫的介面
package com.bjpowernode.dao;
import com.bjpowernode.domain.Student;
import java.util.List;
public interface StudentDao {
//這裡對錶進行選擇操作
//選擇數據
List<Student> selectStudents();
//插入數據
int insertStudent(Student student);
}
本文中使用mapper代理的方式,
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"//mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--namespace是命名空間,作用就是對sql進行分類化管理,理解為sql隔離,在這裡namesapce是dao下的java類,而配置文件和java文件的文件名保持一致-->
<mapper namespace="org.example.dao.StudentDao">
<!--該sql語句的id,resultType是表示指定sql輸出結果所映射的java對象類型,這裡執行操作得到的結果是一個包含一行資料庫資訊的學生類,因此resultType是student類的路徑-->
<select id="selectStudents" resultType="org.example.domain.student">
select *
from ssm
order by id
</select>
<!-- 插入操作,只需要id,不需要輸出類型 -->
<insert id="insertStudent" >
insert into ssm value (#{id},#{name},#{email},#{age})
</insert>
</mapper>
MybatisUtils工具類
package org.example.utils;
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 java.io.IOException;
import java.io.InputStream;
public class MyBatisUtils {
private static SqlSessionFactory factory = null;
static {
//獲取mybatis主配置文件,
String config="mybatis.xml"; // 需要和你的項目中的文件名一樣
try {
//讀取配置文件
InputStream in = Resources.getResourceAsStream(config);
//創建SqlSessionFactory對象,目的是獲取SqlSession
factory = new SqlSessionFactoryBuilder().build(in);
} catch (IOException e) {
e.printStackTrace();
}
}
//獲取SqlSession的方法
public static SqlSession getSqlSession() {
SqlSession sqlSession = null;
if( factory != null){
//獲取SqlSession,SqlSession能執行sql語句
sqlSession = factory.openSession();// 非自動提交事務
}
return sqlSession;
}
}
所有類和配置都搭建好了之後寫一個測試類,以選擇元素的sql語句為例
package org.example;
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.example.domain.student;
import org.example.utils.MyBatisUtils;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
public class MyApp2 {
public static void main( String[] args ) throws IOException {
//獲取SqlSession對象,從SqlSessionFactory中獲取SqlSession
SqlSession sqlSession = MyBatisUtils.getSqlSession();
//【重要】指定要執行的sql語句的標識。 sql映射文件中的namespace + "." + 標籤的id值
String sqlId = "org.example.dao.StudentDao.selectStudents";
//【重要】執行sql語句,通過sqlId找到語句
List<student> studentList = sqlSession.selectList(sqlId);
//輸出結果
studentList.forEach( stu -> System.out.println(stu));
//關閉SqlSession對象
sqlSession.close();
}
}
輸出結果:以自己在資料庫中設置的數據為準