c#开发Mongo笔记第四篇

今天是个伟大的日子,不得不说小苹果的歌词真是深入人心啊。

不过今天伟大并不是因为我种下一颗种子,而是我从今天不再写demo,而是进入项目的正式开发当中,毕竟项目时间有限(想必各位码农也都深有体会吧),边开发边探索吧。

既然是刚刚开始,就先搭了一下系统框架,然后,做了一个登陆功能,和一个登陆日志功能

public  class Log
    {
        public ObjectId Id { get; set; }

        public string Abstract { get; set; }

        public string Description { get; set; }

        public DateTime CreateTime { get; set; }

        public string IPAddress { get; set; }

        public string OS { get; set; }

        public string BrowserVersion { get; set; }

        public string UserHostName { get; set; }

        public string RequestUrl { get; set; }

        public User User { get; set; }
    }

经过考虑,我觉得把用户对象当初冗余存在日志表中,当然了用户表还是存在的,只不过是查询日志的时候避免联查带来的不便,存储的结构式这样的。

 public  class User
    {
        public ObjectId _id { get; set; }
        public string UserName { get; set; }

        public string Password { get; set; }

        public Guid CustomID { get; set; }
    }

其实这个id写成_id而没有遵循驼峰命名法也是很不规范的,之所以这么写,是因为查询的时候要转换成对象的话必须完全匹配,不然的话会报错,所以不得不写了这么一个奇怪的属性。

要是大家有什么号的建议还希望能够多多指教。

然后就是用户的登陆功能了,用户我打算写一个数据访问层,目前先写了两个方法

 public class DALUser
    {
        public static User GetById(ObjectId id)
        {
            MongoDatabase db = MongoHelper.GetConnection();
            MongoCollection collection = db.GetCollection<User>("User");
            var list = collection.FindAllAs<User>();
            return list.FirstOrDefault(u => u._id== id);
        }
        public static User GetByName(string name)
        {
            MongoDatabase db = MongoHelper.GetConnection();
            MongoCollection collection = db.GetCollection<User>("User");
            var list = collection.FindAllAs<User>();
            return list.FirstOrDefault(u => u.UserName == name);
        }
    }

登陆的时候就直接先根据名称查出这个用户对象再比较密码,其实和以前访问sqlserver一样了

日志的存储我用了一个通用的方法

   public static void Add(object o)
        {
            MongoDatabase db = GetConnection();
            Type type = o.GetType();
            MongoCollection collection = db.GetCollection<Type>(type.Name);
            collection.Insert(o);
        }

所以的对象存储都调用这个函数,其实删,改,查本来也想写通用的函数的,但是没想到好的写法呢,就先分开写,以后再探索吧。

总之,c#操作mongo之旅今天是正式开始了

时间: 2024-10-11 23:18:46

c#开发Mongo笔记第四篇的相关文章

c#开发Mongo笔记第八篇

到今天为止,Mongo开发的权限管理系统功能就做完了,剩下的就是完善构架,优化结构,只是现在c#操作Mongo的各种操作基本都掌握了 说到权限管理系统,其实再简单不过了,在关系型数据的是时代,我们通常建一个菜单表,菜单用内建来管理子菜单,然后再建一个角色表(或用户表),然后再建一个角色和菜单的对应关系表,存上菜单id和角色id的对应关系.当然了,方法很多,我只是 举了一个相对比较常见的设计方式. 用上Mongo之后我本来照搬以前的设计思路,完成了权限管理,完成之后突然觉得这样不太好吧.比较Mon

c#开发Mongo笔记第六篇

之前写的五篇比较得到了大家的积极反馈,也有个别高手对我写我写出的代码进行了指教. 其中提到的我写的查询方法性能有问题,我想了想,如果mongo不是延时加载的话,那我的查询就真的有问题了,就成了查询出来所有的数据再进行二次筛选了. 可能这也是之前总是使用entity framework框架导致的习惯性这么写了吧.今天赶紧进行了一下代码,现在贴出来一下,省的之前的错误写法误导了大家,再此也感谢大家对我的批评指正 public static User GetById(ObjectId id) { Mo

c#开发Mongo笔记第七篇

开发到这里遇到了一些问题,哪到这里想请教一下大家 今天我完成的是菜单功能, public class Menu { public ObjectId _id { get; set; } public int MenuId { get; set; } public string Name { get; set; } public int ParentId { get; set; } public string Url { get; set; } public string Icon { get; s

c#开发Mongo笔记第三篇

今天主要测试了一下查询功能了,当然了主要还是为了让查询可以和我们平时使用的实体对象关联起来,并且 那些BsonDocument和Collection我们操作起来不是太方便的 还是首先定义了一个用户类,注意这个类需要和mongo中的对象的字段完全匹配,包括大小写,不然查询的时候会出现字段无法匹配的错误 public class User { public ObjectId Id { get; set; } public string Name { get; set; } public int Ag

c#开发Mongo笔记第五篇

现在增删查改算是都完成了,但是查询算是有点不完美的,相信现在用juqeryeasyui这一类的插件的人应该也不少吧,这样的话前台展示需要JSON格式的数据, 好在mogno驱动提供toJson()的函数,但是却无法在前台显示,不知道是不是objectid导致的,下面是我通过firebug看到的请求数据. {"total":"2","rows":[{ "_id" : ObjectId("545c395937d9dc8a

spss C# 二次开发 学习笔记(四)——Spss授权

Spss的授权方式有两种,单机版和网络版. Spss的激活,在联网的情况下,通过20位的激活码激活,在未联网的情况下,Spss根据机器获取一个类似4-XXXX的锁定码,然后由激活码和锁定码算出一个授权码,来激活程序. 整个激活过程,可以在IBM网站上处理,申请一个单号,然后注册,然后逐步操作,也可以直接打服务电话,由IBM相关人员帮助处理. 网络版的授权模式为,在证书服务器上安装证书授权管理程序,然后客户机通过证书服务器进行授权,允许在任意客户机上安装Spss并授权,但并发数目收到购买的数量的限

c#开发Mongo笔记第二篇

写到第二篇不得不说是我之前犯了一个小错误,其实实现子表存储也是很简单的事,先说我想实现什么样的效果吧 就是用户表里有个成绩字段,成绩字段是个子表 其实实现这个功能也很简单,用面向对象的思想很好理解,子表就是user表的一个对象字段或者集合字段,所以我觉得用c#开发Mongo用面向对象的思想开发更合适一些 public class User { public ObjectId Id { get; set; } public string Name { get; set; } public stri

c#开发Mongo笔记第一篇

转 :http://www.cnblogs.com/bjjjunjie/p/4076177.html 现在开发的这个项目要用mongo数据库开发,发现网上的这方面教程还是比较少的,只能边看官方说明边进行开发,再开发过程中写下笔记,也算上是一个总结吧. 我开发使用的是vs2013了,驱动用的是最新的1.9.2版本的 网上连接数据库的教程一搜一大堆,我就不多赘述了,只一个写一个连接数据库的方法吧 1 protected void GetConnection() 2 { 3 4 //定义Mongo服务

c#开发Mongo笔记第九篇

用skip略过少量的文档还是不错的.但是要是数量非常多的话,skip就会变得很慢,因为要先找到需要被略过的数据,然后再抛弃这些数据.大多数数据库都会在索引中保存更多的元数据,用于处理skip, 但是mongoDB目前还不支持,所以要尽量避免略过太多的数据 .通常可以利用上次的结果来计算下一次的查询条件. 最简单的分页方法就是用limit返回结果的第一页,然后将每个后续页面作为相对开始的偏移量返回. 比如var page1=db.Log.find(query).skip(100).limit(10