【ASP.NET程序员福利】打造一款人见人爱的ORM(二)
上一篇我已经给大家介绍AntORM的框架【ASP.NET程序员福利】打造一款人见人爱的ORM(一),今天就来着重介绍一下如何使用这套框架
1>AntORM 所有成员
如果你只想操作一种数据库,可以针对不同数据库选择独立的dll
Asp.net 4.+ |
说明 |
依赖 |
Ant.ORM.dll |
负责实体和数据库之间解析 |
Ant.Data.dll |
Ant.Data.dll |
数据库访问层 |
MySql.Data.dll System.Data.SQLite.dll Oracle.ManagedDataAccess.dll SQLite.Interop.dll |
Ant.Common.dll |
公共组件 |
无 |
2>数据库连接
1.普通模式
这种模式简单粗爆,适合一个产品支持多种数据库,但是中间没有两种数据库同时操作。
在用数据库连接的时候这两个名称要一样才能读取数据库配置信息
2.灵活模式
适合多种数据库混用项目
从上面图中可以看出,可以支持读写库进行配置分离。
3.数据库配置
<AppSettings>
<DatabaseName>antormsqlite</DatabaseName>
<DatabaseType>mssql</DatabaseType>
<!--oledb:Access数据库;mssql:SQL数据库;oracle:oracle数据库;SQLite:SQLite小型数据库-->
<IsConStringEncrypt>true</IsConStringEncrypt>
<DatabaseKey>A949564832391559D9994800BB8F283D8FB44CCE5FAA0246574C4A247C39F2B2DA3425F0B23582C13BC5FDAD2AED1A33</DatabaseKey>
<ReadData>user id=sa;password=a1b2c3d4@admin;DataBase=OOExceptionHandle;server=1.41.107.147;</ReadData>
<!--1.41.107.147-->
<WriteData>user id=sa;password=a1b2c3d4@admin;DataBase=OOExceptionHandle;server=1.41.107.147;</WriteData>
</AppSettings>
3>增删查改多表操作以及事务
项目中用到的实体:
1 public enum Gender
2 {
3 Man = 1,
4 Woman
5 }
6
7 [Table("Users")]
8 public class User : BaseEntityObj
9 {
10 public User()
11 {
12
13 }
14
15 [Column("id", IsPrimaryKey = true), AutoIncrement]
16 public int? Id { get; set; }
17
18 private string name;
19 public string Name
20 {
21 get { return name; }
22 set { name = value; }
23 }
24 public Gender? Gender { get; set; }
25 private int? age;
26 public int? Age
27 {
28 get { return age; }
29 set { age = value; }
30 }
31 public int? CityId { get; set; }
32 public DateTime? OpTime { get; set; }
33
34 }
1.AntORM实现查询
查询单一实体方法一
using (AntORM orm = new AntORM())
{ orm.db = DataAccessFactory.CreateDataConnection("antormsqlite");//SQLite
orm.ModuleName = "antormsqlite";//SQLite
var q = orm.Queryable<User>();
RequestModel rest = new RequestModel();
rest.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查询用户信息单个实体方法" };
var mod = q.Where(a => a.Id == ).FirstOrDefault();
if (mod.IsSuccess)
{
User user = mod.ResultModel;
}
}
查询单一实体方法二
using (AntORM orm = new AntORM())
{
var request = new RequestModel();
request.db = DataAccessFactory.CreateDataConnection("antormsqlite");
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查询菜单的单个实体方法" };
User query = new User();
query.Id = ;
var reslut = orm.GetEntity(query, request);
if (reslut.IsSuccess)
{
User user = reslut.ResultModel;
}
}
如果只能通主键去查询,还可以这样写
using (AntORM orm = new AntORM())
{
var request = new RequestModel();
request.db = DataAccessFactory.CreateDataConnection("antormsqlite");
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查询菜单的单个实体方法" };
request.Oid = "";
var res = orm.GetEntity<User>(request);
if (res.IsSuccess)
{
User user = res.ResultModel;
}
}
查询带分页方法一
using (AntORM orm = new AntORM())
{
RequestModel request = new RequestModel();
request.db = DataAccessFactory.GetWriteDataDefault;
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查询菜单的单个实体方法" };
var q = orm.Queryable<User>();
//分页
var relust = q.Where(a => a.Id > ).OrderBy(a => a.Age).ThenByDesc(a => a.Id).Top().Skip().ToList(request);
if(relust.IsSuccess)
{
var userlist = relust.ResultModel;
}
}
查询带分页方法二
using (AntORM orm = new AntORM())
{
RequestModel request = new RequestModel();
request.ModuleName = "antormsqlite";
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查询菜单的单个实体方法" };
User query = new User();
query.CityId = ;
var reslut = orm.GetPageList(query, request);
if (reslut.IsSuccess)
{
var userlist = reslut.ResultModel;
}
}
多表查询的方法
using (AntORM orm = new AntORM())
{
orm.db = DataAccessFactory.GetWriteDataDefault;
var users = orm.Queryable<User>();
var cities = orm.Queryable<City>();
var provinces = orm.Queryable<Province>();
//建立连接
var user_city = users.InnerJoin(cities, (user, city) => user.CityId == city.Id && user.Id > );
var user_city_province = user_city.InnerJoin(provinces, (user, city, province) => (city.ProvinceId == province.Id)); RequestModel request = new RequestModel();
request.db = DataAccessFactory.GetWriteDataDefault;
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查出一个用户及其隶属的城市和省份的所有信息三张表数据都返回出来" };
var reslut = user_city_province.Select((user, city, province) => new { Users = user, Citys = city, Provinces = province })
.Where(a => a.Users.Id == && a.Citys.Name == "").OrderByDesc(p => p.Users.Id).ToList(request);
if(reslut.IsSuccess)
{
var userlist = reslut.ResultModel;
}
}
实现查询带In操作
using (AntORM orm = new AntORM())
{
orm.db = DataAccessFactory.CreateDataConnection("antormsqlite");
RequestModel request = new RequestModel();
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "查询用户名称带这几个人实现In操作的方法" };
string[] Names = { "lu", "jjg1", "jjg3" };
var reslut = orm.Queryable<User>().Where(p => Names.Contains(p.Name)).Select(p => new { p.Name, p.CityId }).ToList();
if (reslut.IsSuccess)
{
var mod = reslut.ResultModel;
}
}
通过orm拼接条件来查询
using (AntORM orm = new AntORM())
{
var request = new RequestModel();
request.db = DataAccessFactory.GetWriteDataDefault;
request.newSt = new SqlNote() { Author = "季健国", NewSt = new System.Diagnostics.StackTrace(true), SqlDesc = "通过拼接条件来查询的方法" };
User m = new User();
m.Age = ;
IList<IPredicate> predList = new List<IPredicate>();
var query1 = Predicates.QueryField<User>(p => p.CityId, Operator.Equal, "");
predList.Add(query1);
var query2 = Predicates.QueryField<User>(p => p.CityId, Operator.Equal, "");
predList.Add(query2);
IPredicateGroup query = Predicates.SqlGroup(GroupOperator.And, predList.ToArray());
request.Predicate =query;
var reslut = orm.GetDr2EnList(m, request);
if (reslut.IsSuccess)
{
var modlist = reslut.ResultModel;
}
}
通过自定义SQL查询操作
/// <summary>
/// 自定义SQL操作
/// </summary>
/// <param name="request"></param>
/// <returns></returns>
public static ResponseModel AntOrmItemSQL(RequestModel request)
{
ResponseModel reslut = new ResponseModel();
using (AntORM orm = new AntORM())
{
int id = ;
orm.ModuleName = "antormsqlite";
var list = orm.SqlQuery<User>(string.Format("select top {0} * from Users where Id>@Id", ), new { Id = id }).Select(p => new { p.Name }).ToList();
if (list.IfNotNull() || list.Count > )
{
reslut.ResultModel = list;
reslut.IsSuccess = true;
}
return reslut;
}
}
实现分组查询
/// <summary>
/// 分组查询
/// </summary>
/// <param name="request"></param>
/// <returns></returns>
public static ResponseModel GroupQuery(RequestModel request)
{
using (AntORM orm = new AntORM())
{
var q = orm.Queryable<User>(); IGroupingQuery<User> g = q.Where(a => a.Id > ).GroupBy(a => a.Age); g = g.Having(a => a.Age > && AggregateFunctions.Count() > ); var res = g.Select(a => new
{
a.Age,
Count = AggregateFunctions.Count(),
Sum = AggregateFunctions.Sum(a.Age),
Max = AggregateFunctions.Max(a.Age),
Min = AggregateFunctions.Min(a.Age),
Avg = AggregateFunctions.Average(a.Age)
}).ToList(request);
return res;
}
}
2.AntORM实现新增修改删除操作
/// <summary>
/// 实现保存操作
/// </summary>
public static ResponseModel UserSave(RequestModel request)
{
User mod = new User();
using (AntORM orm = new AntORM())
{ orm.db = DataAccessFactory.CreateDataConnection("antormsqlite");//SQLite var reslut = orm.Queryable<User>().Where(p => p.Id == ).FirstOrDefault();
if (reslut.IsSuccess)
{
mod = reslut.ResultModel;//实现的修改
}
else
{
mod = new User() { Name = "jjg4", Age = , Gender = Gender.Man, CityId = , OpTime = DateTime.Now };//实现的新增 }
//第一种保存
reslut = orm.SaveHaveNull(mod, request);//保存数据(新增和更新)数据库没有Null值
//return reslut; //第二种保存reslut
reslut = orm.Save(mod, request);//根据实体来进行插入数据库的表中带Null值
return reslut; }
}
/// <summary>
/// 批量更新操作
/// </summary>
public static ResponseModel Update(RequestModel request)
{
ResponseModel reslut = new ResponseModel();
orm.db = DataAccessFactory.CreateDataConnection("antormsqlite");//SQLite
using (AntORM orm = new AntORM())
{
#region 第一种更新方法
reslut = orm.UpdateByLambda<User>(a => new User() { Name = a.Name, Age = a.Age + 100, Gender = Gender.Man, OpTime = DateTime.Now }, a => a.Id == 1, request);
return reslut;
#endregion
#region 第二种更新方法
User user = new User();
user.Name = "ljjgu";
user.Age = 30;
user.Gender = Gender.Woman;
user.OpTime = DateTime.Now;
reslut = orm.UpdateById(user, request);//会更新所有映射的字段
if (reslut.IsSuccess)
{ //更新成功 }
#endregion
#region 第三种更新方法 /* * 支持只更新属性值已变的属性 */
user = new User();
user.Name = "ljjgu";
user.Age = 30;
user.Gender = Gender.Woman;
user.OpTime = DateTime.Now;
orm.TrackEntity(user);//这时只会更新被修改的字段 //在上下文中跟踪实体
user.Name = user.Name + "1";
reslut = orm.UpdateByLambda(user, a => a.Id == 2, request);
#endregion
#region 第四种更新方法批量更新 //批量更新 //给所有女性年轻 10 岁
reslut = orm.UpdateByLambda<User>(a => new User() { Age = a.Age - 10, OpTime = DateTime.Now }, a => a.Gender == Gender.Woman, request);
if (reslut.IsSuccess)
{ //更新成功 }
#endregion
}
}
}
}
/// <summary>
/// 删除操作
/// </summary>
public static ResponseModel Delete(RequestModel request)
{
using (AntORM orm = new AntORM())
{
#region 第一种删除方法 var reslut = orm.DeleteByLambda<User>(a => a.Id == 1, request); #endregion #region 第二种删除方法
//批量删除
//删除所有不男不女的用户
reslut= orm.DeleteByLambda<User>(a => a.Gender == null, request);
#endregion #region 第三种删除方法
User user = new User();
user.Id = 1;
reslut=orm.DeleteByModel(user, request); return reslut;
#endregion }
}
3.AntORM实现事务操作
/// <summary>
/// 实现事务要保证数据库连接db是同一个,不能重新创建新的数据库连接
/// </summary>
public static ResponseModel CommitTransaction(RequestModel request)
{
User mod = new User();
using (AntORM orm = new AntORM())
{ using (orm.db = DataAccessFactory.CreateDataConnection("antormsqlite"))//SQLite
{
orm.db.BeginTransaction();
try
{
User query = new User();
query.Id = ;
var reslut = orm.GetEntity(query, request);
if (reslut.IsSuccess)
{
mod = reslut.ResultModel;//实现的修改
reslut = orm.Save(mod, request);//保存数据(新增和更新)数据库没有Null值
reslut = orm.DeleteByModel(query, request); }
else
{
reslut.IsSuccess = false;
reslut.Message = "查询数据失败";
}
orm.db.Commit(); return reslut;
}
catch (Exception ex)
{
orm.db.RollBack();
ResponseModel reslut = new ResponseModel();
reslut.IsSuccess = false;
reslut.Message = "事务中执行报错" + ex.ToString();
return reslut;
} }
}
}
【ASP.NET程序员福利】打造一款人见人爱的ORM(二)的更多相关文章
- 【ASP.NET程序员福利】打造一款人见人爱的ORM(一)
“很多人都不太认可以第三方ORM,因为考虑的点不够全面,没有大用户群体的ORM有保证,这点是不可否认确是事实.但是往往用户群体大的ORM又有不足之处,今天我们就来聊聊关于ORM的话题,打造 ...
- 代码片段添加智能提示,打造一款人见人爱的ORM框架
SqlSugar ORM优点: 1.高性能,达到原生最高水准,比SqlHelper性能要高,比Dapper快30% 比EF快50% 2.支持多种数据库 ,sql版本更新最快,其它会定期更新,可以在多种 ...
- 深受C/C 程序员欢迎的11款IDE
几十年过去了,C和C++作为主要的高级的程序设计语言,在全球范围内仍然广受欢迎,并牢牢占据着TIOBE编程语言排行榜前5名,应用程序和系统的开发离不开这两门语言,现在我们来总结一下近些年来,深受C/C ...
- 优秀ASP.NET程序员修炼之路
初级的程序员或经验不足的程序员往往只意识到自己的程序是写给计算机的,而不会在意程序其实也是写给人的,或在意得不够.不全面. 写给机器的程序,往往追求的是运行正确.执行效率能满足要求.但程序员的任务仅仅 ...
- Java程序员必备的6款最佳开发工具
工欲善其事,必先利其器.每一个Java程序员都有其惯用的工具组件.对于Java程序员,各种有用的软件和工具泛滥成灾.初级开发人员要么找不到合适的工具,要么在寻找过程中浪费了大量的时间.下面,我将为大家 ...
- 程序员简单打造一个灵活智能的自动化运维系统C#实例程序
你是一个程序员,被派去管理公司500台计算机.这些机器可能需要执行一些自动化任务,一台台手动操作会把你累死.重复性的工作还是交给电脑处理,怎么解决这个问题呢?一个自动化的运维系统是必须的.自己实现的好 ...
- asp.net程序员初涉node.js
之前一直听说node.js在处理网站大规模并发上十分有用,所以有一定规模的公司都在使用node.我在工作中只用过jquery,属于那种边做功能边学习的那一种.甚至连原生的js都不太会写,只是知道语法差 ...
- PHP程序员福利“看免费直播,学MySQL索引优化”
六星教育了解到,MySQL是目前所知PHP最流行的关系型数据库管理系统之一,它将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性.之所以它会成为主流使用数据库,这 ...
- .net程序员转行做手游开发经历(二)
上篇主要介绍自己个人的经历,这篇主要讲下学习新语言的过程. 上次说到最终选择的语言是swift,框架用spritekit,上次有网友对为什么选择用这俩呢,为什么不用cocos和unity呢,cocos ...
随机推荐
- SEED信息安全实验系列:缓冲区溢出漏洞实验
缓冲区溢出漏洞实验 本课程详细出自http://www.shiyanlou.com/courses/231,转载请注明出处. 一.实验描述 缓冲区溢出是指程序试图向缓冲区写入超出预分配固定长度数据的情 ...
- C#中DateTime.Ticks属性及Unix时间戳转换
1.相关概念 DateTime.Ticks:表示0001 年 1 月 1 日午夜 12:00:00 以来所经历的 100 纳秒数,即Ticks的属性为100纳秒(1Ticks = 0.0001毫秒). ...
- Web系统性能测试术语简介
并发用户 并发一般分为两种情况.一种是严格意义上的并发,即所有的用户在同一时刻做同一件事情或者操作.这种操作一般指做同一类型的业务,比如在信用卡审批业务中,一定数目的用户在同一时刻对已经完成的审批业务 ...
- nginx 安全优化
http://nginx.org/en/docs/http/ngx_http_access_module.html 官网 1.允许特定的ip访问,拒绝特定ip server { listen 80; ...
- JS--实现简单轮播(一)
<!DOCTYPE html><html><head> <title></title> <meta charset=utf-8> ...
- idea fect
idea facet 昨天从svn检查一个项目后,部署至tomcat服务器,启动成功,但实际代码其实没有进去, 因为该项目不是maven项目, artifacats是自己配的, 应该是这里弄错的. 最 ...
- EL表达式
跳转传到: : 相当于(接值放值): --------------------------- --------------------------------- ------------------- ...
- Linux 进程与线程五
pthread_self函数 pthread_t pthread_self(void); 一般会成功,返回当前线程的ID 注意:在子线程中执行exit()函数会退出整个进程,一般使用pthread_e ...
- [LeetCode] Different Ways to Add Parentheses 添加括号的不同方式
Given a string of numbers and operators, return all possible results from computing all the differen ...
- QT基本操作
QApplication(argc,argv[]) AAA *XX=new AAA();AAA代表要创建的控件类型,XX表示该控件上的命名.