ibatis轻松入门
近日,由于公司项目应用开发的逻辑层使用的是iBatis。上网查了些资料,自己写了点demo入门。感觉良好。iBatis实在是比Hibernate很容易入门,贡献出来与各路菜鸟分享(后文附源码),希望得到大神指教。转载请保留本文出处:http://itred.cnblogs.com ; 作者:itRed。
ORM框架中操作数据库的逻辑层中,Hibernate和iBatis相对来说是比较受欢迎的。Hibernate是“全自动”的,能够完全生成SQL语句;而iBatis是“半自动化”的,需要程序员根据自己的应用程序写相应的SQL语句。但是,在实际的开发过程中还是应根据实际情况进行选择。(iBatis的优缺点比较)
优点 | 缺点 |
与JDBC相比减少了很多的代码量;入门简单;架构级性能较强; Sql语句和程序代码的分离;简化项目中的分工; 增强了移植性。 |
Sql语句需要程序员自己写; 参数数量只能一个,但是如果需要多个参数时, 需要将参数打包封装成Map等; |
在进行iBatis应用程序开发之前首先需要对iBatis这个技术有一定的了解。iBatis是apache下的一个开源项目,因为其小巧,上手很快深受程序员的喜爱。iBatis的核心是SqlMap。
本案例将详细介绍iBatis操作MySQL数据库。 利用iBatis对数据库中的记录进行简单的增删改查操作。测试方法main,显示结果到控制台。部分结果直接查看数据库信息。虽然demo比较简单,但是很能起到抛砖引玉的作用。
数据准备:
数据库名称:ibatis
表名称:student
本人数据库中的数据信息:
案例解析及源码:
在正式操作数据库之前需要做一些准备工作,部分备注详见源码注释中:
首先需要导入ibatis的相关jar包,以及连接数据库的驱动jar包;在新建的项目文件下建一个Student的实体Bean。
package com.red; import java.util.Date;
/**
* Student实体类
* @author Red
*
*/
public class Student {
//保证一个无参数方法。反射机制
private int sid=0;
private String sname=null;
private String major=null;
private Date birth=null;
private int score=0; public int getSid() {
return sid;
}
public void setSid(int sid) {
this.sid = sid;
}
public String getSname() {
return sname;
}
public void setSname(String sname) {
this.sname = sname;
}
public String getMajor() {
return major;
}
public void setMajor(String major) {
this.major = major;
}
public Date getBirth() {
return birth;
}
public void setBirth(Date birth) {
this.birth = birth;
}
public int getScore() {
return score;
}
public void setScore(int score) {
this.score = score;
}
@Override
public String toString() { //重写toString方法,方便控制台显示
String content="sid="+sid+"\tsname:"+sname+"\tmajor:"+major+"\tbirth:"+birth+"\tscore:"+score;
return content;
} }
Student.java
建一个接口以及它的实现类,为了测试方便直接将main方法放到该接口实现类中;
package com.red; import java.util.List;
/**
* 接口
* @author Red
*
*/
public interface IStudentDAO {
public void addStudent(Student student);
public void deleteStudentById(int id);
public void updateStudentById(Student studnet);
public List<Student> queryAllStudent();
public List<Student> queryStudentByName(String name);
public Student queryStudentById(int id);
}
IStudentDAO
package com.red; import java.io.Reader;
import java.sql.SQLException;
import java.util.List; import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder; public class IStudentDAOImpl implements IStudentDAO { private static SqlMapClient sqlMapClient=null;
static{
try{
Reader reader=Resources.getResourceAsReader("com/red/SqlMapConfig.xml");
sqlMapClient = SqlMapClientBuilder.buildSqlMapClient(reader);
reader.close();
}catch (Exception e) {
e.printStackTrace();
}
} public void addStudent(Student student) {
try {
sqlMapClient.insert("insertStudent", student);
} catch (SQLException e) {
e.printStackTrace();
} } public void deleteStudentById(int id) {
try {
sqlMapClient.delete("deleteStudentById",id);
} catch (SQLException e) {
e.printStackTrace();
}
} public List<Student> queryAllStudent() {
List<Student> studentList=null;;
try {
studentList=sqlMapClient.queryForList("selectAllStudent");
} catch (SQLException e) {
e.printStackTrace();
}
return studentList;
} public Student queryStudentById(int id) {
Student student=null;
try {
student=(Student) sqlMapClient.queryForObject("selectStudentById",id);
} catch (SQLException e) {
e.printStackTrace();
}
return student;
} /**
* 模糊查询
*/
public List<Student> queryStudentByName(String name) {
List<Student> studentList=null;
try {
studentList=sqlMapClient.queryForList("selectStudentByName", name);
} catch (SQLException e) {
e.printStackTrace();
}
return studentList;
} public void updateStudentById(Student student) {
try {
sqlMapClient.update("updateStudentById", student);
} catch (SQLException e) {
e.printStackTrace();
} } public static void main(String[] args) {
IStudentDAO dao=new IStudentDAOImpl();
/**
* 查询所有的学生对象*/
for(Student student:dao.queryAllStudent()){//遍历student对象
System.out.println(student);
} /**
* 查询指定id的学生对象
Student student=dao.queryStudentById(1);
System.out.println(student);
//以上两行代码可缩写为:
System.out.println(dao.queryStudentById(1));
*/ /**
* 插入学生对象数据
Student student=new Student();
student.setSid(3);
student.setSname("小明");
student.setMajor("应用化学");
student.setBirth(Date.valueOf("2013-09-09"));
student.setScore(88);
dao.addStudent(student);
*/ /**
* 删除指定id的学生数据
dao.deleteStudentById(1);
*/ /**
* 修改数据对象 Student student=new Student();
student.setSid(3);
student.setSname("朱小明");
student.setMajor("嵌入式开发");
student.setBirth(Date.valueOf("2013-09-09"));
student.setScore(68);
dao.updateStudentById(student);
*/ /**
* 模糊查询 for(Student student:dao.queryStudentByName("t")){
System.out.println(student);
}
*/
}
}
IStudentDAOImpl
建立一个SqlMap.properties的文件,该属性文件主要负责数据库的链接
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/ibatis
username=root
password=123456
SqlMap.properies
建立一个SqlMapConfig.xml文件,主要负责ibatis的配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//ibatis.apache.org//DTD SQLL Map Config 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-config-2.dtd"> <sqlMapConfig>
<properties resource="com/red/SqlMap.properties"/>
<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/red/Student.xml"/>
</sqlMapConfig>
SqlMapConfig.xml
建立实体类的映射文件(SQL语句就在其中)
<?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 alias="student" type="com.red.Student"/>
<!-- 配置表和实体之间的映射关系 -->
<resultMap class="com.red.Student" id="student">
<result property="sname" column="SNAME"/>
<result property="major" column="MAJOR"/>
<result property="birth" column="BIRTH"/>
<result property="score" column="SCORE"/>
</resultMap> <select id="selectAllStudent" resultClass="student">
SELECT SID,SNAME,MAJOR,BIRTH,SCORE FROM `ibatis`.`student`
</select> <select id="selectStudentById" parameterClass="int" resultClass="student">
SELECT SID,SNAME,MAJOR,BIRTH,SCORE FROM `ibatis`.`student`
WHERE SID=#sid#
</select> <insert id="insertStudent" parameterClass="student">
INSERT INTO `ibatis`.`student`(SID,SNAME,MAJOR,BIRTH,SCORE)
values(#sid#,#sname#,#major#,#birth#,#score#)
</insert> <delete id="deleteStudentById" parameterClass="int">
DELETE FROM `ibatis`.`student`
WHERE sid=#sid#
</delete> <update id="updateStudentById" parameterClass="student">
UPDATE `ibatis`.`student` SET
SNAME=#sname#,MAJOR=#major#,BIRTH=#birth#,SCORE=#score#
WHERE sid=#sid#
</update> <select id="selectStudentByName" parameterClass="String" resultClass="student">
SELECT SID,SNAME,MAJOR,BIRTH,SCORE FROM `ibatis`.`student`
WHERE SNAME LIKE '%$sname$%'
</select>
</sqlMap>
Student.xml
ibatis查询数据库所有数据(重点解析本查询案例,另外的几个操作很简单,源码附注释,很容易看懂。不懂可以Email我。)
public List<Student> queryAllStudent() {
List<Student> studentList=null;;
try {
studentList=sqlMapClient.queryForList("selectAllStudent");
} catch (SQLException e) {
e.printStackTrace();
}
return studentList;
}
Student中的SQL语句:
前几日刚在公司学到的经验,程序员在写SQL语句中的字段和关键字时尽量大写,显得专业,而且提高数据库的查询效率。
<select id="selectAllStudent" resultClass="student">
SELECT SID,SNAME,MAJOR,BIRTH,SCORE FROM `ibatis`.`student`
</select>
Main方法中的测试代码:
IStudentDAO dao=new IStudentDAOImpl();
for(Student student:dao.queryAllStudent()){//遍历student对象
System.out.println(student);
}
运行结果:
iBatis 模糊查询
iBatis 添加数据记录
iBatis 修改数据记录
iBatis 删除数据记录
这些操作都可以依葫芦画瓢,后文附本DEMO的源码,欢迎各位来邮交流学习心得。E-mail: it_red@sina.com
测试时,只需要去除要运行部分的注释。右击测试main方法就可顺利在控制台看到运行结果。
作者:itRed
出处:http://itred.cnblogs.com
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段说明,且在文章明显位置给出原文链接,否则保留追究法律责任的权利。
ibatis轻松入门的更多相关文章
- ibatis 轻松入门
1.总中的配置文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE sqlMapConfig ...
- iBatis.net入门指南
iBatis.net入门指南 - 1 - 什么是iBatis.net ? - 3 - iBatis.net的原理 - 3 - 新人指路 - 3 - iBatis.net的优缺点 ...
- Groovy轻松入门——通过与Java的比较,迅速掌握Groovy (更新于2008.10.18)
摘自: http://www.blogjava.net/BlueSUN/archive/2007/03/10/103014.html Groovy轻松入门--通过与Java的比较,迅速掌握Groovy ...
- Groovy轻松入门——搭建Groovy开发环境
摘自: http://www.blogjava.net/BlueSUN/archive/2007/03/17/104391.html Groovy轻松入门--搭建Groovy开发环境 多日来,我发表了 ...
- C++ STL编程轻松入门基础
C++ STL编程轻松入门基础 1 初识STL:解答一些疑问 1.1 一个最关心的问题:什么是STL 1.2 追根溯源:STL的历史 1.3 千丝万缕的联系 1.4 STL的不同实现版本 2 牛刀小试 ...
- Swift轻松入门——基本语法介绍和详细地Demo讲解(利用WebView打开百度、新浪等网页)
转载请务必注明出处(all copyright reserved by iOSGeek) 本文主要分为两个部分,第一部分介绍Swift的基本语法,第二部分讲解一个利用WebView来打开百度.sina ...
- JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)
本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...
- asp.net core轻松入门之MVC中Options读取配置文件
接上一篇中讲到利用Bind方法读取配置文件 ASP.NET Core轻松入门Bind读取配置文件到C#实例 那么在这篇文章中,我将在上一篇文章的基础上,利用Options方法读取配置文件 首先注册MV ...
- AngularJs轻松入门
AngularJs轻松入门系列博文:http://blog.csdn.net/column/details/angular.html AngularJs轻松入门(一)创建第一个应用 AngularJs ...
随机推荐
- JSON 序列化和反序列化——JavaScriptSerializer实现
一. JavaScriptSerializer 类由异步通信层内部使用,用于序列化和反序列化在浏览器和 Web 服务器之间传递的数据.您无法访问序列化程序的此实例.但是,此类公开了公共 API.因此, ...
- nginx(2、反向代理)
反向代理是nginx最重要的特性之一,与正向代理相反,它代理的不是客户端,而是目标源,即我代理目标源满足客户端给出的请求. 在nginx中反向代理的简单配置如下: server { listen 80 ...
- 接口分离原则(Interface Segregation Principle)
接口分离原则(Interface Segregation Principle)用于处理胖接口(fat interface)所带来的问题.如果类的接口定义暴露了过多的行为,则说明这个类的接口定义内聚程度 ...
- 利用avalon 实现一个简单的成绩单
本文的灵感是来自Halower的这篇博文,他是使用knockout与jQuery实现的.不过我觉得MVVM本来就强大的事件绑定功能,因此用jQuery 是多此一举.另,他也用了一些面向对象的写法.我个 ...
- 把 Notepad++ 打造成一款易用的C#脚本编辑器
以前一直用Linqpad在写小程序脚本,但是Linqpad自动完成功能要收费,且不开源,这样的话就不方便扩展了.今天在 http://csscriptnpp.codeplex.com/ 发现了一款C# ...
- Spring-Context之三:使用XML和Groovy DSL配置Bean
在第一讲中显示了如何使用注解配置bean,其实这是Spring3引进的特性,Spring2使用的是XML的方式来配置Bean,那时候漫天的XML文件使得Spring有着配置地狱的称号.Spring也一 ...
- 实践基于Task的异步模式
Await 返回该系列目录<基于Task的异步模式--全面介绍> 在API级别,实现没有阻塞的等待的方法是提供callback(回调函数).对于Tasks来说,这是通过像ContinueW ...
- MVVM架构~knockoutjs系列之包括区域级联列表的增删改
返回目录 这个例子我做了几次,之前总是有BUG,目前测试后,确定没有BUG才发上来的,主要功能是实现“我的银行”模块的增删改的功能,这个里面包括了级联列表的区域选择,这部分是难点,在开发过程中,我们应 ...
- 手打的笔记,java语法中的输入输出,语句,及注释。
手打的笔记: () 内的则为注意事项或者提示 public static void main (String[] args) ******(用一个方法)****{ int i = 10; int j ...
- Atitit 代理与分销系统(1) 子代理 充值总额功能设计概览 sum() groubpy subagt
Atitit 代理与分销系统(1) 子代理 充值总额功能设计概览 sum() groubpy subagt Keyword 分组与聚合操作. 一个for做分组...里面的做聚合... 数据g操作查 ...