1.DMSFrame是一个完整的ORM框架,框架相对来说也比成熟了。使用上有些地方还是比较方便的。DLL文件大约300K左右,但却可以支持各种方式的查询,完全的LINQ化的方式书写代码,更有利于维护。

2.框架完全支持调试时生成的SQL语句跟踪,你可以很清晰地看出是哪里的写法出了问题。

3.框架附加了完全支持查询SQL的写法。更有效的解决复杂的SQL的问题

先上代码尝尝先吧:

1 var query = DMS.Create<Adm_User>().Where(q => q.UserID == 1).ToEntity();

生成SQL参数如下:

SELECT [t0].[UserID],[t0].[UserName],[t0].[TrueName],[t0].[UserPwd],[t0].[DeptID],[t0].[DeptName],[t0].[UserCode],[t0].[CompanyEmail],[t0].[MobileNum],[t0].[StatusFlag],[t0].[LastLoginTime],[t0].[LoginTimes],[t0].[LastLoginIp],[t0].[ResetPwdFlag],[t0].[CreateTime],[t0].[CreateUser],[t0].[DeleteFlag],[t0].[DeleteTime],[t0].[DeleteUser],[t0].[UpdateUser],[t0].[UpdateTime],[t0].[Remark]
FROM [Adm_User] AS [t0] WITH(NOLOCK)
WHERE ([t0].[UserID] = @p0)
ParameterName:@p0 Value:1 DbType:Int32

 可以看出生成的查询语句,会自动将参数信息自动转化为Parameter,这样也有效杜绝SQL注入式攻击

WITH(NOLOCK)这个功能是后续添加的功能,稍候会补充哪里可以修改时面的内容

回到DMS当中,我们可以看到参数说明信息

Create方法有四个参数信息

string bDataBase, bool bNeedParams, bool bWithLock, bool bNeedQueryProvider

相关说明:

/// <summary>
/// DMS查询引擎创建
/// </summary>
/// <typeparam name="T">类型参数必须是引用类型;这一点也适用于任何类、接口、委托或数组类型。</typeparam>
/// <param name="bDataBase">数据库名称</param>
/// <param name="bNeedParams">否使用参数形式生成SQL</param>
/// <param name="bWithLock">是否反向定义WITH(NOCLOCK)</param>
/// <param name="bNeedQueryProvider"></param>
/// <returns>DMS^T</returns>

1.Create可以加入bDataBase数据库名称,此参数会自动在表上面加入数据库的说明,默认为空(暂只测试过MSSQL)

2.bNeedParams是否使用参数的形式去解析SQL,默认为true

3.bWithLock 是否反向定义生成With(nolock)字段,这个是根据数据库配置去生成些查询方式的,默认为false,如果为true,数据库配置XML如果设置成需要nolock的话,刚这里就不会生成,反之亦然。

4.bNeedQueryProvider此参数本身是为了做列权限去写的框架,具体使用后续说明。。。。

那我们查询一些更复杂的例子呢

var query = DMS.Create<Adm_User>()
.Where(q => q.UserName.Like("admin"))
.Select(q => q.Columns(q.UserID, q.UserName))

解析如下:

SELECT [t0].[UserID],[t0].[UserName]
FROM [Adm_User] AS [t0] WITH(NOLOCK)
WHERE ([t0].[UserName] LIKE @p0)
ParameterName:@p0 Value:%admin% DbType:AnsiString

可以看出Where条件里面支持很多最基本的查询,此处注意q.Columns这个写法也是区别Linq的一些写法的。如EF框架就不是这么写的。

目前Where条件方法支持有 GreaterThan | >, GreaterThanOrEqual | >=,LessThan | <,LessThanOrEqual | <=,Like | like %$%, NotLike | not like %$%,

BeginWith | like $%,FinishWith | like %$,In | in(params [] array),NotIn | not in查询的方法

基本上大部分的方法在这里都是支持的。GreaterThan 这些大于小于方法适用于string类型,如果是数字类型,比如int,是可以直接使用 > < 号的

另:Where条件字段支持:IsNull | IS NULL, IsNotNull | IS NOT NULL, Replace | Replace(MSSQL),Substring | Substring(MSSQL),NewID | NEWID(),

等特殊方法。

var query = DMS.Create<Adm_User>()
.Where(q => q.UserName.Like("admin"))
.Select(q => new
{
UserID = q.UserID,
UserName = q.UserName.Substring(1, 2),
});

解析如下:

SELECT [t0].[UserID], Substring([t0].[UserName],1,2)  AS [UserName]
FROM [Adm_User] AS [t0] WITH(NOLOCK)
WHERE ([t0].[UserName] LIKE @p0)
ParameterName:@p0 Value:%admin% DbType:AnsiString

分页写法:

ConditionResult<Adm_User> userList = DMS.Create<Adm_User>()
.Where(a => a.UserName.Like("") && a.UserCode == "")
.OrderBy(q => q.OrderBy(q.UserID))
.Pager(, ).ToConditionResult();

ConditionResult<T>的信息里面包括这里面总共有多少条数据(分页前),List带有结果集里的东西。。。

其它写法:

 var userList = (from a in DMS.Create<Adm_User>()
where a.UserID == && a.UserName.Like("")
select a);

INNER JOIN 写法:

 var query = DMS.Create<Adm_User>()
.Join(DMS.Create<Adm_Rights>(),
(x, y) => x.UserID == y.RightsID,
(x, y) => new
{
x.UserCode,
x.UserID,
y.RightsName,
y.RightsParentID,
RID = y.RightsID,
RightsName2 = y.RightsName,
});

另外还支持LeftJoin,RightJoin,写法相近,这里就不举例了.

查询结果函数有:

ToList<T>    --返回结果集信息,支持任意类,以类属性自动给值,参数有几个,1.是否启用缓存,2.返回条数,3.对属性是否忽略大小写进行赋值

ToConditionResult<T>   --返回分页结果集信息

ToResult<T>  --返回DataTable数据,如果没有实体也没有关系的.只要返回DataTable,想怎么处理就怎么处理,呼呼..

从上可以看出,select查询是支持匿名写法的。生成的SQL语句如上,列查询的方式也加了一个SQL函数

以上是这章的一些查询的例子。。暂先到这了。。

相关下载:http://files.cnblogs.com/files/kingkoo/DMSFrameRights.zip 此版本为以前的一个版本,最新的版本请加群问群主吧

新上传DMSFrame版本文件:http://files.cnblogs.com/files/kingkoo/DMSFrame_Secure20150606.7z

DMSFrame 之简单用法(一)的更多相关文章

  1. DMSFrame 之简单用法(二)

    上次说了下DMSFrame的一些查询方式,之前也有好多朋友问了下这个ORM与EF有什么样的区别. 要论区别,我自己也总结了几点.如果有其它朋友知道的,可以回复补充下. 1.不需要编辑的时候需要再次查询 ...

  2. CATransition(os开发之画面切换) 的简单用法

    CATransition 的简单用法 //引进CATransition 时要添加包“QuartzCore.framework”,然后引进“#import <QuartzCore/QuartzCo ...

  3. jquery.validate.js 表单验证简单用法

    引入jquery.validate.js插件以及Jquery,在最后加上这个插件的方法名来引用.$('form').validate(); <!DOCTYPE html PUBLIC " ...

  4. NSCharacterSet 简单用法

    NSCharacterSet 简单用法 NSCharacterSet其实是许多字符或者数字或者符号的组合,在网络处理的时候会用到 NSMutableCharacterSet *base = [NSMu ...

  5. [转]Valgrind简单用法

    [转]Valgrind简单用法 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian S ...

  6. Oracle的substr函数简单用法

    substr(字符串,截取开始位置,截取长度) //返回截取的字 substr('Hello World',0,1) //返回结果为 'H'  *从字符串第一个字符开始截取长度为1的字符串 subst ...

  7. Ext.Net学习笔记19:Ext.Net FormPanel 简单用法

    Ext.Net学习笔记19:Ext.Net FormPanel 简单用法 FormPanel是一个常用的控件,Ext.Net中的FormPanel控件同样具有非常丰富的功能,在接下来的笔记中我们将一起 ...

  8. TransactionScope简单用法

    记录TransactionScope简单用法,示例如下: void Test() { using (TransactionScope scope = new TransactionScope()) { ...

  9. WPF之Treeview控件简单用法

    TreeView:表示显示在树结构中分层数据具有项目可展开和折叠的控件 TreeView 的内容是可以包含丰富内容的 TreeViewItem 控件,如 Button 和 Image 控件.TreeV ...

随机推荐

  1. jenkins2 multibranch

    通过multibranch类型的pipeline job使得对于多个branch的支持更加简单.只需要创建一个multibranch job,jenkins将自动地为所有的branch创建job. 文 ...

  2. bigautocomplete实现联想输入,自动补全

    bigautocomplete是一款Jquery插件.用它实现仿搜索引擎文本框自动补全插件功能很实用,使用也很简单,引入了插件之后写几行代码就可以实现,可以灵活设置. 先看效果图: 上图是通过ajax ...

  3. paip.python php的未来预测以及它们的比较优缺点

    paip.python php的未来预测以及它们的比较优缺点 跟个php比..python有下列的优点: 1.桌面gui 功能强大. 主要是pyqt很好...而ruby qt 则好像不更新了..php ...

  4. eclipse code templates 设置(eclipse注释模版配置)

    文件(Files)注释标签:/** * @Title: ${file_name} * @Package ${package_name} * @Description: ${todo} * Copyri ...

  5. MyBatis crud操作

    Test2.java package com.mycom.mybatis_1.crud; import java.util.List; import org.apache.ibatis.session ...

  6. C#Winform程序如何发布并自动升级(图解)

    C#Winform程序如何发布并自动升级(图解)     有不少朋友问到C#Winform程序怎么样配置升级,怎么样打包,怎么样发布的,在这里我解释一下打包和发布 关于打包的大家可以看我的文章C# w ...

  7. RTX的api開發實例

    RTX的api開發實例 最近接觸了RTX的接口開發部份,RTX其实有很多玩法,除了可以用自帶的客戶端發消息之外還可以用PHP調用API的方式來做一些事情,下邊整理了一下分享給大家 值得提醒的是这些接口 ...

  8. Lucene 4.X 倒排索引原理与实现: (2) 倒排表的格式设计

    1. 定长编码 最容易想到的方式就是常用的普通二进制编码,每个数值占用的长度相同,都占用最大的数值所占用的位数,如图所示. 这里有一个文档ID列表,254,507,756,1007,如果按照二进制定长 ...

  9. Adobe Illustrator里使用fontawesome矢量图标

     简单教程:1.安装FontAwesome.otf字体2.打开http://fontawesome.io/cheatsheet/3.选中图标图片,ctrl+c4.粘贴到AI中5.选中粘贴的内容,修改字 ...

  10. halcon学习之产品检测

    Rinspect_gasket_local_deformable.hdev   检测垫圈局部变形   *这个例子演示了如何利用局部变形匹配(local deformable matching)来寻找出 ...