Ibatis.Net 数据库操作(四)
一、查询select
还记得第一篇示例中的是如何读出数据库里的3条数据吗?
就是调用了一个QueryForList方法,从方法名就知道,查询返回列表。
1、QueryForList 返回List<T>强类型数据集合
来看看方法原型:
public IList<T> QueryForList<T>(string statementName, object parameterObject);
public IList QueryForList(string statementName, object parameterObject);
public void QueryForList<T>(string statementName, object parameterObject, IList<T> resultObject);
public void QueryForList(string statementName, object parameterObject, IList resultObject);
public IList<T> QueryForList<T>(string statementName, object parameterObject, int skipResults,int maxResults);
public IList QueryForList(string statementName, object parameterObject, int skipResults, int maxResults);
有原型可以看出,其实只是3个参数不同方法,只是分为泛型与非泛型两个版本而已。
这个主要说说,参数skipResults,表示从结果行掉过skipResults行后返回,maxResults表示返回的行数。这个在分页中应该会用到。
下面来看一个最简单的示例:
xml映射文件中
<statements>
<select id="SelectAllPerson" resultMap="Person"> <!--id在程序中会被SqlMapper实体类所调用,resultMap就是resultMap节点的id-->
select * from person
</select>
</statements>
程序中的代码:
IList<PersonModel> ListPerson = mapper.QueryForList<PersonModel>("SelectAllPerson", null);
返回就是IList<PersonModel>的集合实例了。这个不多说。
2、QueryForObject 返回一行数据对应程序的实体类实例
下面来看看方法原型:
public object QueryForObject(string statementName, object parameterObject);
public T QueryForObject<T>(string statementName, object parameterObject);
public T QueryForObject<T>(string statementName, object parameterObject, T instanceObject);
public object QueryForObject(string statementName, object parameterObject, object resultObject)
不多说,下面来看看实例:
xml映射文件:
<select id="SelectOnePerson" resultMap="Person">
select * from person where Id = #Id# <!--其中#Id就是存入的参数#-->
</select>
程序代码:
PersonModel p = mapper.QueryForObject<PersonModel>("SelectOnePerson", ); //1就是存入Sql语句的参数
返回就是一个PersonModel对象的实例了。
3、QueryWithRowDelegate 通过委托过滤返回的数据
下面来看看方法原型:
IList<T> QueryWithRowDelegate<T>(string statementName, object parameterObject, RowDelegate<T> rowDelegate);
IList QueryWithRowDelegate(string statementName, object parameterObject, RowDelegate rowDelegate);
4、QueryForDictionary
5、QueryForMap
以上两个都不懂,看以后有没有用到,再算吧。
二、Insert
insert插入数据的方式比较简单,就只得一个方法Insert方法:
<insert id="InsertOne" resultMap="Person">
insert into Person (Name)
values(#Name#)
<selectKey type="post" resultClass="int" property="Id">
SELECT CAST(@@IDENTITY as int) as Id
</selectKey>
</insert>
因此此处Id设为了自增,所以SQL语句里面并不需要再设置Id
程序代码如下:
PersonModel p = new PersonModel();
p.Name = "曹操";
return (int)mapper.Insert("InsertOne",p);
三、Update
Update方法同样简单,也只是条用一下Update方法。
映射文件:
<update id="UpdateOne" resultMap="Person">
Update Person Set Name = #Name# Where Id = #Id#
</update>
程序代码如下:
PersonModel p = new PersonModel();
p.Id = ;
p.Name = "张三";
return (int)mapper.Update("UpdateOne", p);
四、Delete
删除方法与上面一样,我都感觉自己都有点啰嗦了。
映射文件:
<delete id="DeleteOne" resultMap="Person">
Delete Person Where Id = #Id#
</delete>
程序代码:
PersonModel p = new PersonModel();
p.Id = ;
p.Name = "张三";
return (int)mapper.Delete("DeleteOne", p);
//return (int)mapper.Delete("DeleteOne", 5); //另外这样也可以
Ibatis.Net 数据库操作(四)的更多相关文章
- Ibatis.Net 数据库操作学习(四)
一.查询select 还记得第一篇示例中是如何读出数据库里3条数据的吗?就是调用了一个QueryForList方法,从方法名就知道,查询返回列表. 1.QueryForList 返回List< ...
- 【转】Mybatis/Ibatis,数据库操作的返回值
该问题,我百度了下,根本没发现什么有价值的文章:还是看源代码(详见最后附录)中的注释,最有效了!insert,返回值是:新插入行的主键(primary key):需要包含<selectKey&g ...
- 【转】 Mybatis/Ibatis,数据库操作的返回值
该问题,我百度了下,根本没发现什么有价值的文章:还是看源代码(详见最后附录)中的注释,最有效了!insert,返回值是:新插入行的主键(primary key):需要包含<selectKey&g ...
- ThinkPHP 数据库操作(四) : 聚合查询、时间查询、高级查询
聚合查询 在应用中我们经常会用到一些统计数据,例如当前所有(或者满足某些条件)的用户数.所有用户的最大积分.用户的平均成绩等等,ThinkPHP为这些统计操作提供了一系列的内置方法,包括: 用法示例: ...
- Mybatis/Ibatis,数据库操作的返回值
该问题,我百度了下,根本没发现什么有价值的文章:还是看源代码(详见最后附录)中的注释,最有效了!insert,返回值是:新插入行的主键(primary key):需要包含<selectKey&g ...
- mysql在cmd命令下执行数据库操作
windows+r 运行cmd命令,执行以下操作! 当mysql 数据库文件相对于来说比较大的时候,这个时候你可能在正常环境下的mysql中是导入不进去的,因为mysql数据库本身就有默认的导入文件大 ...
- Python/MySQL(四、MySQL数据库操作)
Python/MySQL(四.MySQL数据库操作) 一.数据库条件语句: case when id>9 then ture else false 二.三元运算: if(isnull(xx)0, ...
- Java Spring Boot VS .NetCore (四)数据库操作 Spring Data JPA vs EFCore
Java Spring Boot VS .NetCore (一)来一个简单的 Hello World Java Spring Boot VS .NetCore (二)实现一个过滤器Filter Jav ...
- 数据库操作事物的四大特性以及MySQL数据库的四种隔离级别
1 .事物操作数据库的四大特性(ACID) 1.原子性 (Atomicity) 原子性:就是事物的所包含的所有操作,要么全部成功,要么全部失败回滚. 2.一致性 (Consistency) 一致性:简 ...
随机推荐
- Linux命令之乐--awk
1.脚本参数传值 #/bin/bash awk '"} {if(($1==a)) print $2;}' /etc/hosts 执行结果:
- C#_Winfrom下的中英文翻译
Winform下的语言国际化,几行代码轻松实现 最近做了一些关于winform的项目,需要用到winform的语言国际化,在初使化的时候用起来非常方便.可以参考一下: 核心逻辑: 预览效果演示: ...
- Linux定时任务Crontab详解_定时备份
文章来源:http://blog.chinaunix.net/uid-7552018-id-182133.html 今天做了个数据库的备份脚本,顺便系统得学习一下Linux下定时执行脚本的设置.Lin ...
- 静态库冲突的解决办法:duplicate symbol
昨天在做微信sdk和xmpp的集成,发现各自单独集成没问题,一起集成却总报错,百度了好一会儿才知道,这应该是库冲突造成的问题 然后参考了很多文章,跟着敲敲一遍,却发现问题多多,最后主要综合结合了这两个 ...
- hook_schema 小总结
1, primary key 可以带空格 做为下表 但field就不行 2, dev_node 仅为下标 'primary key' => array('nid'), 'foreign k ...
- java 基础(第一天)
1. 一个文件里面只能有一个 public 修饰的方法 且方法名与文件名保持一致. 如: public class main(){ } class car(){ } class dog(){ } ...
- iOS 静态类库 打包 C,C++文件及和OC混编
iOS 静态类库 编译 C,C++ 我们都知道,OC 原生支持C, 在 创建的 OC类的 .m 里面,可以直接编写C的代码: 同样 Xcode 也支持 OC ,C++的混编,此时,我们通常把OC创建的 ...
- 美国半个互联网瘫痪对开发者使用DNS的启发
版权声明:本文由腾讯云DNSPod团队原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/174 来源:腾云阁 https:// ...
- java 多线程5(创建方式)
实现Runnable接口: 问题1:Runnable实现类的对象是线程对象吗? 答:不是,该对象只不过是实现了Runnable接口的对象而已,只有是Thread或Thread的子类才是线程对象. 问题 ...
- 【bzoj1053】反素数
[bzoj1053]反素数 题意 对于任何正整数x,其约数的个数记作g(x).例如g(1)=1.g(6)=4.如果某个正整数x满足:g(x)>g(i) 0<i<x,则称x为反质数.例 ...