- Bài 1: MongoDB - Tổng quan
- Bài 2: MongoDB - Điểm mạnh và lợi thế
- Bài 3: MongoDB - Thiết lập môi trường
- Bài 4: MongoDB - Mô hình dữ liệu
- Bài 5: MongoDB - Tạo Database
- Bài 6: MongoDB - Xoá Database
- Bài 7: MongoDB - Tạo Collection
- Bài 8: MongoDB - Xoá Colleciton
- Bài 9: MongoDB - Kiểu dữ liệu
- Bài 10: MongoDB - chèn Document
- Bài 11: MongoDB - truy vấn Document
- Bài 12: MongoDB - Cập nhật Document
- Bài 13: MongoDB - Xoá Document
- Bài 14: MongoDB - Projection
- Bài 15: MongoDB - Giới hạn bản ghi
- Bài 16: MongoDB - Sắp xếp bản ghi
- Bài 17: Mongodb - Index
- Bài 18: MongoDB - Aggregation
- Bài 19: MongoDB - Replication
- Bài 20: MongoDB - Shard
- Bài 21: MongoDB - Tạo backup
- Bài 22: MongoDB - Triển khai
- Bài 23: MongoDB - Java(P1)
- Bài 24: MongoDB - Java(p2)
- Bài 25: MongoDB - PHP
- Bài 26: MongoDB - Relationship
- Bài 27: MongoDB - Tham chiếu database
- Bài 28: MongoDB - Truy vấn Covered
- Bài 29: MongoDB - Phân tích truy vấn
- Bài 30: MongoDB - Toán tử Atomic
- Bài 31: MongoDB - Chỉ mục nâng cao
- Bài 32: MongoDB - Hạn chế chỉ mục (index)
- Bài 33: MongoDB - ObjectID
- Bài 34: MongoDB - Map Reduce
- Bài 35: MongoDB - Text Search
- Bài 36: MongoDB - Regular Expression
- Bài 37: MongoDB - Rockmongo
- Bài 38: MongoDB - GridFS
- Bài 39: MongoDB - Capped Collection
- Bài 40: MongoDB - Auto-Increment
Bài 36: MongoDB - Regular Expression - MongoDB
Đăng bởi: Admin | Lượt xem: 1494 | Chuyên mục: SQL
Regular Expression được sử dụng thường xuyên trong tất cả ngôn ngữ để tìm kiếm một pattern hoặc một từ trong bất cứ chuỗi nào. MongoDB cũng cung cấp tính năng Regular Expression để so khớp mẫu (Pattern matching) trong chuỗi bởi sử dụng toán tử $regex. MongoDB sử dụng PCRE (Perl Compatible Regular Expression) như là ngôn ngữ Regular Expression.
Không giống như Text Search, chúng ta không cần thực hiện bất cứ lệnh nào hoặc cấu hình nào để sử dụng Regular Expression.
Bạn theo dõi cấu trúc của Document dưới posts collection chứa các trường post_text và tags như sau:
{
"post_text": "enjoy the mongodb articles on tutorialspoint",
"tags": [
"mongodb",
"tutorialspoint"
]
}
1. Sử dụng regex trong MongoDB
Truy vấn regex sau tìm kiếm tất cả posts mà chứa chuỗi tutorialspoint trong đó:
>db.posts.find({post_text:{$regex:"tutorialspoint"}})
Truy vấn tương tự có thể viết như sau:
>db.posts.find({post_text:/tutorialspoint/})
2. Sử dụng regex với tùy chọn không phân biệt kiểu chữ
Để làm cho việc tìm kiếm là không phân biệt kiểu chữ, bạn sử dụng tham số $options với giá trị $i. Lệnh sau sẽ tìm kiếm các chuỗi mà có từ tutorialspoint, không quan tâm nó là chữ hoa hay thường.
>db.posts.find({post_text:{$regex:"tutorialspoint",$options:"$i"}})
Một trong các kết quả của truy vấn này là Document sau mà chứa từ tutorialspoint trong các kiểu chữ khác nhau:
{
"_id" : ObjectId("53493d37d852429c10000004"),
"post_text" : "hey! this is my post on TutorialsPoint",
"tags" : [ "tutorialspoint" ]
}
3. Sử dụng regex cho các phần tử mảng
Chúng ta cũng có thể sử dụng khái niệm regex trên trường mảng. Điều này đặc biệt quan trọng khi chúng ta triển khai tính năng của các tags. Vì thế, nếu bạn muốn tìm kiếm tất cả các post có tags bắt đầu với từ tutorial, bạn có thể sử dụng code sau:
>db.posts.find({tags:{$regex:"tutorial"}})
4. Tối ưu hóa các truy vấn Regular Expression
- Nếu các trường của Document là đã được lập chỉ mục, truy vấn sẽ sử dụng các giá trị đã lập chỉ mục này để so khớp với các Regular Expression. Điều này làm cho việc tìm kiếm nhanh hơn khi so sánh với việc quét toàn bộ Collection.
- Nếu Regular Expression là một Prefix expression, tất cả so khớp là bắt đầu với một chuỗi ký tự cụ thể. Ví dụ, nếu regex là ^tut, thì truy vấn sẽ chỉ tìm các chuỗi bắt đầu với tut.
Theo dõi VnCoder trên Facebook, để cập nhật những bài viết, tin tức và khoá học mới nhất!
- Bài 1: MongoDB - Tổng quan
- Bài 2: MongoDB - Điểm mạnh và lợi thế
- Bài 3: MongoDB - Thiết lập môi trường
- Bài 4: MongoDB - Mô hình dữ liệu
- Bài 5: MongoDB - Tạo Database
- Bài 6: MongoDB - Xoá Database
- Bài 7: MongoDB - Tạo Collection
- Bài 8: MongoDB - Xoá Colleciton
- Bài 9: MongoDB - Kiểu dữ liệu
- Bài 10: MongoDB - chèn Document
- Bài 11: MongoDB - truy vấn Document
- Bài 12: MongoDB - Cập nhật Document
- Bài 13: MongoDB - Xoá Document
- Bài 14: MongoDB - Projection
- Bài 15: MongoDB - Giới hạn bản ghi
- Bài 16: MongoDB - Sắp xếp bản ghi
- Bài 17: Mongodb - Index
- Bài 18: MongoDB - Aggregation
- Bài 19: MongoDB - Replication
- Bài 20: MongoDB - Shard
- Bài 21: MongoDB - Tạo backup
- Bài 22: MongoDB - Triển khai
- Bài 23: MongoDB - Java(P1)
- Bài 24: MongoDB - Java(p2)
- Bài 25: MongoDB - PHP
- Bài 26: MongoDB - Relationship
- Bài 27: MongoDB - Tham chiếu database
- Bài 28: MongoDB - Truy vấn Covered
- Bài 29: MongoDB - Phân tích truy vấn
- Bài 30: MongoDB - Toán tử Atomic
- Bài 31: MongoDB - Chỉ mục nâng cao
- Bài 32: MongoDB - Hạn chế chỉ mục (index)
- Bài 33: MongoDB - ObjectID
- Bài 34: MongoDB - Map Reduce
- Bài 35: MongoDB - Text Search
- Bài 36: MongoDB - Regular Expression
- Bài 37: MongoDB - Rockmongo
- Bài 38: MongoDB - GridFS
- Bài 39: MongoDB - Capped Collection
- Bài 40: MongoDB - Auto-Increment