Batis-iBatis基本操作(增删改查)

在上一篇iBatis博客中已介绍了如何 配置iBatis环境,这篇博客主要进行介绍一些iBatis的基本操作实现。iBatis的增删改操作都需要操作SqlMap,DAO层Manger,POJO 这几个类来实现。 下面分别介绍一下iBatis基本操作的实现:

一.iBatis的添加数据方式

这里介绍两种iBatis添加数据的方式:基本方式,添加用户信息;通过map方式,添加用户信息。

若要使用iBatis执行任何CRUD(创建、查询、更新、删除)操作,需要创建一个POJO类。如下:

1.建立POJO对象--User

package com.azj.test;

/**
* 用户实体类
* @author AZJ
*
*/
public class User {
/**
* 唯一标识
*/
private String id;
/**
* 名字
*/
private String firstName;
/**
* 姓
*/
private String lastName;
/**
* 电子邮件
*/
private String email;
/**
* 照片信息
*/
private String img; public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
} public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getImg() {
return img;
}
public void setImg(String img) {
this.img = img;
} }

2.上面User POJO类对应的数据库表为

3.在SqlMap中添加添加用户信息的方法

<?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 namespace="User">
<!-- 使用别名可以避免每次都输入类路径全称 -->
<typeAlias alias="User" type="com.azj.test.User"/>
<!-- 添加用户信息 -->
<insert id="addUsers" parameterClass="User">
INSERT INTO A_USER(
ID,
FIRST_NAME,
LAST_NAME,
EMAIL
) VALUES(
#id#,
#firstName#,
#lastName#,
#email#
)
</insert>
<!-- 通过map方式,添加用户信息 -->
<insert id="addUsersByMap" parameterClass="java.util.HashMap">
INSERT INTO A_USER(
ID,
FIRST_NAME,
LAST_NAME,
EMAIL
) VALUES(
#id#,
#firstName#,
#lastName#,
#email#
)
</insert> </sqlMap>

4.编写Manager类

Manager类数据DAO层,连接数据库,对数据库进行增删改查操作。类中添加两种添加用户信息的方法,与SqlMap中添加用户方法对应:

package com.azj.test;

import java.io.IOException;
import java.io.Reader;
import java.sql.SQLException;
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; /**
* Dao层,连接数据库,对数据库进行增删改查操作
* @author azj
*
*/
public class Manager {
//使用sqlMapClient,此类线程安全,所以可以定义成静态的
private static SqlMapClient sqlMaper; //静态块,初始化 sqlMaper;在类加载的时候执行一次
static{
try{
Reader reader=Resources.getResourceAsReader("sqlMapConfig.xml");
sqlMaper=SqlMapClientBuilder.buildSqlMapClient(reader);
reader.close(); }catch(IOException e){
throw new RuntimeException(e);
}
} /**
* 添加用户信息
* @throws SQLException
*/
public static void addUser(User user) throws SQLException{
sqlMaper.insert("addUsers",user);//与SqlMap中添加用户信息方法对应
} /**
* 通过map方式,添加用户信息
* @param userMap
* @throws SQLException
*/
public static void addUserByMap(Map userMap) throws SQLException{
sqlMaper.insert("addUsersByMap", userMap); //与SqlMap中添加用户信息方法对应 }
}

5.添加测试类,测试用户信息是否添加成功

package com.azj.test;

import java.util.HashMap;
import java.util.Map; import junit.framework.TestCase; public class TestInsert extends TestCase {
/**
* 添加用户信息
*/
public void testInsertUser(){
User user=new User();
user.setId("1");
user.setFirstName("子");
user.setLastName("李");
user.setEmail("m@sina.com"); try{
Manager.addUser(user); }catch(Exception e){
e.printStackTrace();
} } /**
* 通过map方式,添加用户信息
*/
public void testInsertUserByMap(){ Map userMap=new HashMap(); userMap.put("id", "2");
userMap.put("firstName", "芳芳");
userMap.put("lastName","王");
userMap.put("email", "value@163.com"); try{
Manager.addUserByMap(userMap); }catch(Exception e){
e.printStackTrace();
} } }

通过JUnit单元测试,执行此测试文件,可以看出用户信息添加成功!通过JUnit控制台打印信息如图:

数据库表信息添加的用户信息如图:

二.iBatis查询数据方式

这里介绍4种查询用户信息的方式:根据id查询用户信息,根据实体类(用户)查询用户信息,查询所有用户信息(list 和map方式)。

1.POJO对象见iBatis添加数据方式

2.数据表信息

3. 在SqlMap中添加查询用户信息的方法

<resultMap id="UserResult" class="User" >
<result property="id" column="ID"/>
<result property="firstName" column="FIRST_NAME"/>
<result property="lastName" column="LAST_NAME"/>
<result property="email" column="EMAIL"/>
</resultMap>
<!-- 根据id查询用户信息 -->
<select id="selectUserById" parameterClass="java.lang.String" resultMap="UserResult">
SELECT * FROM A_USER WHERE ID=#id#
</select> <!-- 根据实体类(用户)查询用户信息 -->
<select id="selectUserByUser" parameterClass="User" resultMap="UserResult">
SELECT * FROM A_USER WHERE ID=#id#
</select> <!-- 查询所有用户信息 -->
<select id="selectUsers" resultMap="UserResult">
SELECT * FROM A_USER
</select>

4.在Manager类中添加查询用户信息的方法

//因其线程安全,设置为静态方法
/**
* 根据id查询用户信息
* @param id
* @return
* @throws SQLException
*/
public static User selectUserById(String id) throws SQLException{
return (User) sqlMaper.queryForObject("selectUserById",id); } /**
* 根据用户实体类查询用户实体
* @param user
* @return
* @throws SQLException
*/
public static User selectUserByUser(User user) throws SQLException{
return (User) sqlMaper.queryForObject("selectUserByUser",user);
} /**
* 查询所有用户信息,放于list中
* @param user
* @return
* @throws SQLException
*/
public static List selectUsers() throws SQLException{
return sqlMaper.queryForList("selectUsers");
} /**
* 查询所有用户信息,放于Map中
* @return
* @throws SQLException
*/
public static Map selectUserForMap() throws SQLException{ return sqlMaper.queryForMap("selectUsers", null, "id");
}

5.编写测试类,测试查询用户信息是否成功

package com.azj.test;

import java.util.List;
import java.util.Map; import junit.framework.TestCase; /**
* 测试查询用户信息
*
* @author azj
*/
public class TestManager extends TestCase {
public void testSelectUserById() {
try {
User user = Manager.selectUserById("1");
System.out.println(user);
System.out.println(user.getFirstName());
} catch (Exception e) {
e.printStackTrace();
} } /**
* 根据实体类查询用户信息
*/
public void testSelectUserByUser() {
try {
User userParmUser = new User();
userParmUser.setId("2");
User user = Manager.selectUserByUser(userParmUser);
System.out.println(user);
System.out.println(user.getFirstName());
} catch (Exception e) {
e.printStackTrace();
} } /**
* 查询用户信息放于List中
*/
public void testSelectUsers() {
try {
List userList = Manager.selectUsers();
User user = (User) userList.get(1); System.out.println(user);
System.out.println(user.getFirstName());
} catch (Exception e) {
e.printStackTrace();
} } /**
* 查询用户信息放于Map中
*/
public void testSelectUsersMap() {
try { Map userMap = Manager.selectUserForMap();
// 将ID为1的用户查出来
User user = (User) userMap.get("1");
System.out.println(user);
System.out.println(user.getFirstName());
} catch (Exception e) {
e.printStackTrace();
} }
}

通过JUnit测试,可看出查询方法正确,查询结果均如下所示:

三.iBatis修改数据方式

1.POJO对象见iBatis添加数据方式

2.数据表信息

3. 在SqlMap中添加修改用户信息的方法

<!-- 更新用户信息 -->
<update id="updateUserByID" parameterClass="User">
UPDATE A_USER SET
FIRST_NAME=#firstName#,
LAST_NAME=#lastName#,
EMAIL=#email#
WHERE
ID=#id#
</update>

4.在Manager类中添加修改用户信息的方法

/**
* 更新用户信息
* @param user
* @throws SQLException
*/ public static void updateUser(User user) throws SQLException{
sqlMaper.update("updateUserByID", user);
}

5.编写测试类,测试修改用户信息是否成功

/**
* 更新用户信息
*/
public void testUpdateUser(){
User user=new User();
user.setId("1");
try{
user=Manager.selectUserByUser(user); user.setFirstName("娟子");
user.setLastName("马");
user.setEmail("m2@sina.com"); Manager.updateUser(user); }catch(Exception e){
e.printStackTrace();
} }

通过JUnit测试,可看出修改成功!

四.iBatis删除数据方式

1.POJO对象见iBatis添加数据方式

2.数据表信息

3. 在SqlMap中添加删除用户信息的方法

<!--删除用户(多个)字符串拼接方式 -->
<update id="deleteByString" parameterClass="java.lang.String">
DELETE FROM A_USER WHERE ID IN($id$)
</update> <!-- 删除用户(多个)传参,标签说明使用,分割 ;以(开始,以)结束,解析的内容是id -->
<update id="deleteByList" parameterClass="java.util.List">
DELETE FROM A_USER WHERE ID IN
<iterate conjunction="," open="(" close=")">
#id[]#
</iterate>
</update>

4.在Manager类中添加删除用户信息的方法

/**
* 删除用户信息,字符串拼接,容易产生sql注入
* @param userId
* @throws SQLException
*/
public static void deleteUserByID(String userId) throws SQLException{
sqlMaper.update("deleteByString", userId);
} /**
* 删除用户信息,传参
* @param userList
* @throws SQLException
*/
public static void deleteUserByList(List userList) throws SQLException{
sqlMaper.update("deleteByList", userList);
}

5.编写测试类,测试删除用户信息是否成功

/**
* 删除用户信息,拼接字符串
*/
public void testDeleteUserById(){
try{
String idString="'1','2'"; Manager.deleteUserByID(idString); }catch(Exception e){
e.printStackTrace();
} } /**
* 删除用户信息,传参
*/
public void testDeleteUserByList(){ try{
List userList=new ArrayList();
userList.add("1");
userList.add("2");
Manager.deleteUserByList(userList); }catch(Exception e){
e.printStackTrace();
} }

通过JUnit测试,可看到用户信息成功删除!

iBatis的基本操作就简单介绍到这里吧!

Batis-iBatis基本操作(增删改查)的更多相关文章

  1. MongoDB的ObjectId和基本操作增删改查(3)

    ObjectId 基本操作增删改查 增: insert 介绍: mongodb存储的是文档,. 文档是json格式的对象. 语法: db.collectionName.insert(document) ...

  2. MongoDB --- 02. 基本操作,增删改查,数据类型,比较符,高级用法,pymongo

    一.基本操作 . mongod 启动服务端 2. mongo 启动客户端 3. show databses 查看本地磁盘的数据库 4. use 库名 切换到要使用的数据库 5. db 查看当前使用的数 ...

  3. web sql 基本操作 - 增删改查

    不喜欢看md原文的 可以访问这个链接:http://note.youdao.com/noteshare?id=6a91e3dea7cdf5195bb0e851d9fcb5a5 # web sql 增删 ...

  4. MongoDB基本操作(增删改查)

    基本操作      基本的“增删查改“,在DOS环境下输入mongo命令打开shell,其实这个shell就是mongodb的客户端,同时也是一个js的编译器,默认连接的是“test”数据库.  

  5. django数据库基本操作-增删改查(tip)-基本

    补充:django外键保存 #外键保存 form_data = Form_Data() project, is_created = Project_Name.objects.get_or_create ...

  6. MySQL语句基本操作增删改查

    select * from 表名; --------->效率低

  7. c语言实现双链表的基本操作—增删改查

    //初始化 Node*InitList() { Node*head=(Node*)malloc(sizeof(Node)); if(NULL==head) { printf("内存分配失败! ...

  8. ORM之单表增删改查

    ORM之单表增删改查 在函数前,先导入要操作的数据库表模块,model from model所在的路径文件夹 import model   在views文件中,加的路径: #就一个app01功能的文件 ...

  9. day94:flask:Jinjia2模板引擎&flask中的CSRF攻击&Flask-SQLAlchemy的创建模型类和基本的增删改查

    目录 1.Jinjia2模板引擎 1.Jinjia2加载模板并传递数据到模板中 2.Jinjia2的模板语句 3.模板中特有的变量和函数 4.模板中内置的过滤器 5.自定义过滤器 6.模板继承 2.在 ...

随机推荐

  1. 如何修复VUM在客户端启用之后报数据库连接失败的问题

    在上一篇随笔中介绍了关于重新注册VMware Update Manager(VUM)至vCenter Server中的方法,最近有朋友反应,原本切换过去好好的更新服务为什么某次使用一下就不灵了? 当时 ...

  2. Elasticsearch的CRUD:REST与Java API

    CRUD(Create, Retrieve, Update, Delete)是数据库系统的四种基本操作,分别表示创建.查询.更改.删除,俗称"增删改查".Elasticsearch ...

  3. 浏览器加载和渲染HTML的过程(标准定义的过程以及现代浏览器的优化)

    先看一下标准定义的浏览器渲染过程(网上找的): 浏览器打开网页的过程 用户第一次访问网址,浏览器向服务器发出请求,服务器返回html文件: 浏览器开始载入html代码,发现 head 标签内有一个 l ...

  4. 学习之路~sqh

    推荐博客 Edison Chou: Vamei: 算法∙面试专题 - 简书: 设计模式 极速理解设计模式系列[目录索引]- Caleung: Net设计模式 - 灵动生活: 宅男程序员给老婆的计算机课 ...

  5. C#开发微信门户及应用(11)--微信菜单的多种表现方式介绍

    在前面一系列文章中,我们可以看到微信自定义菜单的重要性,可以说微信公众号账号中,菜单是用户的第一印象,我们要规划好这些菜单的内容,布局等信息.根据微信菜单的定义,我们可以看到,一般菜单主要分为两种,一 ...

  6. 深入Collection集合

    List集合 一.ArraryList: 最基本的集合不多做介绍 二.Vector Vector cn=new  Vector(); A:有特有功能 a:添加       public void ad ...

  7. 设置JDK环境变量(linux版)

     设置环境变量一.修改/etc/profile文件当本机仅仅作为开发使用时推荐使用这种方法,因为此种配置时所有用户的shell都有权使用这些环境变量,可能会给系统带来安全性问题.用文本编辑器打开/et ...

  8. php实现设计模式之代理模式

    <?php /* * 代理模式 * 为其他对象提供一种代理以控制对这个对象的访问. * 在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用 ...

  9. Java Business Process Management(业务流程管理) 初识环境搭建

    一.简介 (一)什么是jbpm JBPM,全称是Java Business Process Management(业务流程管理),它是覆盖了业务流程管理.工作流.服务协作等领域的一个开源的.灵活的.易 ...

  10. windows上如何搭建Git Server

    Git在版本控制方面,相比与SVN有更多的灵活性,对于开源的项目,我们可以托管到Github上面,非常方便,但是闭源的项目就会收取昂贵的费用.那么私有项目,如何用Git进行代码版本控制呢?我们可以自己 ...