Michael S. Klishin
b76cffcd1a
Ditto for monger.collection/save
2012-01-29 06:58:02 +04:00
Michael S. Klishin
afa516fff6
Explicit database parameter for monger.collection/insert-batch, /count, /empty?, /any?
2012-01-29 06:31:28 +04:00
Michael S. Klishin
e5af694cc7
Support explicit database parameter for monger.collection/insert
2012-01-29 06:04:11 +04:00
Michael S. Klishin
7b719baf7f
A test that demonstrates querying with date ranges
2012-01-26 17:26:51 +04:00
Oleksandr Petrov
d081a201da
Adding non-array tests for $nin and $in operators.
2012-01-25 22:19:51 +01:00
Oleksandr Petrov
9af8a13ea9
Merge branch 'master' of https://github.com/michaelklishin/monger
2012-01-25 21:56:09 +01:00
Oleksandr Petrov
7ab8d51a84
Adding missing $nin operator.
2012-01-25 21:56:06 +01:00
Michael S. Klishin
12a46ca4ab
Demonstrate querying with comparison operators ($lt, etc) over date fields and Joda Time integration
2012-01-04 19:56:38 +04:00
Michael S. Klishin
1187719ac1
Extend monger.gridfs.GridFSInputFileFactory to support input streams
2011-12-31 16:52:23 +04:00
Michael S. Klishin
cb9ed8edb5
monger.gridfs/find-one-as-map is next to useless, remove it
...
It does not allow you access file content stream.
2011-12-31 16:27:56 +04:00
Michael S. Klishin
a292f082e8
Implement monger.gridfs/find-one and /find-one-as-map
2011-12-31 16:23:49 +04:00
Michael S. Klishin
7eec647a97
Use unqualified function names for what we :use
2011-12-31 15:02:21 +04:00
Michael S. Klishin
7da99d98a3
Implement monger.gridfs.GridFSInputFileFactory for java.io.File instances
2011-12-31 15:01:00 +04:00
Michael S. Klishin
ced9b50153
Make monger.gridfs.IOFactory implementation for String to work the same way as clojure.java.io/IOFactory one does
...
It treats string arguments as local filesystem paths
2011-12-31 14:57:17 +04:00
Michael S. Klishin
b649c7977e
Cosmetics
2011-12-31 06:59:21 +04:00
Michael S. Klishin
eab4405012
Initial bits of monger.gridfs
2011-12-31 06:56:02 +04:00
Michael S. Klishin
f3efbcec16
One more query DSL composition example, introduce monger.query/partial-query
2011-12-31 04:25:26 +04:00
Michael S. Klishin
5bbac64801
Query DSL composition example
2011-12-31 03:23:52 +04:00
Michael S. Klishin
1cb024dcad
Add read preference support for monger.query DSL
2011-12-30 17:19:44 +04:00
Michael S. Klishin
ef3c224441
Fix these early tests to use locals
2011-12-30 17:10:36 +04:00
Michael S. Klishin
c25609a5c3
monger.conversion/to-object-id
2011-12-28 19:46:47 +04:00
Oleksandr Petrov
1a8eb1ef80
Added docs, improved test suite.
...
Removed (seq) method call from find-maps, since DBCursor implements Iterable interface.
Added empty? method for collection.
2011-12-23 11:56:14 +01:00
Michael S. Klishin
3357179659
One more spot
2011-12-18 23:25:28 +04:00
Michael S. Klishin
3b3bb2287a
Extract test DB connection into a helper, use it for every namespace that hits the database
2011-12-18 23:24:23 +04:00
Michael S. Klishin
cd1bd23b3e
Switch test suite to monger.testing/defcleaner
2011-12-18 23:16:54 +04:00
Michael S. Klishin
19a9beb046
Add test examples that demonstrate java.util.Date and java.util.Calendar conversion
2011-12-16 11:42:13 +04:00
Michael S. Klishin
57c4ad6e9b
Switch to clojure.java.io/resource here
2011-12-16 11:12:55 +04:00
Oleksandr Petrov
e6f81e52a7
Merge branch 'master' of https://github.com/michaelklishin/monger
2011-12-03 18:40:52 +01:00
Oleksandr Petrov
611d9666bd
Added get-write-concern function.
2011-12-03 18:39:02 +01:00
Michael S. Klishin
8127d26442
Fix monger.util/get-id for persistent maps with string keys
2011-11-29 15:44:55 +04:00
Michael S. Klishin
be06397849
Introduce monger.collection/any?
...
Useful for detecting duplicate documents and so on
2011-11-28 20:12:19 +04:00
Oleksandr Petrov
01063a3476
Removing outdated comment
2011-11-25 17:33:10 +01:00
Oleksandr Petrov
94acfdec54
Changing 'is' test to 'are' for brevity.
2011-11-19 23:41:53 +01:00
Michael S. Klishin
ddcbf2d068
One more test for clojure.data.json integration
2011-11-16 01:00:18 +04:00
Michael S. Klishin
d9f5ae5951
Move pagination helper to monger.internal.pagination
2011-11-15 03:48:31 +04:00
Michael S. Klishin
3534e579b7
Add pagination support to monger.query DSL
...
An example:
(with-collection coll
(find {})
(paginate :page 1 :per-page 3)
(sort { :title 1 }))
2011-11-15 03:44:19 +04:00
Michael S. Klishin
9b5eee13e0
Port many monger.test.querying tests to use new monger.query DSL
2011-11-15 03:10:55 +04:00
Michael S. Klishin
0536244dce
Merge branch 'master' into query-dsl
...
Conflicts:
src/monger/operators.clj
2011-11-14 15:23:47 +04:00
Michael S. Klishin
bd133c1afc
Initial version of the monger.query DSL
...
Here is what it looks like:
(with-collection "docs"
(find { :inception_year { $lt 2000 $gte 2011 } })
(fields { :inception_year 1 :name 1 })
(skip 10)
(limit 20)
(batch-size 50)
(hint "my-index-name")
(snapshot))
2011-11-14 15:15:43 +04:00
Oleksandr Petrov
8c93095393
Adding test demonstrating regexp document search.
2011-11-13 17:47:26 +01:00
Oleksandr Petrov
047d5b6a88
Separating operators to Logical Operators, Query Operators and Atomic Modifiers.
...
Adding docs to most of operators (still TBC), giving more examples, improving test suite.
2011-11-11 18:55:43 +01:00
Michael S. Klishin
99c46c4860
Merge branch 'master' into query-dsl
2011-11-09 12:44:56 +04:00
Michael S. Klishin
c109702117
Rewort $operator macros to evaluate to strings and not functions
...
Unlike Casbah and Korma, we already use query language data structures as close to what MongoDB uses as possible
(Clojure maps, vectors, numerics and strings are effectively JSON) so we don't need any layers on top, they won't improve
anything.
Having these operators is nice beacuse if you use atomic operators a lot, this will make sure Clojure compiler catches
typos for you. It is completely opt-in, however.
Finally, having a function inserted carries certain runtime performance cost and having $operator macros
that evaluate to themselves does not.
Per discussion with Alex.
2011-11-09 12:40:22 +04:00
Oleksandr Petrov
bb169d3ae3
Adding operators DSL in order to use Clojure functions instead of hashes.
...
Casbah has a similar concept called Bareword Operators.
Korma uses operators a bit differently, but idea is quite same, too.
One of the obvious advantages is that you can make sure you didn't screw make a typo
in operator name during compile-time. Plus, we can guarantee that there is a subset
of used / supported operators, and add them gradually, keeping track of them in one place,
which will simplify tests, too.
2011-11-08 00:12:10 +01:00
Michael S. Klishin
88fa9f07bb
Query DSL work preparation
2011-11-06 23:03:36 +04:00
Michael S. Klishin
6dd3491d39
A few more test examples using "advanced" query operators
2011-11-06 04:59:27 +04:00
Michael S. Klishin
758fb9e7e6
Support skip & limit for monger.collection/find and /find-maps
...
As test example demonstrates, closely following DBCollection and DBCursor API has one downside:
queries that use sorting look really ugly. So monger needs to come up with a DSL à la Casbah or SQLKorma
to make this really nice.
2011-11-05 09:45:54 +04:00
Michael S. Klishin
7a9dcbf15d
Tests/examples for the $rename modifier
2011-10-31 02:52:44 +04:00
Michael S. Klishin
f29d62f181
Tests/examples for $pull and $pullAll modifiers
2011-10-31 02:40:55 +04:00
Michael S. Klishin
60ca5c04a2
Tests/examples for the $pop modifier
2011-10-31 02:30:07 +04:00