Indexes are used to find documents with specific field values quickly. Without an index, MySQL must begin with the first document and then read through the entire collection to find the relevant fields. The larger the collection, the more this costs. If a collection is large and queries on a specific field are common, then consider creating an index on a specific field inside a document.
For example, the following query will perform better with an index:
mysql-js> db.countryinfo.find("demographics.Population < 100") ...[output removed] 8 documents in set (0.00 sec)
create_index() method creates an index
that you can define as nonunique or unique. Use the
field() method to chain the fields that
should be indexed. The
execute() method is
required to create or drop an index.
In MySQL, the
_id field is equivalent to a
primary key by default.
To create a nonunique index, pass to the
create_index() method an index name.
Duplicate index names are prohibited.
In the following example, the first parameter of the
field() method specifies the Population
field inside the demographics object and the next parameter
indicates that the field should be indexed as an Integer
numeric value. The last parameter indicates whether the field
should require the NOT NULL constraint. If the value is
False, the field can contain
mysql-js> db.countryinfo.create_index("pop").\ field("demographics.Population", "INTEGER", False).execute() Query OK (0.04 sec)
To create a unique index, pass to the
create_index() method an index name and the
mysqlx.IndexType.UNIQUE type. Country
"Name" is another common field in the
countryinfo collection to index. In the
the number of characters to index and
indicates that the field cannot contain any
mysql-js> db.countryinfo.create_index("name", mysqlx.IndexType.UNIQUE).\ field("Name", "TEXT(40)", True).execute() Query OK (0.04 sec)
To drop an index, pass to the
method the name of the index to drop. For example, you can
drop the “pop” index as follows:
mysql-js> db.countryinfo.drop_index("pop").execute() Query OK (0.58 sec)