您好,登錄后才能下訂單哦!
JAVA中,操作數(shù)據(jù)庫(kù)有JDBC、hibernate、Mybatis等技術(shù),今天整理了下,來(lái)講一講下Mybatis。也為自己整理下文檔;
hibernate是一個(gè)完全的ORM框架,是完全面向?qū)ο蟮?。但是由于全部都是以?duì)象的形式來(lái)操作數(shù)據(jù)庫(kù),sql代碼都是由框架自動(dòng)生成,可操作性和靈活性比較Mybatis都要差一些。所以,Mybatis慢慢的變成多數(shù)開(kāi)發(fā)的標(biāo)準(zhǔn)配置;
一、myBatis框架建設(shè)
myBatis的整體框架結(jié)構(gòu)如下圖所示,按照下圖的工程原樣建立即可(其中jar包在文章末尾提供)
mysql數(shù)據(jù)庫(kù)):
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中寫(xiě)入配置文件
<!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ù)與密碼需要改成你自己的賬號(hào)密碼
三、在config包下建立log4j.properties(公用文件)
# Global logging configuration,建議開(kāi)發(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
四、開(kāi)始編寫(xiě)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開(kāi)發(fā)dao方式,使用namespace有特殊作用 --> <mapper namespace="test"> <!-- 在mapper.xml文件中配置很多的sql語(yǔ)句,執(zhí)行每個(gè)sql語(yǔ)句時(shí),封裝為MappedStatement對(duì)象 mapper.xml以statement為單位管理sql語(yǔ)句 --> <!-- 根據(jù)id查詢(xún)用戶(hù)信息 --> <!-- id:唯一標(biāo)識(shí) 一個(gè)statement #{}:表示 一個(gè)占位符,如果#{}中傳入簡(jiǎn)單類(lèi)型的參數(shù),#{}中的名稱(chēng)隨意 parameterType:輸入 參數(shù)的類(lèi)型,通過(guò)#{}接收parameterType輸入 的參數(shù) resultType:輸出結(jié)果 類(lèi)型,不管返回是多條還是單條,指定單條記錄映射的pojo類(lèi)型 --> <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)單的查詢(xún)操作;
=========================使用Mybatis!===============================
一、在first包中建立測(cè)試類(lèi)(MybatisFrist.java)
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類(lèi)下的getResourceAsStream實(shí)現(xiàn) InputStream inputStream = Resources.getResourceAsStream(resource); //創(chuàng)建Mybitis的SqlSessionFactory工廠(chǎng)類(lèi) sqlsessionfactory = new SqlSessionFactoryBuilder().build(inputStream); } @Test public void test(){ //通過(guò)工廠(chǎng)類(lèi)打開(kāi)數(shù)據(jù)接口 SqlSession sqlsession = sqlsessionfactory.openSession(); //設(shè)置接收對(duì)象 User user = null; try { //查詢(xún)數(shù)據(jù)selectOne為查詢(xún)一條的方法第一個(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é)果為:
<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類(lèi)型和jdbc類(lèi)型自動(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é)果為:
向AI問(wèn)一下細(xì)節(jié)
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。