>Java >java지도 시간 >Java 프로젝트 구축을 위한 ibatis 학습에 대한 자세한 설명

Java 프로젝트 구축을 위한 ibatis 학습에 대한 자세한 설명

黄舟
黄舟원래의
2017-09-21 10:33:371653검색

이 글의 주요 내용은 ibatis에 대한 간략한 소개와 iBatis를 통해 JAVA 프로젝트를 구축하는 방법입니다. 또한 관련 예제도 포함되어 있어 필요한 친구들이 참고할 수 있습니다.

IBATIS 소개

ibatis는 ORM 솔루션인 Apache의 오픈소스 프로젝트로, 크기가 작고 사용하기 쉽다는 점이 가장 큰 특징입니다.

ibatis에서 제공하는 ORM 메커니즘을 사용하면 비즈니스 로직 구현자는 순수 Java 객체에 직면하게 됩니다. 이 계층은 기본적으로 Hibernate를 통해 ORM을 구현하는 것과 동일합니다.

iBatis는 Java 및 .NET을 지원하는 SQL 매핑 기반의 지속성 계층 프레임워크입니다. Hibernate 및 Apache OJB와 같은 "원스톱" ORM 솔루션과 비교할 때 iBatis는 "반자동" ORM 구현입니다.

1.JAR 패키지 종속성

ibatis-2.3.4.726.jar

mysql-connector-java-5.0.8-bin.jar

2. 아아아아

Three, SqlMapConfig.xml

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

Four, Student.xml

<?xml version="1.0" encoding="UTF-8"?>
<!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>

Five, JAVA 코드

엔티티 클래스: 약간

Dao: 약간

DaoImpl:

<?xml version="1.0" encoding="UTF-8" ?>
<!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 &#39;%$name$%&#39;
	</select>
	<!-- 多条件组合查询 -->
	<!-- 方法一(对象构造查询参数) -->
	<!-- 项目中在写ibatis中的sql语句时,where user_id in (#user_id_list# ),运行时总是不行,这里不该用#,而应该用$,区别如下:
		1.#是把传入的数据当作字符串,如#user_id_list#传入的是1,2,则sql语句生成是这样,in (&#39;1,2&#39;) ,当然不可以
		2.$传入的数据直接生成在sql里,如#user_id_list#传入的是1,2,则sql语句生成是这样,in(1,2) 这就对了. 
		3.#方式能够很大程度防止sql注入. 
		4.$方式无法方式sql注入. 
		5.$方式一般用于传入数据库对象.例如传入表名. 
		6.一般能用#的就别用$. 
		直观的说 
		#str# 出来的效果是 &#39;str&#39; 
		$str$ 出来的效果是 str 
		另外 ##只能用在特定的几个地方 $$可以用在任何地方 比如 order by $str$ 
		你甚至可以直接写 $str$ 把 order by 这个字串放在str里传进来 -->
	<select id="findByCon1" parameterClass="Student" resultClass="Student">
		select * from student where name like &#39;%$name$%&#39; 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 ? and age >= ?
	</select>
</sqlMap>

요약

위 내용은 Java 프로젝트 구축을 위한 ibatis 학습에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.