myBati初學

来源:http://www.cnblogs.com/wangbenqing/archive/2017/07/10/7144234.html
-Advertisement-
Play Games

創建資料庫(y2165) MyBatis環境搭建1.在pom.xml引入依賴2.得替換build節點,為了讓程式編譯在main中所有子包下的配置文件3.構建大配置,位於resources<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configura ...


創建資料庫(y2165)

MyBatis環境搭建
1.在pom.xml引入依賴
2.得替換build節點,為了讓程式編譯在main中所有子包下的配置文件
3.構建大配置,位於resources
<?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">

<!-- 通過這個配置文件,完成mybatis與資料庫的連接 -->
<configuration><!--根節點-->
<!--別名設定-->
<typeAliases>
<package name="cn.happy.entity"/>
</typeAliases>


<environments default="development">
<environment id="development">


<!--
transactionManager:JDBC保證事務的
update
delete
事務分類:JDBC:編程式事務
xxx.beginTransaction()

tx.commit()
tx.rollback()
配置式事務
JDBC|MANAGED
區別

-->


<!-- 配置事物管理採用JDBC -->
<transactionManager type="JDBC"/>

<!--
POOLED:MyBatis內置的連接池
c3p0連接池
POOLED 、UNPOOLED 、JNDI
-->


<!-- POOLED:mybatis的數據源,JNDI:基於tomcat的數據源 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///y2165"/>
<property name="username" value="cd"/>
<property name="password" value="000"/>
</dataSource>
</environment>
</environments>

<mappers>

<mapper resource="cn/happy/dao/IDeptDAO.xml"/>

</mappers>
</configuration>


4.構建實體類
package cn.happy.entity;

/**
* Created by lenovo on 2017/7/7.
*/
public class Dept {
private Integer deptNo;
private String deptName;

public Integer getDeptNo() {
return deptNo;
}

public void setDeptNo(Integer deptNo) {
this.deptNo = deptNo;
}

public String getDeptName() {
return deptName;
}

public void setDeptName(String deptName) {
this.deptName = deptName;
}
}


5.構建小配置
<?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:
命名空間:區分不同空間下的同名SQLID
A: findlAll
B: findAll
-->

<mapper namespace="cn.happy.dao.IDeptDAO" >
<!--SQL標簽
id:唯一鎖定到SQL標識
paramenterType:SQL語句的入參 可以省略
resultType:
增刪除操作:不能 寫
查詢:單個實體的類型
-->
<!--查詢所有-->
<select id="getAllList" resultType="Dept">
SELECT * FROM Dept
</select>
<!--待條件查詢-->
<select id="getDeptById" parameterType="int" resultType="Dept">
select * from Dept where deptNo=#{deptNo}
</select>
</mapper>


6.在大配置中關聯小配置
<mappers>

<mapper resource="cn/happy/dao/IDeptDAO.xml"/>

</mappers>


7.書寫測試類
package cn.happy.test;

import cn.happy.dao.IDeptDAO;
import cn.happy.entity.Dept;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.jdbc.SQL;
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;

/**
* Created by lenovo on 2017/7/9.
*/
public class MyBatisTest01 {
//單元測試
@Test
//1.查詢所有使用getMapper()
public void testall() {
//1 獲取到大配置
String path = "mybatis-config.xml";
try {
InputStream is = Resources.getResourceAsStream(path);
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
SqlSession session = factory.openSession();
IDeptDAO de = session.getMapper(IDeptDAO.class);
List<Dept> list = de.getAllList();
for (Dept dept : list) {
System.out.println(dept.getDeptName());
}

} catch (IOException e) {
e.printStackTrace();
}
}

@Test
//2.待條件查詢 Mapper的使用
public void testGetOneDept() {
String path = "mybatis-config.xml";
try {
InputStream is = Resources.getResourceAsStream(path);
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
SqlSession session = factory.openSession();
IDeptDAO dao = session.getMapper(IDeptDAO.class);
Dept dept = dao.getDeptById(1);
System.out.println(dept.getDeptName());
} catch (IOException e) {
e.printStackTrace();
}
}


使用getMapper查詢所有結果

使用getMapper帶條件查詢結果


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、定義一個類 第一種方法__init__()方法是一種特殊的方法,被稱為類的構造函數或初始化方法,當創建了這個類的實例時就會調用該方法 self 代表類的實例,self 在定義類的方法時是必須有的,雖然在調用時不必傳入相應的參數。 二、self代表的實例,而非類 類的方法與普通的函數只有一個特別的 ...
  • Java集合框架小應用之撲克牌小游戲 學習了Java集合框架之後,我寫了一個撲克牌小游戲來鞏固知識。學習之餘的練習之作,有不足之處還得多多指教了~(*/ω\*) 撲克牌小游戲背景: 1. 創建一副撲克牌,不考慮大小王 包括四種花色:黑桃、紅桃、梅花、方片 十三種點數:2-10,J Q K A 2. ...
  • 手頭現在有一份福布斯2016年全球上市企業2000強排行榜的數據,但原始數據並不規範,需要處理後才能進一步使用。 本文通過實例操作來介紹用pandas進行數據整理。 ...
  • 首先,萬分抱歉,據上一篇更新後,時隔已近一個月。雖然博主不日念起此事,但實在是最近繁事纏身,說這些也是想告訴對此文有所期待的朋友,博主一定會更完到最後一章,不盡人意之處,還請各位多擔待。如果不出意外,博主還是努力一周更兩篇。 前面,我們看過項目實際運行的功能介紹,表結構也有所瞭解。今天,我們就正式進 ...
  • 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 題解 查看運行結果 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 時間限制: 1 ...
  • 為啥整合 Dubbo 實現 SOA Dubbo 不單單隻是高性能的 RPC 調用框架,更是 SOA 服務治理的一種方案。 ...
  • 之前寫過在windows環境上部署rabbitmq,這回介紹在centos上對這個消息中間件進行部署的過程 一 下載和解壓 wget http://www.rabbitmq.com/releases/rabbitmq-server/current/rabbitmq-server_3.6.10-1.d ...
  • // test07.cpp : Defines the entry point for the console application.// #include "stdafx.h"//設計模式第7章 適配器模式 class Duck{public: virtual void quack() = 0; ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...