中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

Java項目怎么利用ibatis進行搭建

這篇文章將為大家詳細講解有關Java項目怎么利用ibatis進行搭建,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

成都創新互聯公司的客戶來自各行各業,為了共同目標,我們在工作上密切配合,從創業型小企業到企事業單位,感謝他們對我們的要求,感謝他們從不同領域給我們帶來的挑戰,讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。專業領域包括網站制作、成都網站設計、電商網站開發、微信營銷、系統平臺開發。

IBATIS簡介

ibatis是 Apache的開源項目,一個ORM 解決方案,ibatis最大的特點就是小巧,上手很快。

使用 ibatis提供的ORM機制,對業務邏輯實現人員而言,面對的是純粹的Java對象,這一層與通過Hibernate 實現ORM而言是基本一致的。

iBatis是一個基于SQL映射支持Java和·NET的持久層框架,相對Hibernate和ApacheOJB等“一站式”ORM解決方案而言,iBatis 是一種“半自動化”的ORM實現。

一、JAR包依賴

ibatis-2.3.4.726.jar

MySQL-connector-java-5.0.8-bin.jar

二、SqlMap.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test
username=root
password=root

三、SqlMapConfig.xml

<&#63;xml version="1.0" encoding="UTF-8"&#63;>
<!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
	<!-- 引用JDBC屬性的配置文件 -->
	<properties resource="com/ligang/SqlMap.properties"/>
	<!-- 使用JDBC的事務管理 -->
	<transactionManager type="JDBC">
		<!-- 數據源 -->
		<dataSource type="SIMPLE">
			<property name="JDBC.Driver" value="${driver}"/>
			<property name="JDBC.ConnectionURL" value="${url}"/>
			<property name="JDBC.Username" value="${username}"/>
			<property name="JDBC.Password" value="${password}"/>
		</dataSource>
	</transactionManager>
	<!-- 這里可以寫多個實體的映射文件 -->
	<sqlMap resource="com/ligang/Student.xml"/>
</sqlMapConfig>

四、Student.xml

<&#63;xml version="1.0" encoding="UTF-8" &#63;>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-2.dtd">
<sqlMap>
	<!-- 通過typeAlias使得我們在下面使用Student實體類的時候不需要寫包名 -->
	<typeAlias alias="Student" type="com.ligang.Student"/>
	
	<!-- id表示select里的sql語句,resultClass表示返回結果的類型 -->
	<select id="findAll" resultClass="Student">
		select * from student
	</select>
	<!-- parameterClass表示參數的內容 -->
	<select id="findByID" parameterClass="String" resultClass="Student">
		select * from student where id = #id#
	</select>
	
	<insert id="insertStudent" parameterClass="Student">
		insert into Student(id,name,age,address) values(#id#,#name#,#age#,#address#)
		<!-- 返回自動增長值 -->
		<selectKey resultClass="String" keyProperty="id">
			select @@identity as inserted
		</selectKey>
	</insert>
	<delete id="deleteStudentByID" parameterClass="String">
		delete from student where id = #id#
	</delete>
	<delete id="deleteStudent" parameterClass="Student">
		delete from Student where id = #id#
	</delete>
	<update id="updateStudent" parameterClass="Student">
		update student set name=#name#,age=#age#,address=#address# where id = #id#
	</update>
	<!-- 模糊查詢,使用$代替#。此種方法就是去掉了類型檢查,使用字符串連接,不過可能會有sql注入風險-->
	<select id="selectByLike" parameterClass="String" resultClass="Student">
		select * from student where name like '%$name$%'
	</select>
	<!-- 多條件組合查詢 -->
	<!-- 方法一(對象構造查詢參數) -->
	<!-- 項目中在寫ibatis中的sql語句時,where user_id in (#user_id_list# ),運行時總是不行,這里不該用#,而應該用$,區別如下:
		1.#是把傳入的數據當作字符串,如#user_id_list#傳入的是1,2,則sql語句生成是這樣,in ('1,2') ,當然不可以
		2.$傳入的數據直接生成在sql里,如#user_id_list#傳入的是1,2,則sql語句生成是這樣,in(1,2) 這就對了. 
		3.#方式能夠很大程度防止sql注入. 
		4.$方式無法方式sql注入. 
		5.$方式一般用于傳入數據庫對象.例如傳入表名. 
		6.一般能用#的就別用$. 
		直觀的說 
		#str# 出來的效果是 'str' 
		$str$ 出來的效果是 str 
		另外 ##只能用在特定的幾個地方 $$可以用在任何地方 比如 order by $str$ 
		你甚至可以直接寫 $str$ 把 order by 這個字串放在str里傳進來 -->
	<select id="findByCon1" parameterClass="Student" resultClass="Student">
		select * from student where name like '%$name$%' and age >= #age#
	</select>
	<!-- 方法二(map封裝查詢參數) -->
	<parameterMap class="java.util.HashMap" id="paramMap">
		<parameter property="name"/>
		<parameter property="age"/>
	</parameterMap>
	<select id="findByCon2" parameterMap="paramMap" resultClass="Student">
		select * from student where name like &#63; and age >= &#63;
	</select>
</sqlMap>

五、JAVA代碼

實體類:略

Dao:略

DaoImpl:

package com.ligang;
import java.io.IOException;
import java.io.Reader;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
public class StudentDaoImpl implements StudentDao {
	public static SqlMapClient sqlMapClient = null;
	static{
		try {
			Reader reader = Resources.getResourceAsReader("com/ligang/SqlMapConfig.xml");
			sqlMapClient = SqlMapClientBuilder.buildSqlMapClient(reader);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	public List<Student> findAll() {
		List<Student> list = null;
		try {
			list = sqlMapClient.queryForList("findAll");
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return list;
	}
	public Student findByID(String id){
		Student student = null;
		try {
			 student = (Student) sqlMapClient.queryForObject("findByID", id);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return student;
	}
	public void addStudent(Student student){
		try {
			sqlMapClient.insert("insertStudent",student);
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	public void deleteStudentByID(String id){
		try {
			sqlMapClient.delete("deleteStudentByID",id);
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	public void deleteStudent(Student student){
		try {
			sqlMapClient.delete("deleteStudent",student);
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	public void updateStudent(Student student){
		try {
			sqlMapClient.update("updateStudent", student);
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	public List<Student> findByCon(String name){
		List<Student> stuList = new ArrayList<Student>();
		try {
			stuList = sqlMapClient.queryForList("selectByLike",name);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return stuList;
	}
	public List<Student> findByCon(Student student){
		List<Student> stuList = new ArrayList<Student>();
		try {
			stuList = sqlMapClient.queryForList("findByCon1",student);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return stuList;
	}
	public List<Student> findByCon(Map map){
		List<Student> stuList = new ArrayList<Student>();
		try {
			stuList = sqlMapClient.queryForList("findByCon2",map);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return stuList;
	}
}

關于Java項目怎么利用ibatis進行搭建就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

分享名稱:Java項目怎么利用ibatis進行搭建
URL標題:http://m.2m8n56k.cn/article34/jdccpe.html

成都網站建設公司_創新互聯,為您提供手機網站建設標簽優化網站排名、網站維護、品牌網站建設、虛擬主機

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

綿陽服務器托管
主站蜘蛛池模板: 亚洲免费视频一区二区三区 | 国产99视频精品免视看9 | 亚洲一级二级三级 | 亚洲国产成人久久一区二区三区 | 久久精品国产免费观看99 | 国产成人高清亚洲一区91 | 亚洲综合图片人成综合网 | 久久免费激情视频 | 亚洲在线欧美 | 国产精品成aⅴ人片在线观看 | 欧美不卡视频在线观看 | 欧美一区二区在线视频 | 日韩视频在线观看一区二区 | 久久精品视频大全 | 欧美一区二区三区免费看 | 免费欧美一级 | 亚洲精品久久久久午夜三 | 亚洲精品中文字幕一区在线 | 亚洲男人的天堂久久香蕉网 | www.一级片.com| 免费香蕉成视频成人网 | 美女很黄很黄免费 | 一级特一级特色生活片 | 成人a区| 免费伦费一区二区三区四区 | 538在线视频二三区视视频 | 亚洲国产一区二区三区四区 | 国产在线观看网址在线视频 | 国内精品伊人久久久久妇 | 日韩在线视频不卡一区二区三区 | 欧美成人 综合网播九公社 欧美成人26uuu欧美毛片 | 狠狠色综合久久丁香婷婷 | 拍拍拍又黄又爽无挡视频免费 | 亚洲aⅴ男人的天堂在线观看 | 国产精品96久久久久久久 | 韩国a级毛片 | 狠狠综合久久久久综合 | 综合亚洲欧美日韩一区二区 | 欧美日韩成人在线视频 | 香蕉网站狼人久久五月亭亭 | 97视频免费在线观看 |