C# Asp.net中简单操作MongoDB数据库(一)    , mongodb数据库连接可以回顾上面的篇幅。

1、model类:
   public class BaseEntity
{
/// <summary>
/// 字段映射,告诉mongodb这个字段在数据库中对应_id
/// </summary>
[BsonId]
//告诉mongodb这个字段在数据库中的类型是ObjectId
[BsonRepresentation(BsonType.ObjectId)]
public string _id { get; set; }
} public class IPInfo : BaseEntity
{
public string ip { get; set; } public string ipAddress { get; set; } public string addTime { get; set; }
} public class IPDetails : BaseEntity
{
/// <summary>
/// 主表id
/// </summary>
[BsonRepresentation(BsonType.ObjectId)]
public string parentId { get; set; }
public string ipAddress { get; set; }
public string ipNetwork { get; set; }
public string ipBrowser { get; set; }
public string addTime { get; set; }
} 自定义实体类
2、基本操作:
public class IPInfoFactory
{
/// <summary>
/// 集合(表)名称
/// </summary>
private static readonly string CollectionName = "IPInfo"; //ip子表名称
private static readonly string ChildCollectionName = "IPDetail"; private static IMongoDatabase db = MongoDb.GetMongoDb(); public static List<IPInfo> GetAllList()
{
try
{
var collection = db.GetCollection<IPInfo>(CollectionName);
List<IPInfo> list = collection.Find(new BsonDocument()).ToList();
return list;
}
catch (Exception ex)
{
return null;
}
} /// <summary>
/// 插入主表
/// </summary>
/// <returns></returns>
public static bool Add(string ip, string ipAddress)
{
try
{
var IPInfoCollection = db.GetCollection<IPInfo>(CollectionName);
IPInfo ipInfo = new IPInfo();
ipInfo.ip = ip;
ipInfo.ipAddress = ipAddress;
ipInfo.addTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss:fff");
IPInfoCollection.InsertOne(ipInfo); return true;
}
catch (Exception ex)
{
return false;
}
} /// <summary>
/// 插入主表、子表:
/// 主表:有则不插入,无则插入;
/// 子表:一条数据都没有,则插入,已经存在数据,判断是否存在一条相同数据,存在则不插入,不存在则插入。
/// </summary>
/// <param name="ip">ip</param>
/// <param name="model">ip接口获取的信息</param>
/// <param name="ipBrowser">浏览器</param>
/// <returns></returns>
public static bool AddIPInfoAndDetail(string ip, ApiIPInfo model, string ipBrowser = "")
{
try
{
//ip地址
var ipAddress = model.Address;
//ip网络
var ipNetwork = model.Network; var IPInfoCollection = db.GetCollection<IPInfo>(CollectionName);
var IPDetailCollection = db.GetCollection<IPDetails>(ChildCollectionName); //判断主表是否已经存在
var pFilter = Builders<IPInfo>.Filter.Eq("ip", ip);
var parentItem = IPInfoCollection.Find(pFilter).FirstOrDefault();
if (parentItem == null)
{
//插入主表
IPInfo ipInfo = new IPInfo();
ipInfo.ip = ip;
ipInfo.ipAddress = ipAddress;
ipInfo.addTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss:fff");
IPInfoCollection.InsertOne(ipInfo); //插入子表
string parent_id = string.Empty;
//刚插入的主表
var parentItemNew = IPInfoCollection.Find(pFilter).FirstOrDefault();
if (parentItemNew != null)
{
parent_id = parentItemNew._id;
AddChild(parent_id, ipAddress, ipNetwork, ipBrowser);
}
}
else
{
string parent_id = parentItem._id;
var childFilter1 = Builders<IPDetails>.Filter.Eq("parentId", parent_id);
var childItem = IPDetailCollection.Find(childFilter1).FirstOrDefault();
if (childItem == null)
{
AddChild(parent_id, ipAddress, ipNetwork, ipBrowser);
}
else
{
//如果没有类似的数据,则插入
var filterBuilder = Builders<IPDetails>.Filter;
var childFilter2 = filterBuilder.Eq("parentId", parent_id)
& filterBuilder.Regex("ipNetwork", new BsonRegularExpression(new Regex(ipNetwork)))
& filterBuilder.Regex("ipBrowser", new BsonRegularExpression(new Regex(ipBrowser)));
var childItem2 = IPDetailCollection.Find(childFilter2).FirstOrDefault();
if (childItem2 == null)
{
AddChild(parent_id, ipAddress, ipNetwork, ipBrowser);
}
}
} return true;
}
catch (Exception ex)
{
return false;
}
} /// <summary>
/// 插入子表
/// </summary>
/// <returns></returns>
public static bool AddChild(string parentId, string ipAddress, string ipNetwork, string ipBrowser)
{
try
{
var IPDetailCollection = db.GetCollection<IPDetails>(ChildCollectionName);
IPDetails ipDetails = new IPDetails();
ipDetails.parentId = parentId;
ipDetails.addTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss:fff");
ipDetails.ipAddress = ipAddress;
ipDetails.ipNetwork = ipNetwork;
ipDetails.ipBrowser = ipBrowser;
IPDetailCollection.InsertOne(ipDetails); return true;
}
catch (Exception ex)
{
return false;
}
} /// <summary>
/// 插入子表
/// </summary>
/// <returns></returns>
public static bool AddChild(IPDetails model)
{
try
{
var IPDetailCollection = db.GetCollection<IPDetails>(ChildCollectionName);
IPDetails ipDetails = new IPDetails();
ipDetails.parentId = model.parentId;
ipDetails.addTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss:fff");
ipDetails.ipAddress = model.ipAddress;
ipDetails.ipNetwork = model.ipNetwork;
ipDetails.ipBrowser = model.ipBrowser;
IPDetailCollection.InsertOne(ipDetails); return true;
}
catch (Exception ex)
{
return false;
} }
}

C# Asp.net中简单操作MongoDB数据库(二)的更多相关文章

  1. C# Asp.net中简单操作MongoDB数据库(一)

    需要引用MongoDB.Driver.dll.MongoDB.Driver.core.dll.MongoDB.Bson.dll三个dll. 1.数据库连接: public class MongoDb ...

  2. Python学习笔记_03:简单操作MongoDB数据库

    目录 1. 插入文档 2. 查询文档 3. 更新文档 4. 删除文档   1. 插入文档 # -*- coding: UTF-8 -*- import datetime from pymongo im ...

  3. C#中简单操作Mysql数据库

    以C#访问MySQL数据库,执行简单的CRUD. MySql.Data.dll是C#操作MySQL的驱动文件,是C#连接MySQL必要插件,使C#语言更简洁的操作MySQL数据库.可以用NuGet命令 ...

  4. C#中简单操作SQLserver数据库(ADO.NET的简单应用)

    本篇文章以 ADO.NET 访问SQL SERVER 数据库为例, 其中需用System.Data.SqlClient; 数据库连接字符串写法为:server=数据源(服务器名称);uid=用户名;p ...

  5. nodeJS中使用mongoose模块操作mongodb数据库

    在实际运用中,对于数据库的操作我们不可能一直在cmd命令行中进行操作,一般情况下需要在node环境中来操作mongodb数据库,这时就需要引入mongoose模块来对数据库进行增删改查等操作. 首先, ...

  6. python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用

    python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...

  7. JAVA操作MongoDB数据库

    1. 首先,下载MongoDB对Java支持的驱动包 驱动包下载地址:https://github.com/mongodb/mongo-java-driver/downloads 2.Java操作Mo ...

  8. PHP操作MongoDB 数据库

    最近有个项目,需要用php操作mongoDb数据,整理如下 1,连接MongoDB数据库 $conn = new Mongo(); 其他链接方式 //$conn=new Mongo(); #连接本地主 ...

  9. mongoose之操作mongoDB数据库

    mongoose是node.js操作mongoDB数据库的一种工具,借助于mongoose,我们可以便捷的完成一些数据库的基本操作,基本使用如下: 1.安装 npm install mongoose ...

随机推荐

  1. 解决jenkins构建job报错“NoClassDefFoundError” in jenkins/scm/RunWithSCM问题

    现象 使用Jenkins 2.8,当我运行一个简单的Jenkins工作时,构建一个job获取源代码,出现下面的错误 FATAL: jenkins/scm/RunWithSCM java.lang.No ...

  2. activiti工作流笔记

    什么是activiti? Activiti是一个身经百战的业务流程管理引擎, 并且还是一个流程平台 为什么要用工作流引擎? 简单来说,就是为了统一管理流程业务. 想想看,如果要设计一个流程的程序,通常 ...

  3. vue-创建新项目

    1.安装node,下载地址:https://nodejs.org/en/download/ 2.安装完成后打开cmd,输入node-v,出现版本信息说明安装成功 3.输入npm install -g ...

  4. Java 模拟http请求

    package ln; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamRea ...

  5. matplotlib坐标轴设置续-【老鱼学matplotlib】

    本次会讲解如何修改坐标轴的位置. 要修改轴,就要先得到当前轴:plt.gca(),这个函数名挺怪的,其实是如下英文字母的首字母:get current axis,也就是得到当前的坐标轴. import ...

  6. sort实现ip排序

    说明: 工具:sort linux自带        ”-t” : 表示以那个字符做分割        “-k” :和-t结合使用,表示取那一段为关键字进行排序,后面跟数据,1…n,表示取第几段,也可 ...

  7. js 在echarts多条折线图数字*100 诡异出现小数

    formatter:function(params){ //数据单位格式化 ].name; //x轴名称 , l = params.length; i < l; i++) { if(params ...

  8. pycharm中连接公网IP方法

    我们的公网IP可以加到pycharm里面,这样程序跑的时候,在测试过程中就用pycharm直接修改文件,然后在pycharm里面上传,操作更加便捷 在pycharm中找到tool按钮,在菜单栏里面 然 ...

  9. PostgreSQL自学笔记:7 插入、更新与删除数据

    7 插入.更新与删除数据 7.1 插入数据 先创建表person: create table person( id int not null, name char(40) not null defau ...

  10. Understanding HBase and BigTable

    Hbase is a distributed data storage systems. A Bigtable is spare , distributed , persistent multidim ...