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小时内与您取得联系。