• 技术文章 >Java >java教程

    Java项目搭建之ibatis学习详解

    黄舟黄舟2017-09-21 10:33:37原创803
    本文的主要内容是简单介绍了ibatis和如何通过iBatis搭建JAVA项目,包含了一个相关实例,需要的朋友可以参考下。

    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

    <?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>

    四、Student.xml

    <?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 '%$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 ? and age >= ?
    	</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学习详解的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:ibatis Java 学习
    上一篇:Java中静态代码块的执行简单介绍 下一篇:Java语言中关于一元运算符的详解
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• 简单归纳java线程池的四种创建方式• Java中Map接口的使用以及面试知识点总结• 简单介绍Java Servlet程序• SpringCloud Tencent 全套解决方案一• 详细介绍Java虚拟机:JVM垃圾回收器
    1/1

    PHP中文网