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. linux 乌班图 lnmp环境搭建

    1.#安装Apache2,目前163的源是2.2.22版本02.sudo apt-get install apache203. 04.#安装MySQL,目前163的源是5.5.24版本05.apt-g ...

  2. TF-tf.arg_max 介绍

    定义为 def arg_max(input, dimension, name=None) 作用是取行或者列的最大值的位置. input:类型为 float32, float64, int64, int ...

  3. js定义数组集合

    简单描述:最近脑子有点抽,js要用到数组,竟然傻傻的写了 var [] str = .简直是糟糕的不要不要的 //js代码var str = [];var str =new Array(); 啥也不说 ...

  4. mac os app 开发

    macOS 新手开发:第 1 部分 macOS 新手开发:第 2 部分 macOS 新手开发:第 3 部分

  5. Windows Internals 笔记——内核对象

    1.每个内核对象都只是一个内存块,它由操作系统内核分配,并只能由操作系统内核访问.这个内存块是一个数据结构,其成员维护着与对象相关的信息. 2.调用一个会创建内核对象的函数后,函数会返回一个句柄,它标 ...

  6. ERROR: invalid byte sequence for encoding "UTF8": 0x00

    1.使用kettle批量导入数据的时候,数据出现了下面的错误.ERROR: invalid byte sequence for encoding "UTF8": 0x00 关键点: ...

  7. Android+openCV 的坑

    之前一直用IntelliJ IDEA 导入 opencv_android_sdk 的 java 包,在最后一步finish时,始终出错. 后来重新安装Android Studio 重复以上步骤,能顺利 ...

  8. java 安装以及配置

    1.下载 JDK 下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index-jsp-138363.html 2.环境变量配 ...

  9. Scala变量| 流程控制

    Scala 是 Scalable Language 的简写,是一门多范式(编程的方式)的编程语言 Scala是一门以java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程的最佳特性结合在一起的 ...

  10. IMCASH:看着朋友赚钱进币圈 我凭啥亏钱? 4月29日币圈报告

    即将过去的四月份,币圈的行情总体是不错的,比特从4000附近最高涨到了5600以上的位置,当前也在5200左右,而成交量更是创出历史天量(4月3日,全球加密货币市场的交易量达890亿美元,创历史天量) ...