ホームページ データベース mysql チュートリアル Mongodb基础入门(3)排序和索引

Mongodb基础入门(3)排序和索引

Jun 07, 2016 pm 04:13 PM
mongodb はじめる ベース 選別 索引

今天继续Mongodb,简单的记录下其排序和索引的使用。 在Mongodb中使用sort()方法对数据进行排序。 命令格式:db.collectionName.find().sort({key:参数}) 参数说明: -1:表示降序 1:表示升序(默认) doc集合中数据如下: db.doc.find({},{_id:0,goods_id:1

今天继续Mongodb,简单的记录下其排序和索引的使用。

在Mongodb中使用sort()方法对数据进行排序。

命令格式:db.collectionName.find().sort({key:参数})

参数说明:

-1:表示降序

1:表示升序(默认)

doc集合中数据如下:

> db.doc.find({},{_id:0,goods_id:1})

{ "goods_id" : 1 }

{ "goods_id" : 4 }

{ "goods_id" : 3 }

{ "goods_id" : 5 }

{ "goods_id" : 6 }

{ "goods_id" : 7 }

{ "goods_id" : 8 }

{ "goods_id" : 9 }

{ "goods_id" : 10 }

{ "goods_id" : 11 }

{ "goods_id" : 12 }

> db.doc.find({},{_id:0,goods_id:1}).sort({goods_id:1})

\

 

索引

1、 简介

和mysql数据类似,为了提高查询效率,Mongodb也提供索引的支持。在Mongodb中,索引可以按照字段进行升序/降序来创建,以便于排序。当然,Mongodb默认采用B-tree方式来索引。

按索引作用类型可分为:

1、 单列索引:在单个键上创建索引。

2、 组合索引:在多个键上同时创建索引,也叫多列索引。

3、 文档索引:任何类型,包括文档(document)都可以作为索引。

索引的性质可以分:

1、 普通索引:普通方式创建的索引。注意:Mongodb存在默认的_id的键,相当于主键。集合在创建之后,系统会自动在_id创建索引,该索引为系统默认,无法删除。

2、 唯一索引:某列为唯一索引时,不能添加重复文档。注意,如果文档不存在指定字段时,会将该字段默认为null,而null也会被认为重复。

3、 稀疏索引:和稀疏矩阵类似,稀疏索引就是将含有某个字段的文档进行索引,不包含该字段的文档则进行索引。一般在小部分文档含有某列时常用。

4、 哈希索引:2.4版本新增的索引方式。相比于普通索引,其速度更快。但是无法对范围查询进行优化。多用于随机性比较强的散列当中。

2、 查看索引

db.collectionName.getIndexes()

3、 创建索引

A、 创建普通单列索引:默认是升序索引,采用B-tree方式

db.collectionName.ensureIndex({field:1/-1})//1:升序;-1:降序

B、 创建多列索引:

db.collectionName.ensureIndex({field1:1/-1,field2:1/-1})

C、 创建文档索引:

A)创建普通文档索引

db.collectionName.ensureIndex({filed:1/-1})

> db.users.insert({name:"god",info:{city:"NewYork",state:"happy"}})

WriteResult({"nInserted" : 1 })

>db.users.ensureIndex({info:1})//将整个info文档作为索引

{

"createdCollectionAutomatically" : false,

"numIndexesBefore" : 1,

"numIndexesAfter" : 2,

"ok" : 1

}

>db.users.getIndexes()

[

{

"v" : 1,

"key" : {

"_id" : 1

},

"name" : "_id_",

"ns" : "test.users"

},

{

"v" : 1,

"key" : {

"info" : 1

},

"name" : "info_1",

"ns" : "test.users"

}

]

注意:在使用索引查询的时候需要按照事先文档字段的顺序。

> db.users.find({info:{city:"NewYork",state:"happy"}})//能够利用索引查到结果

{ "_id" :ObjectId("54a79a1bc289fc3b6fcc719a"), "name" :"god", "info" : { "city

" : "NewYork", "state" : "happy" } }

 

>db.users.find({info:{$gte:{city:"New York"}}})//能够利用索引查到结果

{ "_id" :ObjectId("54a79a1bc289fc3b6fcc719a"), "name" :"god", "info" : { "city

" : "NewYork", "state" : "happy" } }

 

>db.users.find({info:{state:"happy",city:"New York"}})//不能利用索引查到结果

 

B)创建子文档索引

db.collectionName.ensureIndex({filed.subfield:1/-1})

> db.users.ensureIndex({"info.city":1})

{

"createdCollectionAutomatically" : false,

"numIndexesBefore" : 1,

"numIndexesAfter" : 2,

"ok" : 1

}

>db.users.getIndexes()

[

{

"v" : 1,

"key" : {

"_id" : 1

},

"name" : "_id_",

"ns" : "test.users"

},

{

"v" : 1,

"key" : {

"info.city" : 1

},

"name" : "info.city_1",

"ns" : "test.users"

}

]

 

D、创建唯一索引:可以针对多列创建唯一索引

db.collectinName.ensureIndex({filed.subfield:1/-1},{unique:true})

E、创建稀疏索引:

db.collectionName.ensureIndex({filed:1/-1},{sparse:true})

F、 创建哈希索引:可以对单个字段或字文档建立hash索引,不能针对多个列。

db.collectionName.ensureIndex({field:”hash”})

 

4、 删除索引

A、删除单个索引:

db.collectionName.dropIndex({filed:1/-1})

B、删除所有索引:_id列的索引不会删除。

db.collectionName.dropIndexes()

注意:在关系数据库中,表被删除后,索引随之删除。

而在Monodb中删除集合,索引仍然存在,因此需要手动删除索引。

 

5、 重建索引

一个集合在经过多次修改之后,将会导致集合的文件产生碎片。同样索引文件也会如此。因此可以通过索引的重建来减少索引文件碎片,提高索引效率。和mysql中的optimize table类似。命令:db.collectionName.reIndex().

 

索引的管理

1、查询所有索引:

system.indexes集合中包含了每个索引的详细信息,因此可以通过该命令:

db.system.indexes.find()查询已经存在的索引.

{"v" : 1, "key" : { "_id" : 1 }, "name": "_id_", "ns" : "test.doc" }

{"v" : 1, "key" : { "_id" : 1 }, "name": "_id_", "ns" : "test.category" }

{"v" : 1, "key" : { "_id" : 1 }, "name": "_id_", "ns" : "test.tea" }

{"v" : 1, "key" : { "email" : 1 },"name" : "sparse:1", "ns" : "test.tea"}

{"v" : 1, "key" : { "_id" : 1 }, "name": "_id_", "ns" : "test.users" }

{"v" : 1, "key" : { "info.city" : 1 },"name" : "info.city_1", "ns" :"test.users" }

 

2、查看查询计划:

为了分析查询性能及索引,一边获得更多查询方面有用的信息,可以使用如下命令:

db.collectionName.find(查询表达式).explain()

\

"cursor" :"BasicCursor" ——>表示索引没有发挥作用

"nscanned":1 ——>表示查询了多少个文档。
"n",:1 ——>表示返回的文档数量。
"millis":0 ——>表示整个查询的耗时。

"nscannedObjects" : 11, ——>理论上需要扫描多少行

 

3、后台创建索引

为已有数据的文档创建索引时,为了不阻塞其他操作,同时可以在后台创建索引,可以使用命令:db.test.ensureIndex({filed:1/-1},{"background":true})

相比阻塞创建索引而言,后台创建索引效率较低。

 

 

注意

1、如果数据集合比较小(一般来说是4m一下),此时如果使用sort()进行排序就不需要使用索引。

2、在使用组合索引查询时,查询字段的顺序必须和事先创建索引时的顺序保持一致。否则会出现上文提到的出现查不到的情况。

 

 

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

DebianでMongoDB自動拡張を構成する方法 DebianでMongoDB自動拡張を構成する方法 Apr 02, 2025 am 07:36 AM

この記事では、自動拡張を実現するためにDebianシステムでMongodbを構成する方法を紹介します。主な手順には、Mongodbレプリカセットとディスクスペース監視のセットアップが含まれます。 1。MongoDBのインストール最初に、MongoDBがDebianシステムにインストールされていることを確認してください。次のコマンドを使用してインストールします。sudoaptupdatesudoaptinstinstall-yymongodb-org2。mongodbレプリカセットMongodbレプリカセットの構成により、自動容量拡張を達成するための基礎となる高可用性とデータ冗長性が保証されます。 Mongodbサービスを開始:Sudosystemctlstartmongodsudosys

作曲家を使用して、推奨システムのジレンマを解決する:Andres-Montanez/推奨 作曲家を使用して、推奨システムのジレンマを解決する:Andres-Montanez/推奨 Apr 18, 2025 am 11:48 AM

eコマースのWebサイトを開発するとき、私は困難な問題に遭遇しました。ユーザーにパーソナライズされた製品の推奨事項を提供する方法です。当初、私はいくつかの簡単な推奨アルゴリズムを試しましたが、結果は理想的ではなく、ユーザーの満足度も影響を受けました。推奨システムの精度と効率を改善するために、より専門的なソリューションを採用することにしました。最後に、Andres-Montanez/Adcumentations Bundleを介してAndres-Montanez/Bundleをインストールしました。これは、問題を解決しただけでなく、推奨システムのパフォーマンスを大幅に改善しました。次の住所から作曲家を学ぶことができます。

DebianでMongodbの高可用性を確保する方法 DebianでMongodbの高可用性を確保する方法 Apr 02, 2025 am 07:21 AM

この記事では、Debianシステムで非常に利用可能なMongoDBデータベースを構築する方法について説明します。データのセキュリティとサービスが引き続き動作し続けるようにするための複数の方法を探ります。キー戦略:レプリカセット:レプリカセット:レプリカセットを使用して、データの冗長性と自動フェールオーバーを実現します。マスターノードが失敗すると、レプリカセットが自動的に新しいマスターノードを選択して、サービスの継続的な可用性を確保します。データのバックアップと回復:MongoDumpコマンドを定期的に使用してデータベースをバックアップし、データ損失のリスクに対処するために効果的な回復戦略を策定します。監視とアラーム:監視ツール(プロメテウス、グラファナなど)を展開して、MongoDBの実行ステータスをリアルタイムで監視し、

MongoDBデータベースパスワードを表示するNAVICATの方法 MongoDBデータベースパスワードを表示するNAVICATの方法 Apr 08, 2025 pm 09:39 PM

Hash値として保存されているため、Navicatを介してMongoDBパスワードを直接表示することは不可能です。紛失したパスワードを取得する方法:1。パスワードのリセット。 2。構成ファイルを確認します(ハッシュ値が含まれる場合があります)。 3.コードを確認します(パスワードをハードコードできます)。

Centos Mongodbバックアップ戦略とは何ですか? Centos Mongodbバックアップ戦略とは何ですか? Apr 14, 2025 pm 04:51 PM

MongoDB効率的なバックアップ戦略の詳細な説明CENTOSシステムでは、この記事では、データセキュリティとビジネスの継続性を確保するために、CENTOSシステムにMongoDBバックアップを実装するためのさまざまな戦略を詳細に紹介します。 Dockerコンテナ環境でのマニュアルバックアップ、タイミング付きバックアップ、自動スクリプトバックアップ、バックアップメソッドをカバーし、バックアップファイル管理のベストプラクティスを提供します。マニュアルバックアップ:MongoDumpコマンドを使用して、マニュアルフルバックアップを実行します。たとえば、Mongodump-Hlocalhost:27017-U Username-P Password-Dデータベース名-O/バックアップディレクトリこのコマンドは、指定されたデータベースのデータとメタデータを指定されたバックアップディレクトリにエクスポートします。

Debian Mongodbでデータを暗号化する方法 Debian Mongodbでデータを暗号化する方法 Apr 12, 2025 pm 08:03 PM

DebianシステムでMongoDBデータベースを暗号化するには、次の手順に従う必要があります。ステップ1:MongoDBのインストール最初に、DebianシステムがMongoDBをインストールしていることを確認してください。そうでない場合は、インストールについては公式のMongoDBドキュメントを参照してください:https://docs.mongodb.com/manual/tutorial/install-mongodb-onedbian/-step 2:暗号化キーファイルを作成し、暗号化キーを含むファイルを作成し、正しい許可を設定します。

CentosでGitLabのデータベースを選択する方法 CentosでGitLabのデータベースを選択する方法 Apr 14, 2025 pm 04:48 PM

gitlabデータベース展開ガイドcentosシステム適切なデータベースの選択は、gitlabを正常に展開するための重要なステップです。 GitLabは、MySQL、PostgreSQL、MongoDBなど、さまざまなデータベースと互換性があります。この記事では、これらのデータベースを選択して構成する方法を詳細に説明します。データベース選択の推奨MYSQL:広く使用されているリレーショナルデータベース管理システム(RDBMS)。安定したパフォーマンスを備えており、ほとんどのGitLab展開シナリオに適しています。 POSTGRESQL:強力なオープンソースRDBMSは、大規模なデータセットの処理に適した複雑なクエリと高度な機能をサポートしています。 Mongodb:人気のNoSQLデータベース、海の扱いが上手です

Mongodbでユーザーをセットアップする方法 Mongodbでユーザーをセットアップする方法 Apr 12, 2025 am 08:51 AM

MongoDBユーザーを設定するには、次の手順に従ってください。1。サーバーに接続し、管理者ユーザーを作成します。 2。ユーザーアクセスを許可するデータベースを作成します。 3. CreateUserコマンドを使用してユーザーを作成し、その役割とデータベースアクセス権を指定します。 4. Getusersコマンドを使用して、作成されたユーザーを確認します。 5.オプションで、特定のコレクションに他のアクセス許可または付与ユーザーの権限を設定します。

See all articles