Orm 常见查询实例

1、Moon.Orm框架总述 (您还用hibernate?实体框架?)

1.框架名:Moon 意思是月亮,而非Mono.由于很喜欢明月,因此以此为名.它是一个.NET下的Orm框架.html

2.发展历史:历经近乎三年的发展历程,原由是EF框架的起初性能缘由,为项目实战而生.mysql

3.项目经验:通过数家公司项目实战、以及众多用户的确定.sql

 

qq群: 225656797 

 

Moon.Orm的追求方向:

1)高性能.
这也是架构建立的目的之一,已经将它的性能提高到了极致.你们能够本身测试.我能够说其性能是首屈一指的.
链接地址: Moon洗冤录
2)易用性强
我想,用过Moon.ORM的应该能够知道这点.配置简单,智能感知,代码生成器的辅助,会sql就可以使用之.
详情见,链接地址: Moon使用配置说明
3)多数据库多数据源支持
在同一个项目中咱们经常须要处理这些状况时.目前moon的目标,支持sqlserver sqlite oracle mysql postgreSQL db2

若是您须要换数据库:直接修改配置文件而后一键生成实体层便可;数据库

若是您须要多数据库:直接添加配置文件便可.详情:Moon使用配置说明架构

4)智能感知

这个不用讲了,值得一提的是MQL,她可以为你提供强大的智能感知功能,而且无数据库类型差别.oracle

详情:MQL无linq化的战役框架

5).NET 2.0原生支持.

有人问:为何没有LINQ、lambda,其实我只想说:没有必要作这些了,由于微软一个团队在作实体框架,去作一些没必要要的事情,sqlserver

真的没有意思. 以为MQL复杂的兄弟们,有了智能感知,大家就适应适应,由于这是萝卜白菜的问题.post

6) 使用便捷.

这个其实上面的连接也谈到,详情见:http://www.cnblogs.com/humble/p/3293500.html性能

 

2、Moon.Orm的功能预览

 

2.MQL查询分类讲解

2.1 MQL的标准查询

var mm=ClassSet. Select(ClassSet.ClassID,ClassSet.ClassName).

Where(ClassSet.ClassName.Contains("s").And(ClassSet.ClassID.BiggerThan(9)));

 

SELECT [Class].[ClassID],[Class].[ClassName] FROM [Class] WHERE [Class].[ClassName] LIKE @p1  AND  [Class].[ClassID]>@p2
@p1=%s%
@p2=9

2.2 MQL的嵌套查询(含有Top查询:支持mysql、oracle、postgreSQL、sqlserver、sqlite)

var qiantao=ScoreSet. SelectAll(). Where(
                    ScoreSet.UserID. In(UserSet. Select(UserSet.UserID). Where(
                        UserSet.ClassID. In(
                        ClassSet. Select(ClassSet.ClassID). Where(
                                ClassSet.ClassName. Equal(c.ClassName). And(ClassSet.ClassID. BiggerThan( 0))
                            )
                        )
                    )
                  ) 
                ). Top( 1);
  SELECT TOP 1 [Score].* FROM [Score] WHERE [Score].[UserID] IN (SELECT [User].[UserID] FROM [User] WHERE [User].[ClassID] IN (SELECT [Class].[ClassID] FROM [Class] WHERE [Class].[ClassName]=@p1  AND  [Class].[ClassID]>@p2 ) )
@p1=综合测试ClassName2
@p2=0

2.3 MQL的分组查询

var mql=ScoreSet. Select(ScoreSet.ScoreM. Sum(). AS( "sum"),ScoreSet.TypeName).

Where(ScoreSet.ScoreM.BiggerThanOrEqual(100)).

GroupBy(ScoreSet.TypeName).

Having(ScoreSet.ScoreM.Sum().BiggerThan(300));

 

SELECT SUM([Score].[ScoreM]) AS 'sum',[Score].[TypeName] FROM [Score] WHERE  [Score].[ScoreM]>=@p1  GROUP BY [Score].[TypeName]  HAVING  SUM([Score].[ScoreM])>@p2
@p1=100
@p2=300

2.4 MQL的链接查询

var m1=ClassSet. Select(ClassSet.ClassID,ClassSet.ClassName)
                    . LeftJoin(
                    UserSet. Select(UserSet.UserID))
                    . ON(ClassSet.ClassID. Equal(UserSet.UserID))
                    . Where(UserSet.UserID. BiggerThan( 9));
SELECT [Class].[ClassID],[Class].[ClassName],[User].[UserID] FROM [Class] LEFT JOIN [User] ON [Class].[ClassID]=[User].[UserID]  WHERE  [User].[UserID]>@p1
@p1=9

2.5 MQL的Union查询

var mql=ClassSet. SelectAll(). Where(ClassSet.ClassID. BiggerThan( 1))
                    . Union(ClassSet. SelectAll(). Where(ClassSet.ClassID. BiggerThan( 2)));
 
var mql=ClassSet. SelectAll(). Where(ClassSet.ClassID. BiggerThan( 1))
                    . UnionAll(ClassSet. SelectAll(). Where(ClassSet.ClassID. BiggerThan( 2)));

 

SELECT [Class].* FROM [Class] WHERE  [Class].[ClassID]>@p1  UNION  SELECT [Class].* FROM [Class] WHERE  [Class].[ClassID]>@p2
@p1=1
@p2=2
SELECT [Class].* FROM [Class] WHERE  [Class].[ClassID]>@p1  UNION ALL SELECT [Class].* FROM [Class] WHERE  [Class].[ClassID]>@p2
@p1=1
@p2=2

3.MQL查询结果预览

public  static  void  Main( string[] args)
        {
            
             using ( var db=Db. CreateDefaultDb()) {
                db.TransactionEnabled= true;
                db.DebugEnabled= true;
                Console. WriteLine( "---------------嵌套查询---------------------");
                 var qiantao=ScoreSet. SelectAll(). Where(
                    ScoreSet.UserID. In(UserSet. Select(UserSet.UserID). Where(
                        UserSet.ClassID. In(
                        ClassSet. Select(ClassSet.ClassID). Where(
                                ClassSet.ClassName. Equal(c.ClassName). And(ClassSet.ClassID. BiggerThan( 0))
                            )
                        )
                    )
                  ) 
                ). Top( 1);
               
                Console. WriteLine( "---------------分组查询---------------------");
                 var mql=ScoreSet. Select(ScoreSet.ScoreM. Sum(). AS( "sum"),ScoreSet.TypeName). Where(ScoreSet.ScoreM. BiggerThanOrEqual( 100)). GroupBy(ScoreSet.TypeName). Having(ScoreSet.ScoreM. Sum(). BiggerThan( 300));
              
                Console. WriteLine( "---------------链接查询---------------------");
                 var m1=ClassSet. Select(ClassSet.ClassID,ClassSet.ClassName)
                    . LeftJoin(
                    UserSet. Select(UserSet.UserID))
                    . ON(ClassSet.ClassID. Equal(UserSet.UserID))
                    . Where(UserSet.UserID. BiggerThan( 9));

            }
            Console.WriteLine("---------------Union测试---------------------");
            using (var db=Db.CreateDefaultDb()) {
                db.TransactionEnabled=true;
                db.DebugEnabled=true;
                
                var mql=ClassSet.SelectAll().Where(ClassSet.ClassID.BiggerThan(1))
                    .Union(ClassSet.SelectAll().Where(ClassSet.ClassID.BiggerThan(2))); 

            }
        }

 

 

 

 

 

 

3、Moon.Orm的开源发布

1)Moon.Orm 5.0以前的版本以(LGPL)开源发布

 

 

2)以后的版本步步开源,对于参与者提供源代码.

 

 

若是您参与Moon.Orm的核心开发或辅助平台开发,您将直接得到5.0的源代码,有意者联系:qsmy_qin@163.com

固然您能够资金支持.十块钱那也是支持,请注明,您的邮箱地址.

 

 
5.0框架下载: http://www.cnblogs.com/humble/p/3298594.html

5.0社区版代码生成器下载:http://www.cnblogs.com/humble/p/3312018.html

 

4、Moon.Orm的技术文档

 若是您喜欢它,请推荐支持一下吧:)

 待续
相关文章
相关标签/搜索