v1.0发布后,承蒙各位博友们的热心关注,也给我不少意见和建议,在此我真诚的感谢 @冰麟轻武 等朋友,你们的支持和鼓励,是这个开源项目最大的推动力。

v2.0在除了细枝末节外,在功能上主要做了一下更新:

1、实体类不再需要自己跟踪属性值变化:

    [Serializable]
public class Person
{
[PrimaryKey, AutoIncrease]
public virtual int Id { get; set; } public virtual string Name { get; set; } public virtual int? Age { get; set; } public virtual decimal? Money { get; set; } public virtual DateTime CreateTime { get; set; } public virtual bool IsActive { get; set; }
}

属性需要限定为 virtual ,以便生成代理。

如何新增数据:

[Test()]
public void Insert()
{
// 新增时,对象务必使用 EntityProxyGenerator 创建实体代理,否则无法跟踪属性变化
var person = EntityProxyGenerator.CreateProxy<Person>(); person.Name = "test";
//person.Age = 20;
person.Money = ;
person.CreateTime = DateTime.Now;
person.IsActive = false; using (ISession session = SessionFactory.CreateDefaultSession())
{
int i = session.Insert(person); // 输出生成的SQL语句
Console.WriteLine(SqlCmd.Current.Sql); int id = session.GetIndentifer<int>(); Assert.AreEqual(, i);
Assert.Greater(id, );
}
}

如何更新数据:

[Test()]
public void Update()
{
var person = EntityProxyGenerator.CreateProxy<Person>(); person.Name = "test";
person.Age = ;
person.Money = ;
person.CreateTime = DateTime.Now;
person.IsActive = true; using (ISession session = SessionFactory.CreateDefaultSession())
{
int i = session.Insert(person); int id = session.GetIndentifer<int>(); // Find 方法返回的对象都是原始对象而非代理对象
person = session.Find<Person>().Where(s => s.Id == id).Single(); Console.WriteLine(SqlCmd.Current.Sql); // 根据原始对象创建代理对象
person = person.ToEntityProxy<Person>(); person.Name = "test01";
person.Age = ;
person.Money = ;
i = session.Update(person); Console.WriteLine(SqlCmd.Current.Sql); person = session.Find<Person>().Where(s => s.Id == id).Single(); Console.WriteLine(SqlCmd.Current.Sql); Assert.AreEqual(, i);
Assert.AreEqual("test01", person.Name);
Assert.AreEqual(, person.Age.Value);
Assert.AreEqual(, person.Money.Value); person = EntityProxyGenerator.CreateProxy<Person>(); person.Name = "test";
person.Age = ;
person.Money = ;
person.CreateTime = DateTime.Now;
person.IsActive = true; i = session.Update<Person>().Set(person).Where(s => s.Id == id).Execute(); Console.WriteLine(SqlCmd.Current.Sql); Assert.AreEqual(, i);
Assert.AreEqual("test", person.Name);
Assert.AreEqual(, person.Age.Value);
Assert.AreEqual(, person.Money.Value);
Assert.AreEqual(true, person.IsActive);
}
}

2、SQL语句中的参数:

你可以这样写:

using (ISession session = SessionFactory.CreateDefaultSession())
{
string sql = "select count(*) from Person where Id = ? and CreateTime < ?"; int count = session.ExecuteScalar<int>(sql, , DateTime.Now); Assert.AreEqual(, count);
}

在任何数据库环境下,所有参数均使用问号替代参数名,但需保证问号的数量与传入的参数值数量一致,并顺序一致。

如何需要进行条件拼接,可以这样写:

StringBuilder builder = new StringBuilder();

                builder.Append("select * from Person where ");

                IList<object> parameters = new List<object>();

                if (model.Id != )
{
builder.Append("Id = ?, ");
parameters.Add(model.Id);
} if (string.IsNullOrEmpty(model.Name) == false)
{
builder.Append("Name = ?, ");
parameters.Add(model.Name);
} return session.ExecuteDataTable(builder.ToString(), parameters);

OK,就介绍这两点,其他功能请自己摸索。

后期将陆续发布oracle与sqlserver的provider,功能上将不再做大的更新和变动。

如有不明白的,请参见我的上两篇帖子。

我马上也要专心去找工作养家糊口了,在家呆了快一个月了,各位博友有好的工作机会帮忙推荐一下。

Restful.Data v2.0发布,谢谢你们的支持和鼓励的更多相关文章

  1. Restful.Data v1.0 - 轻量级数据持久层组件, 正式开源发布了

    经过几个星期的优化调整,今天 Restful.Data 正式开源发布. 源码地址:https://github.com/linli8/Restful 今天不写那么多废话了,还是重新介绍一下 Restf ...

  2. iBox v2.0 发布,Web化仿iOS7界面/交互的JavaScirpt库

    iBox2 是一个仿 iOS 7 界面/交互的 JavaScirpt 库,它运行在 webkit 内核的移动浏览器之上,依赖 iScroll5,帮助开发者构建更接近 iOS 体验的 WebApp. 伴 ...

  3. Pyston v2.0 发布,解决 Python 慢速的救星

    Pyston 自从 2017 年发布 0.6.1 版本后,已经淡出了人们的视线三年多了,导致现在新人都很少听过它的大名. 前两天(2020年10月28日)Pyston 在官方博客上(https://b ...

  4. CoreWCF 1.0.0 发布,微软正式支持WCF

    2022年4月28日,我们达到了一个重要的里程碑,并发布了CoreWCF的1.0.0版本.对Matt Connew (微软WCF团队成员)来说,这是5年前即 2017年1月开始的漫长旅程的结束.Mat ...

  5. CodeManage 源代码管理器v2.0发布

    下载地址 欢迎大家提出宝贵的意见和bug

  6. kkfileview v2.0 发布,文件在线预览项目方案

    kkfileview文件在线预览 此项目为文件文档在线预览项目解决方案,项目使用流行的spring boot搭建,易上手和部署,部署好后可以独立提供预览服务,使用http接口访问,不需要和应用集成,具 ...

  7. 重大更新!Druid 0.18.0 发布—Join登场,支持Java11

    Apache Druid本质就是一个分布式支持实时数据分析的数据存储系统. 能够快速的实现查询与数据分析,高可用,高扩展能力. 距离上一次更新刚过了二十多天,距离0.17版本刚过了三个多月,Druid ...

  8. 【Beta】“北航社团帮”发布声明——小程序v2.0与网页端v1.0

    目录 Beta版本新功能 小程序v2.0新功能 新功能列表 功能详情图 新功能动图展示 网页端v1.0功能 登录方式 社团信息的修改 新闻的录入和修改 活动的录入和修改 这一版修复的缺陷 Beta版本 ...

  9. 魔方NewLife.Cube升级v2.0

    魔方是一套集成权限管理的MVC管理后台,最具特色功能是模版覆盖机制,是XCode实体类的最佳搭档! v2.0.2017.1126   借助Ajax支持高级操作,如:删除选中.批量启用禁用等 用户管理增 ...

随机推荐

  1. 空MVC项目找不到System.Web.Optimization的处理办法

    install-package Microsoft.AspNet.Web.Optimization Create the bundle in Global.asax Application_Start ...

  2. 實際案例: 已知要獲取臨時票証 (JsApi Ticket) 才能調用的接口

    需獲取票証才能調用的接口,簡單列示如下: 一.基礎類 1. wx.checkJsApi (當前客戶端是否支持指定JS) 二.分享類 1.wx.onMenuShareTimeline (分享到朋友圈)2 ...

  3. c# DESEncrypt 加密、解密算法

    using System; using System.Security.Cryptography; using System.Text; namespace AttendService { publi ...

  4. php count函数

    最近被问到一个函数count 1.count("123456") 对应的输出是什么? 2.count(null) 对应的输出是什么? 以前没有认真的考虑,只是心里有一个印象那就是c ...

  5. 未添加document.ready产生的BUG

    今天在框架里使用superslide插件时,在javascript部分 <script type="text/javascript"> jQuery(".yj ...

  6. vim深入研究

    About VIM--Unix及类Unix系统文本编辑器 Vim是一个类似于Vi的著名的功能强大.高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特性.VIM是纯粹的自由软件. Vim普遍被推崇 ...

  7. 解析jquery获取父窗口的元素

    ("#父窗口元素ID",window.parent.document); 对应javascript版本为window.parent.document.getElementByIdx ...

  8. JS-offsetParent定位父节点

    offsetParent:离当前元素最激动呢一个有定位的父节点 如果没有定位父级,默认是body IE7以下如果当前元素没有定位默认是body,如果有定位就是html IE7以下,如果当前元素的某个父 ...

  9. Ubuntu 14.04安装mysql

    在ubuntu kylin上面安装mysq的过程中遇到一些问题,记录如下, wget http://cdn.mysql.com//Downloads/MySQL-5.7/mysql-server_5. ...

  10. oracle官方文档的阅读方法

    Concept 包含了 oracle 数据库里面的一些基本概念和原理, 比如 数据库逻辑结构, 物理结构, 实例结构, 优化器, 事务等. PDF 460页 Reference 包含了动态性能视图, ...