forked from mongo-dart/mongo_dart
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample.dart
84 lines (82 loc) · 3.39 KB
/
example.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import 'package:mongo_dart/mongo_dart.dart';
import 'dart:io' show Platform;
String host = Platform.environment['MONGO_DART_DRIVER_HOST'] ?? '127.0.0.1';
String port = Platform.environment['MONGO_DART_DRIVER_PORT'] ?? '27017';
void main() async {
var db = Db('mongodb://$host:$port/mongo_dart-blog');
// Example url for Atlas connection
/* var db = Db('mongodb://<atlas-user>:<atlas-password>@'
'cluster0-shard-00-02.xtest.mongodb.net:27017,'
'cluster0-shard-00-01.xtest.mongodb.net:27017,'
'cluster0-shard-00-00.xtest.mongodb.net:27017/'
'mongo_dart-blog?authSource=admin&compressors=disabled'
'&gssapiServiceName=mongodb&replicaSet=atlas-stcn2i-shard-0'
'&ssl=true'); */
var authors = <String, Map>{};
var users = <String, Map>{};
await db.open();
await db.drop();
print('====================================================================');
print('>> Adding Authors');
var collection = db.collection('authors');
await collection.insertMany([
{
'name': 'William Shakespeare',
'email': '[email protected]',
'age': 587
},
{'name': 'Jorge Luis Borges', 'email': '[email protected]', 'age': 123}
]);
await db.ensureIndex('authors',
name: 'meta', keys: {'_id': 1, 'name': 1, 'age': 1});
await collection.find().forEach((v) {
print(v);
authors[v['name'].toString()] = v;
});
print('====================================================================');
print('>> Authors ordered by age ascending');
await collection.find(where.sortBy('age')).forEach(
(auth) => print("[${auth['name']}]:[${auth['email']}]:[${auth['age']}]"));
print('====================================================================');
print('>> Adding Users');
var usersCollection = db.collection('users');
await usersCollection.insertMany([
{'login': 'jdoe', 'name': 'John Doe', 'email': '[email protected]'},
{'login': 'lsmith', 'name': 'Lucy Smith', 'email': '[email protected]'}
]);
await db.ensureIndex('users', keys: {'login': -1});
await usersCollection.find().forEach((user) {
users[user['login'].toString()] = user;
print(user);
});
print('====================================================================');
print('>> Users ordered by login descending');
await usersCollection.find(where.sortBy('login', descending: true)).forEach(
(user) =>
print("[${user['login']}]:[${user['name']}]:[${user['email']}]"));
print('====================================================================');
print('>> Adding articles');
var articlesCollection = db.collection('articles');
await articlesCollection.insertMany([
{
'title': 'Caminando por Buenos Aires',
'body': 'Las callecitas de Buenos Aires tienen ese no se que...',
'author_id': authors['Jorge Luis Borges']?['_id']
},
{
'title': 'I must have seen thy face before',
'body': 'Thine eyes call me in a new way',
'author_id': authors['William Shakespeare']?['_id'],
'comments': [
{'user_id': users['jdoe']?['_id'], 'body': 'great article!'}
]
}
]);
print('====================================================================');
print('>> Articles ordered by title ascending');
await articlesCollection.find(where.sortBy('title')).forEach((article) {
print("[${article['title']}]:[${article['body']}]:"
"[${article['author_id'].toHexString()}]");
});
await db.close();
}