1. 程式人生 > >Mybatis學習筆記(二)--入門程式

Mybatis學習筆記(二)--入門程式

1.下載Mybatis包

mybaits的程式碼由github.com管理

下載地址:https://github.com/mybatis/mybatis-3/releases

選擇對應的版本下載

下載後解壓mybatis後

2.環境搭建

2.1 建立工程

匯入核心包(mybatis和lib中的jar包)

這裡使用的是mysql資料庫,需要匯入mysql的連線包,不然會報查詢不到驅動等錯誤

在根目錄下建立log4j.porperties檔案,用來列印日誌資訊

log4j.rootLogger=DEBUG, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

在根目錄下建立SqlMapConfig.xml(核心配置檔案)

<?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>
	<!-- 和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/db_mybatis?characterEncoding=utf-8" />
				<property name="username" value="root" />
				<property name="password" value="root" />
			</dataSource>
		</environment>
	</environments>
	
	<mappers>
		<mapper resource="sqlMapper/UserMapper.xml" />
	</mappers>
</configuration>

建立pojo類User

Public class User {
	private int id;
	private String username;// 使用者姓名
	private String sex;// 性別
	private Date birthday;// 生日
	private String address;// 地址
...省略get/set/toString()
}

建立資料庫表

CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(32) NOT NULL COMMENT '使用者名稱稱',
  `birthday` date DEFAULT NULL COMMENT '生日',
  `sex` char(1) DEFAULT NULL COMMENT '性別',
  `address` varchar(256) DEFAULT NULL COMMENT '地址',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=27 DEFAULT CHARSET=utf8;

INSERT INTO `user` VALUES ('1', 'janson', '2018-11-06', '0', '廣州市');
INSERT INTO `user` VALUES ('2', 'jansonLin', '2018-11-06', '0', '廣州市');
INSERT INTO `user` VALUES ('3', 'lin', '2018-11-06', '0', '廣州市');
INSERT INTO `user` VALUES ('4', 'test', '2018-11-06', '0', '廣州市');
INSERT INTO `user` VALUES ('5', 'testlin', '2018-11-06', '0', '廣州市');

新建對映檔案(這裡對映檔案需要寫到前面核心檔案的mappers中)

<?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 namespace="user">

	<!-- 查詢使用者 -->
	<!-- 
		屬性:
			id:宣告的唯一標識
			paramterType:傳入引數型別
			resultType:返回值的型別
	 -->
	<select id="findById" parameterType="Integer" resultType="com.janson.pojo.User">
		select * from user where id=#{v}
	</select>

</mapper>

新建測試類

package com.janson.test;

import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.List;

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 com.janson.pojo.User;

public class MybatisDemoTest {

	/**
	 * 查詢使用者
	 * @throws Exception
	 */
	@Test
	public void demoTest() throws Exception {
		//載入配置檔案
		String resource = "sqlMapConfig.xml";
        //通過流來載入
		InputStream inputStream = Resources.getResourceAsStream(resource);
		//建立sqlsessoionFactory
		SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); 
		
		//建立sqlsession
		SqlSession session = sqlSessionFactory.openSession();
		
		User user = session.selectOne("user.findById", 1);
		System.out.println(user);
	}
}

相關推薦

Mybatis學習筆記--入門程式

1.下載Mybatis包 mybaits的程式碼由github.com管理 下載地址:https://github.com/mybatis/mybatis-3/releases 選擇對應的版本下載 下載後解壓mybatis後 2.環境搭建 2.1 建立工程

mybatis學習筆記之XML方式的基本用法

在前一篇筆記中,我們建立了配置 mybatis-config.xml 檔案,原來 mappers標籤下的內容為: <mappers> <mapper resource="tk/mybatis/simple/mapper/CountryMa

MyBatis學習筆記- 介面式程式設計

MyBatis 的 HelloWorld 的進階 注意:本次操作是在上一個筆記的基礎之上 工程目錄如下: 1. 建立一個 EmployeeMapper 的介面 public interface EmployeeMapper { public Employee ge

編譯原理學習筆記翻譯程式的實現

上一節所學的主要是語法到語義的內容,通過手動構造語法樹來理解編譯過程。 在3.5節,書中給出了字尾表示式翻譯程式的java實現。根據前面的內容,今天對NC程式碼編譯給出簡易的實現。 在實現前,需要幾個準備內容用以簡化程式碼: 1. 正則表示式 正則表示式

Mybatis學習筆記-Mybatis配置檔案與對映檔案詳解

一、Mybatis配置檔案詳解 以下是mybatis.xml檔案,提倡放在src目錄下,檔名任意 <?xml version="1.0" encoding="UTF-8"?> <

mybatis框架總體說明---Mybatis學習筆記

mybatis是什麼? mybatis可以讓程式設計師的主要精力放在sql上,通過mybatis提供的對映方式,自由靈活生成(半自動化,大部分需要程式設計師編寫sql)滿足需要的sql語句。 my

MyBatis學習筆記優化MyBatis配置,解耦合,提高複用性

我們接著上篇的環境,優化MyBatis配置 1.連線資料庫的配置放在properties檔案中 在src下建立db.properties檔案,寫連線資料庫需要使用到的資料庫驅動,連線URL地址,使用者名稱,密碼;內容如下 driver=com.mysq

MyBatis學習筆記——標籤使用

resultMap手動對映 當資料庫表中的欄位名稱與pojo的實體類的名稱不同的時候,使用resultMap: 示例程式碼: <mapper namespace="com.zrxjuly.mybatis.mapper.OrderMapper"&g

MyBatis學習筆記——優化MyBatis配置檔案

在使用MyBatis的時候,MyBatis的配置檔案可以說是相當重要的了。那麼,我們先來看看MyBatis配置檔案中的內容和順序: <properties>(屬性) <setting>(全域性配置引數) <typeAliases>(類

mybatis學習筆記 多pojo,複雜對映

現在在資料庫增加兩張表blog與comment ,即部落格與評論表。 CREATE TABLE `blog` ( `id` int(11) NOT NULL default '0', `title` varchar(255) default NULL, `co

微信小程式入門學習筆記——阿里雲伺服器PHP MYSQL Apache配置

持續更新 持續學習 感謝原文大佬連結 https://www.linuxidc.com/Linux/2017-08/146220.htm 筆者在阿里雲上買了輕量應用伺服器 學生認證通過以下 便宜的 選擇的CentOS 7.3 64位  https://promot

ADO.NET入門學習筆記

pre ID ssa private 更新 clear event and form gridView再winform中顯示數據庫的數據。 SqlDataAdapter, DataSet, DataTable的簡單應用 1,安裝學習筆記一的那幾步打開數據庫,然後使用。

python入門學習筆記——列表

3.列表 3.1使用列表的值 name = ['dad','sss','ff'] print(name) print(name[0]) print(name[-1].upper()) 3.2修改列表值 name[-1] = 'aa' print(name) 3

Mybatis學習筆記1——第一個程式

暑期之前就有打算學習SSM,但是我記得當時再配置一個框架瘋狂報錯,弄得我很難受,,再加上當時有點其他事情,所以就放了下來。現在很有需求要會ssm,所以就學了一下。感覺框架這東西配置就煩的要死。錯一丁點就全錯。。下面開始說配置詳情。 介紹一下這些東西,將mybatis的jar包依賴放

微信小程式——學習筆記:邏輯層1

邏輯層將資料進行處理後傳送給檢視層,同時接受檢視層的事件反饋。 用App()函式註冊一個小程式。 當小程式初始化完成時,會觸發 onLaunch(全域性只觸發一次) 當小程式啟動,或從後臺進入前臺顯示,會觸發 onShow 當小程式從前臺進入後臺,會觸發 onHide 當小程式發生指令碼錯

SQL入門經典(第5版)學習筆記

1.判斷對錯:個人社會保險號碼,輸入格式為 '1111111111',它可以是下面任何一種資料型別:定長字元、變長字元、數值。錯 不能是數值 引號會轉換為字元 2.判斷對錯:數值型別的標度是指數值的總體長度。對 會自動補全 3.所有的SQL實現都使用同樣的資料型別嗎?不同 按需使用 4.下面定義的有效位

Web 前端開發入門學習筆記

  9.盒子模型:    它講了這樣一個事實:在HTML裡,在瀏覽器渲染頁面時,所有的元素都是要佔據一定空間的,而且這個空間一定是一個矩形的。在我們的瀏覽器中絕對不出現佔據圓形、不規則圖形這樣空間的元素存在。 簡單的來說,我們可以把頁面上的所有元素都當做

docker入門學習筆記

1、開始執行docker命令時,提示 “docker: Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?. See 'docke

Spring Boot 學習筆記第一個 Spring boot 程式

  SpringBoot程式建立方式  1、建立一個Spring boot專案      1) 可以採用方式一: 使用 eclipse 的 Spring Tool Suite (STS) 外掛/或者 IDEA 自帶的外掛建立;    

GTK+圖形化應用程式開發學習筆記—Glib庫1

 在學習GTK+之前我們需要先學習一下 glib的有關知識。因為我們將會在以後的學習中遇到這些知識。由於本筆記不是專門介紹glib的,所以下面的介紹不會太詳細。 <?xml:namespace prefix = o ns = "urn:schemas-microsoft