SqlMapCient 类提供了执行所有 mapped statement 的 API。这些方法如下:

 public int insert(String statementName, Object parameterObject)
throws SQLException public int update(String statementName, Object parameterObject)
throws SQLException public int delete(String statementName, Object parameterObject)
throws SQLException public Object queryForObject(String statementName, Object parameterObject)
throws SQLException public Object queryForObject(String statementName, Object parameterObject, Object resultObject) throws SQLException public List queryForList(String statementName, Object parameterObject)
throws SQLException public List queryForList(String statementName, Object parameterObject, int skipResults, int maxResults)
throws SQLException public List queryForList (String statementName, Object parameterObject, RowHandler rowHandler) throws SQLException public PaginatedList queryForPaginatedList(String statementName, Object parameterObject, int pageSize)
throws SQLException public Map queryForMap (String statementName, Object parameterObject, String keyProperty)
throws SQLException public Map queryForMap (String statementName, Object parameterObject, String keyProperty, String valueProperty)
throws SQLException

在上面的每个方法中,Mapped  Statement  的名称作为第一个参数。这个名称要对应<statement>的名称属性。另外,第二个参数总是参数对象。如果不需要参数对象,可以为

null。除了这些之外,上面的方法就没有相同的了。下面简单地介绍一下它们的不同之处。

* insert( ),update( ),delete( )

这些方法用于数据更新(即非查询语句)。这就是说,使用下面的查询方法来执行数据更新操作并不是不可能。但这显得很奇怪,并明显依赖于 JDBC 的驱动程序。执行 update(), 返回受影响数据记录的数目。

* queryForObject( )

queryForObject()方法有两个版本。一个返回查询得到的新对象,另一个用一个事先生成 的对象作为参数。后者对于使用多个查询为对象赋值很有用。

* queryForList( )

queryForList()方法也有三个版本。第一个执行一个查询并返回所有的查询结果。第二个 允许指定跳过结果的数目(即开始点)和返回结果的最大数目。对于查询一个数量很大的结 果集,并且不想返回所有的数据时很有用。最后一个版本的 queryForList()方法需要一个行处理器(row handler)作为输入参数。这 个方法可以让您使用结果对象,而不是数据表的行和列来逐行地处理查询结果集。这个方法 的参数除了例行的名称和参数对象外,还包括了一个实现了 RowHandler 接口的类的实例。 RowHandler 接口只有一个方法:

public void handleRow (Object object, List list);对于每一行从数据库中返回的数据,RowHandler 接口的方法都会被执行。这种处理数 据的方法,简洁而具有扩展性。

* queryForPaginatedList( )

对于要返回一个可以向前和向后翻页的数据子集,queryForPaginatedList()方法很有用, 它返回一个可管理的 List  对象。通常用于只显示一部分查询结果的用户界面。一个常见的 例子是,搜索引擎找到了 10000 条结果,但每次只显示其中的 100 条。PaginatedList 接口包 含了向前和向后翻页的方法(nextPage(),previousPage(),gotoPage()),并提供了检查翻页 状态的方 法( isFirstPage() , isMiddlePage() , isLastPage() , isPreviousPageAvailable() , getPageIndex(),getPageSize())。虽然不能从 PaginatedList 接口得到查询结果集的总数,但 这个总数可以再执行一个简单的语句 count()来得到。否则,PaginatedList 接口会大大的降低 性能。

* queryForMap( )

queryForMap()方法将结果集放在一个Map 对象中,这个 Map 对象用一个传入参数 keyProperty 作为 key 值。例如,要读入一批 Employee 对象,您可以将这些 Employee 对象放在一个用 employeeNumber 属性作为 key 值 的 Map 对象中。Map 对象的值可以是整个 Employee 对象,也可以是 Employee 对象的另一 个属性,属性的名称由第二个参数 valueProperty 指定。例如,您可能只是需要一个 Map 对 象,用员工号作为 key 值,员工姓名作为 value 值。不要把它和用 Map 作为结果对象的概念 混淆。这个方法可以使用 Java Bean 和 Map(或基本类型的包装类,但不可能这样用)作为 结果对象。

代码实例:

例子1:执行update(insert,update,delete)

 sqlMap.startTransaction();
Product product = new Product(); product.setId (1); product.setDescription (“Shih Tzu”);
int rows = sqlMap.insert (“insertProduct”, product);
sqlMap.commitTransaction();

例子2:查询成对象(select)

 sqlMap.startTransaction();
Integer key = new Integer (1);
Product product = (Product)sqlMap.queryForObject (“getProduct”, key); sqlMap.commitTransaction();

例子3:用预赋值的结果对象查询成对象(select)

 sqlMap.startTransaction();
Customer customer = new Customer(); sqlMap.queryForObject(“getCust”, parameterObject, customer);
sqlMap.queryForObject(“getAddr”, parameterObject, customer); sqlMap.commitTransaction();

例子4:查询成对象List(select)

 sqlMap.startTransaction();
List list = sqlMap.queryForList (“getProductList”, null);
sqlMap.commitTransaction();

例子5:用结果集边界查询成对象List(select)

 sqlMap.startTransaction();
List list = sqlMap.queryForList (“getProductList”, null, 0, 40); sqlMap.commitTransaction();

例子6:用RowHandler执行查询(select)

 public class MyRowHandler implements RowHandler {
public void handleRow (Object object, List list) throws SQLException { Product product = (Product) object;
product.setQuantity (10000);
sqlMap.update (“updateProduct”, product);
// Optionally you could add the result object to the list.
// The list is returned from the queryForList() method.
}
}
sqlMap.startTransaction();
RowHandler rowHandler = new MyRowHandler();
List list = sqlMap.queryForList (“getProductList”, null, rowHandler);
sqlMap.commitTransaction();

例子7:查询成Paginated List(select)

 PaginatedList list =
sqlMap.queryForPaginatedList (“getProductList”, null, 10);
list.nextPage(); list.previousPage();

例子9:查询成Map(select)

 sqlMap.startTransaction();
Map map = sqlMap.queryForMap (“getProductList”, null, “productCode”);
sqlMap.commitTransaction();
Product p = (Product) map.get(“EST-93”);

注意:自动提交,当没调用 startTransaction 的情况下,statements 会自动提交。没必要 commit/rollback。

Ibatis学习总结7--SqlMapClient 执行 SQL 语句的更多相关文章

  1. power desinger 学习笔记三<批量执行sql语句>

    使用sql脚本导入表结构,直接 附带表的 约束.列的注释.真的可以哦 sql语句如下: create table test01 (   ID                   VARCHAR2(10 ...

  2. QtSQL学习笔记(3)- 执行SQL语句

    QSqlQuery类提供了一个用于执行SQL语句和浏览查询的结果集的接口. QSqlQueryModel和QSqlTableModel类提供了一个用于访问数据库的高级接口,这将在下一节介绍.如果你不熟 ...

  3. 10.1(java学习笔记)JDBC基本操作(连接,执行SQL语句,获取结果集)

    一.JDBC JDBC的全称是java database connection java数据库连接. 在java中需要对数据库进行一系列的操作,这时就需要使用JDBC. sun公司制定了关于数据库操作 ...

  4. MyBatis学习 之 三、动态SQL语句

    目录(?)[-] 三动态SQL语句 selectKey 标签 if标签 if where 的条件判断 if set 的更新语句 if trim代替whereset标签 trim代替set choose ...

  5. 在mybatis执行SQL语句之前进行拦击处理

    转载自:http://blog.csdn.net/hfmbook/article/details/41985853 比较适用于在分页时候进行拦截.对分页的SQL语句通过封装处理,处理成不同的分页sql ...

  6. SQL*PLUS中批量执行SQL语句

    SQL*PLUS中批量执行SQL语句 今天由于工作的需要,要在CMD中批量执行大量的SQL语句,对于Oracle学习还处在入门阶段的我,只能硬着头皮到处去寻找资料(主要是网络资料,也包括自己的电子书) ...

  7. MVC EF 执行SQL语句(转载)

    MVC EF 执行SQL语句 最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 闲着没事,看了一篇关于LI ...

  8. easyui datagrid 禁止选中行 EF的增删改查(转载) C# 获取用户IP地址(转载) MVC EF 执行SQL语句(转载) 在EF中执行SQL语句(转载) EF中使用SQL语句或存储过程 .net MVC使用Session验证用户登录 PowerDesigner 参照完整性约束(转载)

    easyui datagrid 禁止选中行   没有找到可以直接禁止的属性,但是找到两个间接禁止的方式. 方式一: //onClickRow: function (rowIndex, rowData) ...

  9. 个人永久性免费-Excel催化剂功能第21波-Excel与Sqlserver零门槛交互-执行SQL语句篇

    在前两波中,已完成了Excel与Sqlserver的查询和上传功能,但难免许多临时的或更深入地操作数据库需要用Sql语句来操作,对一般用户电脑里,不可能有条件轻易安装一个数据库客户端软件,就算安装了对 ...

  10. 4.5 .net core下直接执行SQL语句并生成DataTable

    .net core可以执行SQL语句,但是只能生成强类型的返回结果.例如var blogs = context.Blogs.FromSql("SELECT * FROM dbo.Blogs& ...

随机推荐

  1. OO的设计原则

    今天同事和我们一起讨论分享了OO的设计原则,讨论使人明晰,有人一起讨论学习是一件幸福的事情. 1.开闭原则 对功能的扩展是开放的,对修改是闭合的. 可以应用于类的设计,框架的设计等. 为什么?开闭原则 ...

  2. 使用flume的一个例子

    新项目中需要使用到hadoop和vertica,使用flume把数据加载到hadoop中,我做了一个例子, 即监控一个sharefolder,如果里面有文件,则会文件load到hadoop. 开启Fl ...

  3. OpenStack neutron删除网络设备出错解决办法

    目标:要删除外网Ext-Net2 直接删网络也会出错:因为有一个或多个端口在使用该网络 root@controller:~# neutron net-list +------------------- ...

  4. linux sed命令

    一.初识sed 在部署openstack的过程中,会接触到大量的sed命令,比如 # Bind MySQL service to all network interfaces. sed -i 's/1 ...

  5. 二分+DP HDU 3433 A Task Process

    HDU 3433 A Task Process Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/ ...

  6. 边工作边刷题:70天一遍leetcode: day 89-1

    Smallest Rectangle Enclosing Black Pixels 要点:记题:这题有两个限制条件:所有black pixel是连通的(所以可以用binary search)以及给了一 ...

  7. [转载]ExtJs4 笔记(10) Ext.tab.Panel 选项卡

    作者:李盼(Lipan)出处:[Lipan] (http://www.cnblogs.com/lipan/)版权声明:本文的版权归作者与博客园共有.转载时须注明本文的详细链接,否则作者将保留追究其法律 ...

  8. 安全框架 - Shiro与springMVC整合的注解以及JSP标签

    Shiro想必大家都知道了,之前的文章我也有提过,是目前使用率要比spring security都要多的一个权限框架,本身spring自己都在用shiro,之前的文章有兴趣可以去扒一下 最近正好用到s ...

  9. Cg关键字(keywords)

    保留标识符 除了下面列出的,任何以两个的下划线作为前缀(例如,__ newType)的标识符被保留. 注意,矩阵(matrix)和向量类型(vector types)(如half2x3或float4) ...

  10. [C#] 委托之Action和Func区别

    一.说明 一般我们定义委托都是有如下两步: public delegate void MyDelegate(string name);//定义委托 public MyDelegate myDelega ...