全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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;
	}
}

总结

通过学习我们会发现,Hibernate体系中的内容真的很多,而ibatis更容易上手,小巧灵活。本文有关ibatis搭建Java项目的介绍就到这里,希望对大家有所帮助。


# ibatis  # ibatis搭建Java项目  # struts2+spring+ibatis框架整合实现增删改查  # 在Spring使用iBatis及配置讲解  # ibatis结合oracle批量插入三种方法的测评  # java~springboot~ibatis数组in查询的实现方法  # ibatis迁移到mybatis3的注意事项  # 通过ibatis解决sql注入问题  # Mybatis报错: org.apache.ibatis.exceptions.Persistenc  # Mybatis与Ibatis的区别  # Ibatis配置xml文件CDATA使用方法详解  # 的是  # 是这样  # 该用  # 是一个  # 几个  # 这一  # 是一种  # 会有  # 放在  # 多个  # 的说  # 不可以  # 这就  # 掉了  # 可以直接  # 实体类  # 不需  # 更容易  # 就到  # 用在 


相关文章: 如何通过云梦建站系统实现SEO快速优化?  建站之星代理平台如何选择最佳方案?  上海网站制作开发公司,上海买房比较好的网站有哪些?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  如何选择高性价比服务器搭建个人网站?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  如何快速生成凡客建站的专业级图册?  建站之星安装模板失败:服务器环境不兼容?  盐城做公司网站,江苏电子版退休证办理流程?  如何在VPS电脑上快速搭建网站?  如何在云虚拟主机上快速搭建个人网站?  如何快速搭建安全的FTP站点?  开封网站制作公司,网络用语开封是什么意思?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  宝塔Windows建站如何避免显示默认IIS页面?  建站主机类型有哪些?如何正确选型  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  ppt制作免费网站有哪些,ppt模板免费下载网站?  建站之星代理商如何保障技术支持与售后服务?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  深圳网站制作平台,深圳市做网站好的公司有哪些?  网站制作需要会哪些技术,建立一个网站要花费多少?  电商平台网站制作流程,电商网站如何制作?  实例解析Array和String方法  如何在云服务器上快速搭建个人网站?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  如何设计高效校园网站?  如何快速查询网址的建站时间与历史轨迹?  大型企业网站制作流程,做网站需要注册公司吗?  常州企业建站如何选择最佳模板?  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  如何通过老薛主机一键快速建站?  如何零基础在云服务器搭建WordPress站点?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  如何在建站之星绑定自定义域名?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  如何规划企业建站流程的关键步骤?  宝塔面板如何快速创建新站点?  如何在云主机快速搭建网站站点?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何选择网络建站服务器?高效建站必看指南  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  网站制作公司排行榜,四大门户网站排名? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。