[关闭]
@zero1036 2017-05-31T18:42:07.000000Z 字数 1872 阅读 1518

morphia API汇总

Mongodb-Client Mongodb


查询 query

操作符:["=", "==","!=", "<>", ">", "<", ">=", "<=", "in", "nin", "all", "size", "exists"],适用于Datastore.find()Query.filter()

注意:十分要注意:所有的操作符与字段名,必须留空格,例如:Age!=22,就会报错

Datastore.find()示例:

  1. //年龄22的用户:{Age:22}
  2. List<Customer> list = datastore.find(Customer.class, "Age =", 22).asList();
  3. //等价于以上
  4. list = datastore.find(Customer.class, "Age", 22).asList();
  5. //年龄22以上的用户:{Age:{$gt:22}}
  6. list = datastore.find(Customer.class, "Age >", 22).asList();
  7. //名字是Tgor、Mark其中一位的用户:{Name:{$in:["Tgor","Mark"]}}
  8. list = datastore.find(Customer.class, "Name in", new String[]{"Tgor", "Mark"}).asList();
  9. //名字不在Tgor、Mark之间的用户:{Name:{$nin:["Tgor","Mark"]}}
  10. list = datastore.find(Customer.class, "Name nin", new String[]{"Tgor", "Mark"}).asList();
  11. //角色是A、B、C其中之一的用户:{Role:{$in:["A","B","C"]}}。结果失败,所有用户都会查出,role字段是数组,应使用$all
  12. list = datastore.find(Customer.class, "Role in", new String[]{"A", "B", "C"}).asList();
  13. //全部具有A、B、C三种角色的用户:{Role:{$all:["A","B","C"]}}。结果失败,所有用户都会查出,role字段是数组,应使用$all
  14. list = datastore.find(Customer.class, "Role all", new String[]{"A", "B", "C"}).asList();
  15. //具有3种角色的用户:
  16. list = datastore.find(Customer.class, "Role size", 3).asList();
  17. //年龄不等于28的用户:{Age:{$ne:28}}
  18. list = datastore.find(Customer.class, "Age !=", 28).asList();

通过find()查询,find api只支持单个条件参数,对于复合查询,需要使用Query.filter(),示例:

注意

  1. Query<Customer> qry = datastore.createQuery(Customer.class);
  2. //年龄22以上,且具有C角色的用户:{$and:[{Age:{$gt:22}},{Role:{$all:["C"]}}]}
  3. List<Customer> list = qry.filter("Age >", 22).filter("Role all", new String[]{"C"}).asList();
  4. //注意:filter()拼接方法只支持and
  5. //年龄22以上,或具有C角色的用户:{ "$or" : [ { "Age" : { "$gt" : 22}} , { "Role" : { "$all" : [ "C"]}}]}
  6. List<String> roles = new ArrayList<String>();
  7. roles.add("C");
  8. qry.or(qry.criteria("Age").greaterThan(22), qry.criteria("Role").hasAllOf(roles));
  9. List<Customer> list = qry.asList();
  10. System.out.println("打印查询条件:" + qry.toString());

排序 order

  1. Query<Customer> qry = datastore.createQuery(Customer.class);
  2. //根据手机升序,再根据年龄降序
  3. List<Customer> list = qry.order("Phone,-Age").asList();

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注