PCB C# MongoDB 查询(SQL,NOSQL,C#对比)
一.准备阶段
1.查询数据清单准备

2.这里先将SQL语句执行顺序列出来,方便后面语句对比更好理解
(8)SELECT
(9)DISTINCT
(11)<Top Num> <select list>
(1)FROM [left_table]
(3)<join_type> JOIN <right_table>
(2) ON <join_condition>
(4)WHERE <where_condition>
(5)GROUP BY <group_by_list>
(6)WITH <CUBE | RollUP>
(7)HAVING <having_condition>
(10)ORDER BY <order_by_list>
二.查询全表
1. SQL:
select * from ppeflow
2. MongoDB NO SQL:
db.ppeflow.find()
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var resultList = ppeflows.Find(filter).ToList();//获取集合
三.查询数据总数
1. SQL:
select count(1) from ppeflow
2. MongoDB NO SQL:
db.ppeflow.find({}).count()
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var result = ppeflows.CountDocuments(filter); //获得集合数量
四.查询并排序
1. SQL:
select * from ppeflow order by orderid
select *from ppeflow order by orderid desc
2. MongoDB NO SQL:
db.ppeflow.find().sort({'orderid':1})
db.ppeflow.find().sort({'orderid':-1})
3. MongoDB C#
方式一
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var builderSort = Builders<ppeflow>.Sort.Ascending(t => t.orderid); //创建排序
var resultList = ppeflows.Find(filter).Sort(builderSort).ToList();//获取集合
方式二
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var resultList = ppeflows.Find(filter).SortByDescending(t => t.orderid).ToList();//获取集合
五.查询TOP前10条记录
1. SQL:
select top 10 * from ppeflow
2. MongoDB NO SQL:
db.ppeflow.find().limit(10)
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var resultList = ppeflows.Find(filter).Limit().ToList();//获取集合
六.查询从第6条到第10条记录(即:跳过前5条记录起的后5条记录)
1. SQL:
select * from ppeflow limit 5,5
2. MongoDB NO SQL:
db.ppeflow.find().skip(5).limit(5)
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var resultList = ppeflows.Find(filter).Skip().Limit().ToList();//获取集合
七.查询distinct去除重复字段
1. SQL:
select DISTINCT techname from ppeflow
2. MongoDB NO SQL:
db.ppeflow.distinct('techname')
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Empty;//过滤为空
var resultList = ppeflows.Distinct(tt => tt.techname, filter).ToList();//获取集合
八.查询Group by分组
1. SQL:
select techname,count(1) as total from ppeflow group by techname
2. MongoDB NO SQL:
db.ppeflow.group({
key:{ "techname":true}
,initial: {techname:'',total: 0}
,reduce: function(doc, out)
{
out.techname = doc.techname;
out.total += doc.orderid;
}
})
3. MongoDB C#
//待完善
九.查询条件>,>=,<,<=,<>
1. SQL:
select techname from ppeflow where orderid > 10
select techname from ppeflow where orderid >= 10
select techname from ppeflow where orderid < 10
select techname from ppeflow where orderid <= 10
select techname from ppeflow where orderid <> 10
2. MongoDB NO SQL:
db.ppeflow.find({'orderid':{$gt:10}},{'techname':1})
db.ppeflow.find({'orderid':{$gte:10}},{'techname':1})
db.ppeflow.find({'orderid':{$lt:10}},{'techname':1})
db.ppeflow.find({'orderid':{$lte:10}},{'techname':1})
db.ppeflow.find({'orderid':{$ne:10}},{'techname':1})
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
FilterDefinition<ppeflow> filter = builderFilter.Where(t => t.orderid > ); ;//过滤条件 改为对应的>=,<,<=,!=
var resultList = ppeflows.Find(filter).ToList();//获取集合
十.查询条件in与not in
1. SQL:
select * from ppeflow where orderid in (10,11,12)
select * from ppeflow where orderid not in (10,11,12)
2. MongoDB NO SQL:
db.ppeflow.find({'orderid':{$in:[10,11,12]}})
db.ppeflow.find({'orderid':{$nin:[10,11,12]}})
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
var filter = builderFilter.In(tt => tt.orderid, new List<int> { , , });//In 条件 或Nin
var resultList = ppeflows.Find(filter).ToList();//获取集合
十一.查询模糊查询 like
1. SQL:
select * from ppeflow where techname like '%钻孔%'
select * from ppeflow where techname like '钻孔%'
select * from ppeflow where techname like '%钻孔'
2. MongoDB NO SQL:
说明:i 忽略大小写 m 多行匹配模式 x 忽略非转义的空白字符 s 单 匹配模式
db.ppeflow.find( { 'techname': /钻孔/i } )
db.ppeflow.find( { 'techname': /钻孔$/i } )
db.ppeflow.find( { 'techname': /^钻孔/i } )
3. MongoDB C#
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
var filter = builderFilter.Regex(tt => tt.techname, new BsonRegularExpression("/钻孔/i")); //正则匹配
var resultList = ppeflows.Find(filter).ToList();//获取集合
十二.查询多条件逻辑 or与and
1. SQL:
select * from ppeflow where techname = '开料' or techname = '钻孔'
select * from ppeflow where orderid = 2 and techname = '钻孔'
2. MongoDB NO SQL
db.ppeflow.find({$or:[{'techname':'开料'},{'techname':'钻孔'}]})
db.ppeflow.find({$and:[{'orderid':2},{'techname':'钻孔'}]})
3. MongoDB C#
C# or
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
var filter1 = builderFilter.Eq(tt => tt.techname, "开料");
var filter2 = builderFilter.Eq(tt => tt.techname, "钻孔");
var filter = builderFilter.Or(filter1, filter2);
var resultList = ppeflows.Find(filter).ToList();//获取集合
//ppeflows.AsQueryable().Where(tt => tt.techname == "开料" || tt.techname == "钻孔").ToList(); //lamda一种简写
C# and
IMongoCollection<ppeflow> ppeflows = db.GetCollection<ppeflow>("ppeflow");//指定数据库
FilterDefinitionBuilder<ppeflow> builderFilter = Builders<ppeflow>.Filter; //创建过滤
var filter1 = builderFilter.Eq(tt => tt.orderid, );
var filter2 = builderFilter.Eq(tt => tt.techname, "钻孔");
var filter = builderFilter.And(filter1, filter2);
var resultList = ppeflows.Find(filter).ToList();//获取集合
//ppeflows.AsQueryable().Where(tt => tt.orderid == 2 && tt.techname == "钻孔").ToList(); //lamda一种简写
PCB C# MongoDB 查询(SQL,NOSQL,C#对比)的更多相关文章
- Entity Frameword 查询 sql func linq 对比
Entity Framework是个好东西,虽然没有Hibernate功能强大,但使用更简便.今天整理一下常见SQL如何用EF来表达,Func形式和Linq形式都会列出来(本人更多在用Func形式,l ...
- mongodb查询语句与sql语句对比
左边是mongodb查询语句,右边是sql语句.对照着用,挺方便. db.users.find() select * from users db.users.find({"age" ...
- mongodb 跟踪SQL语句及慢查询收集
有个需求:跟踪mongodb的SQL语句及慢查询收集 第一步:通过mongodb自带函数可以查看在一段时间内DML语句的运行次数. 在bin目录下面运行 ./mongostat -port 端口号 ...
- mongodb与sql语句对比
左边是mongodb查询语句,右边是sql语句.对照着用,挺方便. db.users.find() select * from users db.users.find({"age" ...
- 8种Nosql数据库系统对比
导读:Kristóf Kovács 是一位软件架构师和咨询顾问,他最近发布了一片对比各种类型NoSQL数据库的文章. 虽然SQL数据库是非常有用的工具,但经历了15年的一支独秀之后垄断即将被打破.这只 ...
- 数据库 --> 8种NoSQL数据库对比
8 种 NoSQL 数据库对比 NoSQL是一项全新的数据库革命性运动,NoSQL的拥护者们提倡运用非关系型的数据存储.现今的计算机体系结构在数据存储方面要求具备庞大的水平扩展性,而NoSQL致力于改 ...
- [转]mongodb 查询条件:关系运算符"$lt", "$lte", "$gt", "$gte", "$ne" 逻辑运算符"$and“, "$or“, "$nor“
mongodb 查询条件 这节来说说mongodb条件操作符,"$lt", "$lte", "$gt", "$gte" ...
- Mongodb查询的用法,备注防止忘记
最近在用这个东西,为防止忘记,记下来. 集合简单查询方法 mongodb语法:db.collection.find() //collection就是集合的名称,这个可以自己进行创建. 对比sql语句 ...
- sql,nosql
1. 关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库. 关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐渐成 ...
随机推荐
- pygame 方块随机飞舞动画
import pygame import random # default WIDTH=1280 HEIGHT=1060 FPS=60 sum=0 # set color WHITE=(255,255 ...
- [POJ1155]TELE(树形背包dp)
看到这道题的第一眼我把题目看成了TLE 哦那不是重点 这道题是树形背包dp的经典例题 题目描述(大概的): 给你一棵树,每条边有一个cost,每个叶节点有一个earn 要求在earn的和大于等于cos ...
- Git安装使用指南
Git安装使用指南 Git原理示意图 1. 安装git Linux服务器版本为Redhat6.2-64,其他版本可能有些许不同 1.1 安装依赖包 在安装git前首先安装依赖包,包括的依赖包有: cv ...
- 1.Linux标准IO编程
1.1Linux系统调用和用户编程接口 1.1.1系统调用 用户程序向操作系统提出请求的接口.不同的系统提供的系统调用接口各不相同. 继承UNIX系统调用中最基本和最有用的部分. 调用按照功能分:进程 ...
- Java Syntax Specification
Java Syntax Specification Programs <compilation unit> ::= <package declaration>? <imp ...
- [luoguP2890] [USACO07OPEN]便宜的回文Cheapest Palindrome(DP)
传送门 f[i][j] 表示区间 i 到 j 变为回文串所需最小费用 1.s[i] == s[j] f[i][j] = f[i + 1][j - 1] 2.s[i] != s[j] f[i][j] = ...
- nyoj_79_拦截导弹_201403182040
拦截导弹 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 某国为了防御敌国的导弹袭击,发展中一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到 ...
- Java中基于HTTP协议网络编程
java中为我们的网络支持提供了java.net包,能够使我们以编程的方式来訪问Web服务功能,这篇博客,就跟大家分享一下.Java中的网络编程的知识.主要是学习下该java.net包下的API. U ...
- 猫猫学iOS 之CoreLocation反地理编码小Demo输入经纬度得到城市
猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243 一:效果 输入经纬度,能够得到相应的地名 二:思路 跟地里编码差 ...
- 【Cocos2dx游戏开发】CCNotificationCenter传递消息和数据
在开发游戏的时候我们经常需要在层与层之间.场景与场景之间传递数据和消息,Cocos2dx框架应用观察者模式为我们封装了一个CCNotificationCenter类,也叫消息通知中心,它也是一个单例类 ...