持久层框架Clone
Clone框架:http://www.52chloe.com/Wiki/Document/3324802610879266816
Clone框架支持多种数据库,我用的是sql server
基本查询:
1.取前几条数据
sql server的sql 语句是:
- UPDATE dbo.POM_Entry SET Status = 'Suspend' WHERE EntryCode IN
- (SELECT TOP EntryCode FROM dbo.POM_Entry WHERE OrderCode = 'POM20170401151750740865' AND status = 'Issued' ORDER BY OrderIndex desc);
用Clone框架:.TakePage(1,20)
- //将该订单下相应个数的状态为下发的工单的状态改为暂停
- public void SuspendAmount(string orderCode, int SuspendAmount)
- {
- //加事务
- this.DbContext.DoWithTransaction(() =>
- {
- //查询出该订单下状态为下发的工单,并按排序号倒叙排序,取出SuspendAmount个工单,将其状态设为暂停
- List<POM_Entry> Lq = this.DbContext.Query<POM_Entry>().FilterDeleted()
- .Where(a => a.OrderCode == orderCode && a.Status == "Issued")
- .OrderByDesc(a => a.OrderIndex).TakePage(, SuspendAmount).ToList();
- var entryAccount = Lq.Count;
- for (var i = ;i < entryAccount; i++)
- {
- //更新语句a => a.EntryCode == entryCode中entryCode不能用Lq[i].EntryCode代替,必须先取出来
- var entryCode = Lq[i].EntryCode;
- this.DbContext.Update<POM_Entry>(a => a.EntryCode == entryCode, a => new POM_Entry()
- {
- Status = "Suspend"
- });
- }
- });
- }
2.调用存储过程
存储过程如下:
- SET ANSI_NULLS ON
- GO
- SET QUOTED_IDENTIFIER ON
- GO
- --创建生成工单的存储过程
- CREATE PROCEDURE [dbo].[P_POM_CreateEntry]
- @OrderCode nvarchar(),--输入参数订单号
- @CreateUserId NVARCHAR(),--输入参数创建者ID
- @vMsg INT OUTPUT --输出参数
- AS
- BEGIN
- SET NOCOUNT ON;
- DECLARE --声明变量
- @MaterielNo NVARCHAR(),
- @NumberSegmentStart INT,
- @NumberSegment INT,
- @CellCode NVARCHAR(),
- @PPRCode NVARCHAR(),
- @Type NVARCHAR(),
- @OrderIndex INT = 1,
- @Amount FLOAT=
- --根据订单号查询 给变量赋值
- SELECT
- @MaterielNo = dbo.POM_Order.MaterielNo,
- @NumberSegmentStart = dbo.POM_Order.NumberSegmentStart,
- @CellCode = dbo.POM_Order.CellCode,
- @PPRCode = dbo.POM_Order.PPRCode,
- @Type = dbo.POM_Order.[Type],
- @Amount= dbo.POM_Order.Amount
- FROM dbo.POM_Order WHERE OrderCode = @OrderCode;
- SET @NumberSegment = @NumberSegmentStart
- --加入事务
- begin tran;
- begin TRY
- --循环号段
- DELETE FROM dbo.POM_Entry WHERE OrderCode = @OrderCode;--如果存在删除
- WHILE @NumberSegment < @NumberSegmentStart+CONVERT(INT,@Amount)--重点:int类型和float类型的直接相加 会出错,得做一下类型转换
- BEGIN
- INSERT dbo.POM_Entry
- ( Id ,
- OrderCode ,
- EntryCode ,
- ProductUniqueCode ,
- CellCode ,
- PPRCode ,
- Type ,
- Status ,
- PlanStartTime ,
- PlanEndTime ,
- ActualStartTime ,
- ActualEndTime ,
- OrderIndex,
- CreationTime ,
- CreateUserId ,
- IsEnabled ,
- IsDeleted ,
- DeletionTime ,
- DeleteUserId
- )
- VALUES ( NEWID() , -- Id - nvarchar() --调用函数
- @OrderCode , -- OrderCode - nvarchar()
- [dbo].[f_GetNumber]('EN', floor(RAND()*)) , -- EntryCode - nvarchar() --调用函数f_GetNumber
- [dbo].f_GetProductUniqueCode(@MaterielNo, @NumberSegment) , -- ProductUniqueCode - nvarchar()--调用函数f_GetProductUniqueCode
- @CellCode , -- CellCode - nvarchar()
- @PPRCode , -- PPRCode - nvarchar()
- @Type , -- Type - nvarchar()
- 'New' , -- Status - nvarchar()
- NULL , -- PlanStartTime - datetime
- NULL , -- PlanEndTime - datetime
- NULL , -- ActualStartTime - datetime
- NULL , -- ActualEndTime - datetime
- @OrderIndex , -- OrderIndex - int
- GETDATE() , -- CreationTime - datetime
- @CreateUserId , -- CreateUserId - varchar()
- , -- IsEnabled - bit
- , -- IsDeleted - bit
- NULL , -- DeletionTime - datetime
- NULL -- DeleteUserId - varchar()
- );
- SET @NumberSegment += ;
- SET @OrderIndex += ;
- end
- commit;--成功
- SET @vMsg = ;
- end TRY
- begin catch
- rollback tran;--失败回滚
- SET @vMsg = ;
- end catch
- END
用Clone框架:
- public int CreateEntry(string orderCode) {
- DbParam[] pas = new DbParam[];
- pas[] = new DbParam("@OrderCode", orderCode);
- pas[] = new DbParam("@CreateUserId",this.Session.UserId);
- pas[] = new DbParam("@vMsg", null, typeof(int)) { Direction = ParamDirection.Output };
- DbContext.SqlQuery<int>("P_POM_CreateEntry", CommandType.StoredProcedure, pas).FirstOrDefault();
- return (int)pas[].Value;
- }
3.对时间类型的模糊查询
sql server 的sql语句:
- SELECT ISNULL(COUNT(1), 0) as amount FROM dbo.POM_Entry WHERE convert(varchar(10), ActualEndTime, 121) = '2017-04-01' AND Status = 'Complete'
用Clone框架:Clone框架有.Contains(),表示like模糊查询,但是不适用于Date类型的字段ActualEndTime,所以我只能写sql语句了
- /*
- 平台首页:月产量统计图获取本月每日的产量
- */
- public string GetFinishAmountByMonth(string year,int month,int day)
- {
- string MonthStr = "";
- var dataStr = "";
- int vliday = ;
- if (month < )
- {
- MonthStr = "" + month.ToString();
- }
- else
- {
- MonthStr = month.ToString();
- }
- for(; vliday <= day;vliday ++ )
- {
- string NowDate = "";
- if ( vliday < )
- {
- NowDate = year + "-" + MonthStr + "-" + "" + vliday.ToString();
- }
- else
- {
- NowDate = year + "-" + MonthStr + "-" + vliday.ToString();
- }
- //SELECT ISNULL(COUNT(1), 0) as amount FROM dbo.POM_Entry WHERE convert(varchar(10), ActualEndTime, 121) = '2017-04-01' AND Status = 'Complete'
- string sql = "SELECT ISNULL(COUNT(1), 0) as amount FROM dbo.POM_Entry WHERE convert(varchar(10), ActualEndTime, 121) = '{0}' AND Status = 'Complete'";
- POMDayProduct data = this.DbContext.SqlQuery<POMDayProduct>(string.Format(sql, NowDate),null).ToList()[];
- if ( vliday != day)
- {
- dataStr = dataStr + data.amount + ",";
- }
- else
- {
- dataStr = dataStr + data.amount;
- }
- }
- return dataStr;
- }
注意:
1.这个方法得频繁的和数据库交互,不是很好;
2.对时间模糊查询时,时间字符串必须是'2017-04-09'这样的格式,也就是说'2017-4-9'这种格式是查不出来数据的,
所以我对月,日做了判断,小于10==>拼成'0x';
3.时间字符串类型的转换,充分利用convert(varchar(10), ActualEndTime, 121),这个函数是将ActualEndTime日期类型转化为10位的字符串时间:'2017-04-09';
4.查询某一天的记录直接利用convert()函数等值判断就可以了,不需要like了,代码中的"= '{0}'"就是了,而且" '{0}'"表示第一个参数NowDate,一定要加单引号,不然数据库也是查询不出来的;
5.SELECT ISNULL(COUNT(1), 0) as amount 也要注意, ISNULL(COUNT(1), 0)的数据类型是int类型的,所以POMDayProduct实体里的属性amount的类型(as amount) 也一定必须是int类型的;
6.最后说一下,为了避免和数据库多次交互,这个方法本来我是写成了存储过程,但无奈返回的是"1,2,3,4,,,,,"类型的字符串,而我用Clone框架的this.DbContext.SqlQuery<T>,T不能使用string,必须是一个实体,故放弃了存储过程
持久层框架Clone的更多相关文章
- MyBatis持久层框架使用总结
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis . 2 ...
- MyBatis持久层框架使用总结 转载
MyBatis持久层框架使用总结 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google co ...
- Mybatis详解系列(一)--持久层框架解决了什么及如何使用Mybatis
简介 Mybatis 是一个持久层框架,它对 JDBC 进行了高级封装,使我们的代码中不会出现任何的 JDBC 代码,另外,它还通过 xml 或注解的方式将 sql 从 DAO/Repository ...
- java持久层框架mybatis如何防止sql注入
看到一篇很好的文章:http://www.jfox.info/ava-persistence-framework-mybatis-how-to-prevent-sql-injection sql注入大 ...
- .NET平台下,关于数据持久层框架
在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...
- 菜鸟学习Hibernate——持久层框架
一.Java操作数据库的阶段. Java对数据库进行操作经历了三个阶段. 1.1操作JDBC阶段 这个阶段就是利用JDBC类来操作数据库.这个阶段出现了两个问题: 代码过度重复:在每一次数据库操作的是 ...
- .NET平台数据持久层框架
在.NET平台下的几个数据持久层框架: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS.NET 5.DAAB 6.DLinq
- Hibernate数据库持久层框架
Hibernate是一种Java语言下的对象关系映射解决方案. 它是使用GNU宽通用公共许可证发行的自由.开源的软件.它为面向对象的领域模型到传统的关系型数据库的映射,提供了一个使用方便的框架.Hib ...
- 持久层框架之MyBatis
1.mybatis框架介绍: MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并 ...
随机推荐
- vue --- 关于多个router-view视图组件,渲染同一页面
vue.js多视图的使用,可以提高网页组件化,模块化 比如使用多视图,可以将网站页面封装header.footer.navbar等多个公共部分, 遇到修改公共部分的文案信息等数据的时候,不再需要逐一修 ...
- Python中functools模块函数解析
Python自带的 functools 模块提供了一些常用的高阶函数,也就是用于处理其它函数的特殊函数.换言之,就是能使用该模块对可调用对象进行处理. functools模块函数概览 functool ...
- 又一个设计工具 Framer X Preview
又一个设计工具 Framer X Preview 所说比 Sketch 和 Figma 都要好用,不知道是不是真的 ~~ To give you a little background, I've b ...
- Paper-[arXiv 1710.03144]Island Loss for Learning Discriminative Features in Facial Expression
[arXiv 1710.03144]Island Loss for Learning Discriminative Features in Facial Expression ABSTRACT 作者在 ...
- Guitar Pro中文版下载,你想要的,都在这啦!
我的音乐我做主!Guitar Pro7中文版的发布为更多音乐爱好者带来更多更优质的体验!为帮助所有吉他爱好者学习.绘谱.创作而设计的音乐空间!为前所未有的音乐盛听而震撼,音乐才子,等的就是你! Gui ...
- 第十二章 Python网络编程
socket编程 socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket ...
- day09-1 列表,元祖的内置方法
目录 列表类型的内置方法 作用 定义方式 方法 优先掌握 需要掌握 储存一个值or多个值 有序or无序?(有序:有索引, 无序:无索引) 可变or不可变(可变:值变id不变,不可变:值变id也变) 元 ...
- 转载:常用 Git 命令清单
转载:常用 Git 命令清单 原文地址:http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 作者: 阮一峰 我每天使用 Git , ...
- B-Tree概念
记录下学习B-Tree: concept:(m-阶) 1. 根节点 孩子数 ( 2 <= N <= m) 根节点key数([m/2] - 1 <= n <= m -1) 2 ...
- xmllint命令
xmllint是一个很方便的处理及验证xml的工具,linux下只要安装libxml2就可以使用这个命令,下面整理一些常用功能 1. --format 此参数用于格式化xml,使其具有良好的可读性. ...