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

Mybatis框架搭建與簡(jiǎn)單查詢?cè)斀?/h1>
 更新時(shí)間:2017年02月20日 15:39:58   作者:mylydg  
本文主要介紹了Mybatis框架搭建與簡(jiǎn)單查詢的相關(guān)知識(shí),具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧

JAVA中,操作數(shù)據(jù)庫(kù)有JDBC、hibernate、Mybatis等技術(shù),今天整理了下,來(lái)講一講下Mybatis。也為自己整理下文檔;

hibernate是一個(gè)完全的ORM框架,是完全面向?qū)ο蟮摹5怯捎谌慷际且詫?duì)象的形式來(lái)操作數(shù)據(jù)庫(kù),sql代碼都是由框架自動(dòng)生成,可操作性和靈活性比較Mybatis都要差一些。所以,Mybatis慢慢的變成多數(shù)開發(fā)的標(biāo)準(zhǔn)配置;

一、myBatis框架建設(shè)

myBatis的整體框架結(jié)構(gòu)如下圖所示,按照下圖的工程原樣建立即可(其中jar包在文章末尾提供)

二、編寫數(shù)據(jù)庫(kù)表對(duì)應(yīng)的實(shí)體類

首先,數(shù)據(jù)庫(kù)表結(jié)構(gòu)如下(mysql數(shù)據(jù)庫(kù)):

1、實(shí)體類User.java中寫入如下代碼:

public class User {
 @Override
 public String toString() {
 return "User [id=" + id + ", username=" + username + ", sex=" + sex
 + ", address=" + address + ", birthday=" + birthday + "]";
 }
 private int id;
 private String username;
 private String sex;
 private String address;
 private Date birthday;
 public int getId() {
 return id;
 }
 public void setId(int id) {
 this.id = id;
 }
 public String getUsername() {
 return username;
 }
 public void setUsername(String username) {
 this.username = username;
 }
 public String getSex() {
 return sex;
 }
 public void setSex(String sex) {
 this.sex = sex;
 }
 public String getAddress() {
 return address;
 }
 public void setAddress(String address) {
 this.address = address;
 }
 public Date getBirthday() {
 return birthday;
 }
 public void setBirthday(Date birthday) {
 this.birthday = birthday;
 }
}

2、向SqlMapConfig.xml中寫入配置文件

<!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事務(wù)管理-->
<transactionManager type="JDBC" />
<!-- 數(shù)據(jù)庫(kù)連接池-->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
<property name="username" value="root" />
<property name="password" value="123456" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="sqlmap/User.xml"></mapper>
</mappers>
</configuration>

注意:SqlMapConfig中的mysql賬戶與密碼需要改成你自己的賬號(hào)密碼

三、在config包下建立log4j.properties(公用文件)

在文件中寫入默認(rèn)參數(shù):

# Global logging configuration,建議開發(fā)環(huán)境中要用debug
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

四、開始編寫User.xml

<?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命名空間,為了對(duì)sql語(yǔ)句進(jìn)行隔離,方便管理 ,mapper開發(fā)dao方式,使用namespace有特殊作用 -->
<mapper namespace="test">
<!-- 在mapper.xml文件中配置很多的sql語(yǔ)句,執(zhí)行每個(gè)sql語(yǔ)句時(shí),封裝為MappedStatement對(duì)象
mapper.xml以statement為單位管理sql語(yǔ)句
 -->
 <!-- 根據(jù)id查詢用戶信息 -->
 <!-- 
 id:唯一標(biāo)識(shí) 一個(gè)statement
 #{}:表示 一個(gè)占位符,如果#{}中傳入簡(jiǎn)單類型的參數(shù),#{}中的名稱隨意
 parameterType:輸入 參數(shù)的類型,通過(guò)#{}接收parameterType輸入 的參數(shù)
 resultType:輸出結(jié)果 類型,不管返回是多條還是單條,指定單條記錄映射的pojo類型
 -->
 <select id="findUserById" parameterType="int" resultType="cn.qkp.mybatis.po.User"> 
 SELECT * FROM USER WHERE id=#{id}
 </select>
</mapper>

以上配置完成,整個(gè)Mybatis基礎(chǔ)框架就算是搭建完畢了。我們就可以使用代碼來(lái)操作數(shù)據(jù)庫(kù)了。我們先對(duì)數(shù)據(jù)庫(kù)進(jìn)行簡(jiǎn)單的查詢操作;

=========================使用Mybatis!===============================

一、在first包中建立測(cè)試類(MybatisFrist.java)

內(nèi)容代碼為:

private SqlSessionFactory sqlsessionfactory;//存儲(chǔ)SqlSessionFactory 對(duì)象
@Before
 public void star() throws Exception{
 //設(shè)置配置路徑,mybitis是以SqlMapConfig.xml為主路徑。因?yàn)镾qlMapConfig中的mapper關(guān)聯(lián)了user.xml
 //因?yàn)樵赾onfig根目錄下,所以可以直接引用而不用帶config
 String resource = "SqlMapConfig.xml";
 //SqlMapConfig.xml讀給輸入流,使用mybitis的Resources類下的getResourceAsStream實(shí)現(xiàn)
 InputStream inputStream = Resources.getResourceAsStream(resource);
 //創(chuàng)建Mybitis的SqlSessionFactory工廠類
 sqlsessionfactory = new SqlSessionFactoryBuilder().build(inputStream);
 }
 @Test
 public void test(){
 //通過(guò)工廠類打開數(shù)據(jù)接口
 SqlSession sqlsession = sqlsessionfactory.openSession();
 //設(shè)置接收對(duì)象
 User user = null;
 try {
 //查詢數(shù)據(jù)selectOne為查詢一條的方法第一個(gè)參數(shù)是user.xml中的namespace.id;第二個(gè)參數(shù)是user配置文件中的#{id}
 user = sqlsession.selectOne("test.findUserById", 1);
 } catch (Exception e) {
 // TODO: handle exception
 }finally{
 sqlsession.close();//讀完要關(guān)閉sqlsession
 }
 System.out.println(user);//打印輸出
 }

運(yùn)行上述代碼,結(jié)果為:

以上便成功連通數(shù)據(jù)庫(kù),并獲取到指定數(shù)據(jù)!

ps:以上是查詢單一數(shù)值的查詢方法,如果要查詢一組數(shù)據(jù)使用SqlSession的selectList方法,接收一個(gè)List;代碼如下:

在User.xml中:

<select id="selectByName" parameterType="String" resultType="cn.qkp.po.User">
select * from User where username like '%${value}%'
</select>

PS:在xml中,使用#{}占位符表示系統(tǒng)自動(dòng)會(huì)進(jìn)行java類型和jdbc類型自動(dòng)轉(zhuǎn)換;而${}表示原樣輸出,使用${}會(huì)造成sql注入漏洞攻擊,慎用;

在myBatisRun代碼中:

@Test
 public void star2(){
 SqlSession sqlsession = sqlsessionfactory.openSession();
 List<User> user = sqlsession.selectList("test.selectByName", "小明");
 sqlsession.close();
 System.out.println(user.get(0));
 }

結(jié)果為:

相關(guān)的jar包連接:http://pan.baidu.com/s/1i4TiJD7

以上就是基本的框架搭建和簡(jiǎn)單的查詢操作,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • JDBC程序更新數(shù)據(jù)庫(kù)中記錄的方法

    JDBC程序更新數(shù)據(jù)庫(kù)中記錄的方法

    這篇文章主要介紹了JDBC程序更新數(shù)據(jù)庫(kù)中記錄的方法,涉及Java基于JDBC操作數(shù)據(jù)庫(kù)的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • SpringBoot項(xiàng)目使用mybatis-plus逆向自動(dòng)生成全套代碼

    SpringBoot項(xiàng)目使用mybatis-plus逆向自動(dòng)生成全套代碼

    在JavaWeb工程中,每一個(gè)SSM新項(xiàng)目或者說(shuō)是SpringBoot項(xiàng)目也好,都少不了model、controller、service、dao等層次的構(gòu)建。使用mybatis-plus逆向可以自動(dòng)生成,感興趣的可以了解一下
    2021-09-09
  • JavaGUI事件監(jiān)聽機(jī)制超詳細(xì)講解

    JavaGUI事件監(jiān)聽機(jī)制超詳細(xì)講解

    Java事件監(jiān)聽器是由事件類和監(jiān)聽接口組成,自定義一個(gè)事件前,必須提供一個(gè)事件的監(jiān)聽接口以及一個(gè)事件類。JAVA中監(jiān)聽接口是繼承java.util.EventListener的類,事件類繼承java.util.EventObject的類
    2023-03-03
  • Java設(shè)計(jì)模式之命令模式

    Java設(shè)計(jì)模式之命令模式

    這篇文章介紹了Java設(shè)計(jì)模式之命令模式,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-10-10
  • java super關(guān)鍵字知識(shí)點(diǎn)詳解

    java super關(guān)鍵字知識(shí)點(diǎn)詳解

    在本篇文章里小編給大家整理的是一篇關(guān)于java super關(guān)鍵字知識(shí)點(diǎn)詳解內(nèi)容,有興趣的朋友們可以參考下。
    2021-01-01
  • Java調(diào)用SSE流式接口并流式返回給前端實(shí)現(xiàn)打字輸出效果

    Java調(diào)用SSE流式接口并流式返回給前端實(shí)現(xiàn)打字輸出效果

    在Web開發(fā)中,有時(shí)我們需要將文件以流的形式返回給前端,下面這篇文章主要給大家介紹了關(guān)于Java調(diào)用SSE流式接口并流式返回給前端實(shí)現(xiàn)打字輸出效果的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • Spring思維導(dǎo)圖助你輕松學(xué)習(xí)Spring

    Spring思維導(dǎo)圖助你輕松學(xué)習(xí)Spring

    這篇文章主要為大家詳細(xì)介紹了Spring思維導(dǎo)圖,幫助你輕松學(xué)習(xí)Spring的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Java并發(fā)編程預(yù)防死鎖過(guò)程詳解

    Java并發(fā)編程預(yù)防死鎖過(guò)程詳解

    這篇文章主要介紹了Java并發(fā)編程預(yù)防死鎖過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • 關(guān)于弱引用WeakReference所引用的對(duì)象的回收規(guī)則

    關(guān)于弱引用WeakReference所引用的對(duì)象的回收規(guī)則

    這篇文章主要介紹了關(guān)于弱引用WeakReference所引用的對(duì)象的回收規(guī)則,如果一個(gè)弱引用實(shí)例的成員變量referent引用了一個(gè)對(duì)象obj,那么就稱這個(gè)弱引用實(shí)例對(duì)obj的引用是弱引用,被一個(gè)弱引用實(shí)例引用的對(duì)象,稱為弱引用對(duì)象,需要的朋友可以參考下
    2023-09-09
  • Java實(shí)現(xiàn)發(fā)送手機(jī)短信語(yǔ)音驗(yàn)證功能代碼實(shí)例

    Java實(shí)現(xiàn)發(fā)送手機(jī)短信語(yǔ)音驗(yàn)證功能代碼實(shí)例

    這篇文章主要介紹了Java實(shí)現(xiàn)發(fā)送手機(jī)短信語(yǔ)音驗(yàn)證功能代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09

最新評(píng)論