• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MongoDB的三层操作

MongoDB的三层操作

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MongoDB,三层,操作等相关知识,希望本文的分享对您有所帮助

今天也不知道哪根筋不对了,没有打Dota却想写一篇文章,其实自己也不知道写什么,专业技术较水,但真的很想写,自己文采又不够,所以还是只能写技术方面的文章啦!半瓶子还是可以晃荡晃荡的哈哈~ NOSQL近来势头不错,MongoDB更是其中的娇娇者,自己学nosql的

今天也不知道哪根筋不对了,没有打Dota却想写一篇文章,其实自己也不知道写什么,专业技术较水,但真的很想写,自己文采又不够,所以还是只能写技术方面的文章啦!半瓶子还是可以晃荡晃荡的哈哈~

NOSQL近来势头不错,MongoDB更是其中的娇娇者,自己学nosql的时候也是参考了大量的资料,最终决定要从MongoDB入手的,最重要的原因有两点:1自己是简单的爱好者,一切问题我都在想是否有简单的方法解决,宁可停下来去思考大量时间,也不愿用笨方法马上去做,而MongoDB的操作大都很简单,2自己是JS的爱好者,没事就喜欢拿一本js的本从头到尾看一边,也不管记住多少,也不管用不用得到,就是喜欢,MongoDB以BSON格式存储,所以操作也起来也算得心应手!现在做一个项目正是用MongoDB做为数据库的,一开始没有DAL,BLL直接访问数据库,然后就到UI了,香港空间,而且BLL是全静态的(我喜欢静态方法的调用简单,但狠静态类的不能继承!),当时考虑的是用MongoDB的驱动去操作太直白了!感觉没必要再写个DAL!,后来知道我想法还是很天真的,哈哈!下面就说现在的操作方式吧~

一、Module层

[Serializable] user { public ObjectId id; public string n; public int age; public Birthday birth; Birthday { public int y; public int m; public int d; } }

咋一看,虚拟主机,有几个地方不规范,1类名首字母和公开字段没有大写,2公开的字段,而没有用属性,3字段命名没表达它的意思。现在逐个解释一下,类名和字段没大写首字母主要是数据库里的命名是遵循js的,用js表示时大家一般会这样写:

var user={id:ObjectId("123456"),n:"loogn",age:23,birth:{y:1989,m:7,d:7}}

然而,可能有人会说可以用MongoDB.Bson.Serialization.Attributes.BsonElement这样一个Attribute关联呢!不过我不会那样做,原因就是太麻烦了!这里可能还是有疑问,留到第3个问题说。

公开字段而没有用属性也是不合常理的,学校老师都交过,不管你能不能理解,反正就是要私有化字段,想公开请用属性,哈哈!不过我想了很久还是不走寻常路了,目前为止用字段没有出现过缺陷问题,我不保证以后不会,但我感觉几率十分小,就算真的有什么问题必需要用属性,后面加上{get;set;}也不麻烦吧!属性毕竟还是方法,用属性有多余的方法调用开销,而且实体类本来就是不寻常的类,一般只表示对象状态(用字段),属性里如果有逻辑(就像老师常说的年龄不能小于0且不能大于150等等!),你会放到这里做吗?显然你都是放在BLL里做!字段命名太短了没有表达它的意思,其实这个可以和第一个一起来说,MongoDB是无模式的,同一个合集可以保多个不规则的文档,如user集合:

{id:1,n:"user1",desc:"我的描述"} {id:2,n:"user2"}

所以数据库必须保存文档的每一个元素的name(即id,name,desc,id,name),所以元素name越短越节省空间,本来是用name更能表达的,这里用了n,其实只要把常用的约定一下,绝大部分人都是可以接受的。

在user里还有个内嵌类Birthday,而这个类大写了首字母,我是这样考虑的,内嵌类名全部按C#命名规范,因为容器类有一个该内嵌类类型的字段,这里是birth,但如果找不到合适的缩写怎么办呢,直接小写内嵌类名就可以了,如内嵌城市类City,字段名为city就不会重复了。

二、DAL层

在这一层要写一个基类,完成这个基类后,其他的各各DAL类都是浮云了~,在写基类之前有一个MongoHelper,MongoHelper很简单,直接给出代码且不写解释:

MongoServer

public class MongoHelper { static readonly MongoConnectionStringBuilder ConnectionStringBuilder; static MongoHelper() { ] != null) { ConnectionStringBuilder = ].ConnectionString); } ] != null) { ConnectionStringBuilder = ].ConnectionString); } else { ); } } public static MongoServer GetServer(string connectionString) { var server = MongoServer.Create(connectionString); return server; } public static MongoServer GetServer() { var server = MongoServer.Create(ConnectionStringBuilder); return server; } public static MongoDatabase GetDatabase(string databaseName) { return GetServer().GetDatabase(databaseName); } public static MongoDatabase GetDatabase() { return GetDatabase(ConnectionStringBuilder.DatabaseName); } }

完了后就可以写BaseDAL了,如果没有泛型,DAL的工作还真是索然无味,但现在用泛型DAL的工作有趣多了,先承上代码:

数据访问层基类 BaseDAL { CollectionName { set; get; } 设置集合名 SetCollectionName(); private MongoCollection m_collection; 根据CollectionName得到MongoCollection对象 MongoCollection Collection { get { if (m_collection == null) { CollectionName = SetCollectionName(); m_collection = MongoHelper.GetDatabase().GetCollection(CollectionName); } return m_collection; } } 根据query条件得到一个文档对象 TDocument FindOne(IMongoQuery query, PreprocessHandler preprocess) { var document = Collection.FindOne(query); if (preprocess != null) { preprocess(ref document); } return document; } 把MongoCursor转换成IList类型 IList CursorToList(MongoCursor cursor, PreprocessHandler preprocess) { IList list = new List(30); bool isPreprocess = preprocess != null; foreach (TDocument document in cursor) { var doc = document; if (isPreprocess) preprocess(ref doc); list.Add(doc); } return list; } 根据query查询集合 IList Find(IMongoQuery query, MongoCursorSettings cursorSettings, PreprocessHandler preprocess) { var cursor = Collection.Find(query); if (cursorSettings != null) { cursorSettings.Set(cursor); } var list = CursorToList(cursor, preprocess); return list; } }

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MongoDB中常用的语句总结
  • MongoDB导入json数据的方法
  • MongoDB提升性能的方法总结
  • 什么是MongoDB?MongoDB简介
  • 什么是mongoDB数据库
  • 黑马云课堂mongodb实操视频的源码课件推荐
  • 燕十八mongodb视频资料分享
  • 分享用MongoDB中oplog机制实现数据监控实例
  • 详细介绍MongoDB常用的操作
  • mongoDB是怎么实现分页的?

相关文章

  • 2017-05-11与MSSQL对比学习MYSQL的心得(六)--函数
  • 2017-05-11Ubuntu 设置开放 MySQL 服务远程访问教程
  • 2017-05-11MySQL定时执行脚本(计划任务)命令实例
  • 2017-05-11修改Innodb的数据页大小以优化MySQL的方法
  • 2018-12-05Mysql索引的实现原理
  • 2017-05-11mysql insert if not exists防止插入重复记录的方法
  • 2018-12-05图文详解MySql中的事务
  • 2018-12-05自动清理MySQL 的Lock 进程的脚本
  • 2018-12-05Mysql数据库服务器安装与配置教程
  • 2018-12-05MySQL入门之一次函数调用执行多条语句

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MYSQL不能从远程连接的一个解决方法(s not allowed to connect t
    • 不同数据库之间导入导出功能介绍
    • MySQL数据库如何解决无法被其他ip访问的方法
    • MSSQL 检查所使用的语句是否符合标准
    • 提升SQL Server速度 整理索引碎片
    • mysql 5.7.11 winx64快速安装配置教程_MySQL
    • 关于mysql索引长度的相关内容总结
    • 一个字段同时满足多个条件的查询
    • 基于mysqldump搭建gtid主从
    • Oracle Portal及其门户网站开发概述

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有