MongoDB概要 [关于MongoDB] 官方网站: MongoDB属于比较典型的NoSql数据库。和Relationship数据库相比,其数据属于文档结构。 最新版本的MongoDB为2.2.2 不支持WindowsXP [C#官方驱动程序] GitHub:https://github.com/mongodb/mongo-csharp-driver [管理工
MongoDB概要
[关于MongoDB]
官方网站:
MongoDB属于比较典型的NoSql数据库。和Relationship数据库相比,其数据属于文档结构。
最新版本的MongoDB为2.2.2 不支持WindowsXP
[C#官方驱动程序]
GitHub:https://github.com/mongodb/mongo-csharp-driver
[管理工具]
这里选用本人自制的可视化管理工具作为教程的演示工具。
大声呼吁:有兴趣的同志,加入这个工具的开发
下载地址:
GitHub: https://github.com/magicdict/MagicMongoDBTool
[建立第一个空数据库]
关于MongoDB的安装,香港服务器,已经有很多文章介绍了。
这里推荐CNBLOGS网友 百灵 的Mongodb之(初识如故)
安装这篇文章,应该可以正确安装MongoDB,其实就是下载和解压,完全绿色软件。
这个系列的教程,我将MongoDB解压到:C:\runmongo,可执行文件则都在C:\runmongo\bin下面。
新建一个MongoDB实例的方法很多,这里我新建了一个BAT文件,在BAT文件里面写了3句命令:
第一句:将执行目录切换到Mongo可执行目录
第二句:新建一个目录,MongoDB实例需要一个存放文件的目录,这里我选择新建一个C:\mongodb\magicdict 目录
第三句,则是新建一个MongoDB实例,同时,将MongoDB实例的侦听端口设置为 28030
关于MongoDB的启动参数,推荐 咫尺天涯的文章:mongodb启动参数
1 cd C:\runmongo\bin 2 mkdir C:\mongodb\magicdict 3 mongod --port 28030 --dbpath C:\mongodb\magicdict --rest
如果成功的话,将会有一个黑色的DOS控制台出现。当然,这个控制台只是日志输出,无法操作。你也可以将日志存放到一个文件里面。
这个时候去查看 C:\mongodb\magicdict,系统自动添加了一个 mongod.lock 锁文件。
接下来,启动可视化工具,看看数据库吧。
第一次启动时候,选择语言:
由于某些功能需要使用mongo的可执行文件,在可执行文件里面选择可执行文件路径
下面是连接管理界面,里面列出了所有现存的连接
单击添加按钮
由于是最简单的数据库,我们只需要填写 连接名称,主机,端口号即可。
连接名称:这个可以使任意字符,是便于用户记忆的。
主机:这里填写服务器的IP地址,这里使用 localhost 表示本机
端口:28030
这里你可以先使用 [测试] 按钮,检验一下设置是否正确。如果没有问题,则可以[添加]连接。
选中刚才建立的连接,按下[确定]按钮。则进入主界面。
界面左边的是当前连接(MongoDB实例)中所包含的数据库对象。当然,这个连接里面只是单纯的数据库。除了有一个系统自动生成的local数据库以外,什么都没有。
界面右边的是当前连接的状态信息。 关于这些状态信息,你可以参看官方的帮助文档:
一般来说,我们不会在local系统目录里面添加数据,一般都会新建一个数据库来保存用户数据。
当然,你可以 选中Connection节点,然后用主菜单或者右键菜单来 [新建数据库]。不过,这里将演示如何使用C#来创建数据库,添加数据。
1 using System;
2 using System.Collections.Generic;
3 using System.Linq;
4 using System.Text;
5 using MongoDB.Driver;
6 using MongoDB.Bson;
7 using MongoDB.Driver.GridFS;
8 using MongoDB.Bson.Serialization.Attributes;
MagicMongoDBTool.Module
11 {
InitTestData
13 {
User
15
{
16
[BsonId]
17
public String ID;
)]
19
public String Name;
20
public Byte Age;
21
public Byte Age2;
22
public Byte Age3;
23
public Address address;
24
}
Address
26
{
27
public String street;
28
public String City;
29
public String state;
Zip;
31
32
}
GeoObject
34
{
35
[BsonId]
36
public String ID;
[] Geo;
38
}
TLLObject
40
{
41
[BsonId]
42
public String ID;
43
public DateTime CreateDateTime;
Game;
45
}
FillDataForGeoObject(MongoServer mongosvr)
47
{
);
);
50
mongoCol.RemoveAll();
51
Random Ro = new Random();
(int i = 0; i 1000; i++)
54
{
55
mongoCol.Insert(new GeoObject()
56
{
57
ID = i.ToString(),
58
Geo = new int[2] { Ro.Next() % 180, Ro.Next() % 180 }
});
61
}
62
}
FillDataForTTL(MongoServer mongosvr)
64
{
);
);
67
mongoCol.RemoveAll();
68
Random Ro = new Random();
(int i = 0; i 1000; i++)
71
{
72
mongoCol.Insert(new TLLObject()
73
{
74
ID = i.ToString(),
75
CreateDateTime = System.DateTime.Now.AddSeconds(i),
76
Game = Ro.Next()
77
});
78
}
79
}
FillDataForUser(MongoServer mongosvr)
81
{
);
);
85
mongoJsCol.Insert
这里我新建了一个mongodb的数据库,同时新增了3个演示用数据集(collection)。
具体的操作方法,推荐 码农的文章: MongoDB的C#驱动程序教程(译)
这里有非常详细的C#操作数据库的解释。全部是官方文档的翻译,可能是机器翻译的,但是对于英语不好的同志来说,有一定帮助。
当然,如果你的英语还可以,原汁原味的在这里:+Driver+Tutorial
MongoDB的对象存取,代码看上去有点ORM的味道,不过,由于MongoDB已经是阶层数据库了,完全不需要将Object进行映射(Map),而是直接存取到数据库中。
在简单类的时候,由于数据结构只是二维表格,这种优势不是很明显。在复杂类的时候,出现层次结构的时候,则效果非常明显。
下图则通过[树形视图]来直观展示了复杂阶层的类。
关系型数据库,需要将User数据和Address数据放在两张表中,然后用主键连接成视图。
阶层型数据库,香港服务器,则已经将User和Address信息放在一个文档(Document,类似于记录的概念)里面。
(当然,关系型的好处也非常明显,可以减少数据冗余,灵活性也非常好。阶层型数据库在编码上,可能更加贴近OOP)
[索引-TTL索引]
索引都是为了检索的性能而生的,MongoDB的索引也不例外。
TTL(TimeToLive)索引(MongoDB2.2.2新增)和地理位置索引(“2d”)则是MongoDB的特色。
TTL索引,索引对象是一个日期型字段,然后需要设定一个有效时间。通过监视 日期型字段的值和当前系统时间,参考有效时间,判断是否数据过期,对于过期的数据则自动删除。
这个特性对于自动删除日志这样的操作来说,将非常有用。例如我们可以对于 日志创建时间 进行索引,同时设定过期时间为 3600秒,这样系统将自动删除一个小时之前的日志。
这里我们准备了TTL这样的一个数据集:
数据集里面包含了一个CreateDateTime的日期型字段,里面存放着建立记录的时间。
接着我们选中数据集,通过索引管理器建立索引。
我们将对于CreateDateTime建立所以,同时设定有效时间为180秒。
这样的话,如果CreateDateTime和系统时间相差180秒,则记录将会被自动删除。
1.TTL索引必须建立在日期型字段(或者日期型字段数组)
2.不能建立在复杂索引上
3.你不能在 _id或者任何一个已经存在索引的字段上建立TTL索引
TTL索引的官方说明:
注意上面这张图的左边,显示了数据集的索引信息:
AutoDelete的索引过期时间为180秒。而默认的索引_id,则没有设定过期时间。
同时,里面的数据已经全部被系统自动删除掉了。
[索引-GEO索引]
如果,你的数据集里面有一个地理位置字段(所谓的地理位置字段,是一个数组,数组里面有两个数字,数字的范围是 [-180,180])。
例如,下面的Geo字段,就是一个地理位置字段。
我们可以对于地理位置字段,进行“2d”索引,美国空间,或者说是Geo索引。
观察一下索引类型:这里显示的是 “2d”,表示这是一个Geo地理索引
建立过地理索引的数据集,可以进行GeoNear查询。
官方文档:
GeoNear的意思就是:查询一下,指定的坐标附近,有那些记录。
你可以指定: 1.需要查询多少个最邻近的记录。
2.你可以限制最大的距离。
3.由于地理坐标的单位是弧度【-180,180】,有时候你需要将距离放大一些,你可以指定距离乘积
4.Spherical(球形)
下面我们要查询离坐标 【100,100】,距离在10以内的记录,我们限制最多查询100个记录。
并且我们不需要系统对于距离进行放大或者缩小的处理。
查询结果:我们扫描了23个记录(由于有索引,所以不需要扫描全部记录),扫描时间为0
符合条件的记录有6个,平均距离为 6.34 最大距离为 9.21
每条记录的详细信息都可以在结果里面看到。

MySQLインデックスのカーディナリティは、クエリパフォーマンスに大きな影響を及ぼします。1。高いカーディナリティインデックスは、データ範囲をより効果的に狭め、クエリ効率を向上させることができます。 2。低カーディナリティインデックスは、完全なテーブルスキャンにつながり、クエリのパフォーマンスを削減する可能性があります。 3。ジョイントインデックスでは、クエリを最適化するために、高いカーディナリティシーケンスを前に配置する必要があります。

MySQL学習パスには、基本的な知識、コアの概念、使用例、最適化手法が含まれます。 1)テーブル、行、列、SQLクエリなどの基本概念を理解します。 2)MySQLの定義、作業原則、および利点を学びます。 3)インデックスやストアドプロシージャなどの基本的なCRUD操作と高度な使用法をマスターします。 4)インデックスの合理的な使用や最適化クエリなど、一般的なエラーのデバッグとパフォーマンス最適化の提案に精通しています。これらの手順を通じて、MySQLの使用と最適化を完全に把握できます。

MySQLの実際のアプリケーションには、基本的なデータベース設計と複雑なクエリの最適化が含まれます。 1)基本的な使用法:ユーザー情報の挿入、クエリ、更新、削除など、ユーザーデータの保存と管理に使用されます。 2)高度な使用法:eコマースプラットフォームの注文や在庫管理など、複雑なビジネスロジックを処理します。 3)パフォーマンスの最適化:インデックス、パーティションテーブル、クエリキャッシュを使用して合理的にパフォーマンスを向上させます。

MySQLのSQLコマンドは、DDL、DML、DQL、DCLなどのカテゴリに分割でき、データベースとテーブルの作成、変更、削除、データの挿入、更新、削除、複雑なクエリ操作の実行に使用できます。 1.基本的な使用には、作成可能な作成テーブル、INSERTINTO INSERTデータ、クエリデータの選択が含まれます。 2。高度な使用法には、テーブル結合、サブQueries、およびデータ集約のためのグループに参加します。 3.構文エラー、データ型の不一致、許可の問題などの一般的なエラーは、構文チェック、データ型変換、許可管理を介してデバッグできます。 4.パフォーマンス最適化の提案には、インデックスの使用、フルテーブルスキャンの回避、参加操作の最適化、およびデータの一貫性を確保するためのトランザクションの使用が含まれます。

INNODBは、ロックメカニズムとMVCCを通じて、非論的、一貫性、および分離を通じて原子性を達成し、レッドログを介した持続性を達成します。 1)原子性:Undologを使用して元のデータを記録して、トランザクションをロールバックできることを確認します。 2)一貫性:行レベルのロックとMVCCを介してデータの一貫性を確保します。 3)分離:複数の分離レベルをサポートし、デフォルトでrepeatable -readが使用されます。 4)持続性:Redologを使用して修正を記録し、データが長時間保存されるようにします。

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

MySQLは、中小企業に適しています。 1)中小企業は、顧客情報の保存など、基本的なデータ管理にMySQLを使用できます。 2)大企業はMySQLを使用して、大規模なデータと複雑なビジネスロジックを処理して、クエリのパフォーマンスとトランザクション処理を最適化できます。

INNODBは、次のキーロックメカニズムを通じてファントムの読み取りを効果的に防止します。 1)Next-KeyLockingは、Row LockとGap Lockを組み合わせてレコードとギャップをロックして、新しいレコードが挿入されないようにします。 2)実際のアプリケーションでは、クエリを最適化して分離レベルを調整することにより、ロック競争を削減し、並行性パフォーマンスを改善できます。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
