安装

查看mongo可用版本

docker search mongo

安装指定版本的mogo或者拉取最新版本的镜像

docker pull mongo:latest

或者官网下载安装包

https://www.mongodb.com/try/download/community-kubernetes-operator

下载完成解压至自己的目录

tar -zxvf mongodb-macos-x86_64-4.2.18.tgz

创建mongo数据持久化目录

sudo mkdir -p /usr/local/var/mongodb

创建mongo数据库日志目录

sudo mkdir -p /usr/local/var/log/mongodb

分配权限

sudo chown my_mongodb_user /usr/local/var/mongodb

sudo chown my_mongodb_user /usr/local/var/log/mongodb

运行mongod服务

mongod --dbpath /usr/local/var/mongodb --logpath /usr/local/var/log/mongodb/mongo.log --fork

查看是否启动成功

ps aux | grep -v grep | grep mongod

shell操作mongo

mongo

初次安装,只有几个默认的数据库

springboot程序查询mongo可以借助MongoRepository或者MongoTemplate

这里的MongoRepository跟spring data jpa很像,由于继承了CrudRepository或者ListCrudRepository和QueryByExampleExecutor所以基本的增删改查操作都可以直接调用方法来实现

如果使用MongoRepository多字段条件查询时可能会很复杂,使用MongoTemplate查询更为方便,这两者的使用得依靠自己来区分哪种方式更为方便

比如一般的分页以及排序查询MongoRepository更为方便一些





而mongoTemplate只能靠mongoTemplate.query()来实现分页的查询

spring data jpa

interface PersonRepository extends Repository<Person, Long> {

  List<Person> findByEmailAddressAndLastname(EmailAddress emailAddress, String lastname);

  // Enables the distinct flag for the query
List<Person> findDistinctPeopleByLastnameOrFirstname(String lastname, String firstname);
List<Person> findPeopleDistinctByLastnameOrFirstname(String lastname, String firstname); // Enabling ignoring case for an individual property
List<Person> findByLastnameIgnoreCase(String lastname);
// Enabling ignoring case for all suitable properties
List<Person> findByLastnameAndFirstnameAllIgnoreCase(String lastname, String firstname); // Enabling static ORDER BY for a query
List<Person> findByLastnameOrderByFirstnameAsc(String lastname);
List<Person> findByLastnameOrderByFirstnameDesc(String lastname);
}

解析查询的方法名称分为主语和谓语find…By,exists…By),第二部分形成谓词,可以进一步操作如,find(或其他引入关键字)和By之间的任何文本可认为形容词,除非使用结果限制关键字,如Distinct在要创建的查询上设置不同的标志,如根据用户名去重复(findDistinctByUsername)或者使用Top/First来限制查询结果(findFirstByUsername),排序之后取前3条数据(findTop3ByOrderByCreateTimeDesc)。

Repository中的特殊参数

除了基本类型参数,还可以支持Pageable和 Sort来进行分页和排序

Page<User> findByLastname(String lastname, Pageable pageable);

Slice<User> findByLastname(String lastname, Pageable pageable);

List<User> findByLastname(String lastname, Sort sort);

List<User> findByLastname(String lastname, Pageable pageable);

分页

使用Pageable参数来进行分页,使用sort来排序,因为page分页需要根据总数来进行分页计算,判断总共多少页,是否有下一页等等,如果只想分页,不需要知道总共多少页,可使用slice实现,根据属性hasNext判断是否有下一次分页即可,因为计算总页数需要总条数,使用page来接受会额外花费一次count查询





如果只需要排序,可以在方法参数添加sort,可以使用page也可以使用list接受

在jpa查询中,如果添加了pageable,但是不想分页查询,可以使用Pageable.unpaged(),如果不想使用排序可以使用Sort.unsorted(),如果传入null值会报NPE

排序

定义排序表达式,可以多个条件同时排序

Sort sort = Sort.by("firstname").ascending().and(Sort.by("lastname").descending());

lambda条件表达式

TypedSort<Person> person = Sort.sort(Person.class);
Sort sort = person.by(Person::getFirstname).ascending().and(person.by(Person::getLastname).descending());

条数限制

在find...By中间可以使用其他限制词,比如first或者top关键词来限制查询结果的条数,如果只写first或者top,默认为1条,即findByFirst1 = findByFirst

User findFirstByOrderByLastnameAsc();

User findTopByOrderByAgeDesc();

Page<User> queryFirst10ByLastname(String lastname, Pageable pageable);

Slice<User> findTop3ByLastname(String lastname, Pageable pageable);

List<User> findFirst10ByLastname(String lastname, Sort sort);

List<User> findTop10ByLastname(String lastname, Pageable pageable);

如果是单条查询,如findFirstByOrderByLastnameAsc可以将返回结果使用Optional来包装避免NPE

Optional<User> findFirstByOrderByLastnameAsc();

最新文章

  1. Mac 终端 Linux 命令总结(简单命令)
  2. 教你一招:Excel中使用MID函数获取身份证中的出生年月日
  3. EF INNER JOIN,LEFT JOIN,GROUP JOIN
  4. vmware 虚拟机克隆之后配IP重启网络失败
  5. Setting property &#39;source&#39; to &#39;org.eclipse.jst.jee.server
  6. Xcode --自动注释插件VVDocumenter-Xcode(配置须知)
  7. ajaxSubmit中option的参数
  8. linux文档编辑
  9. 员工部门表综合查询SQL
  10. Oracle EBS-SQL (BOM-10):检查有BOM无计划员的数据.sql
  11. C#开源汇总
  12. JS 中 cookie 的使用
  13. I/O----复制文本文件
  14. QLineEdit拾遗:数据的过滤、验证和补全
  15. react图工具集成
  16. Android软键盘的隐藏显示、事件监听的代码
  17. 19.Odoo产品分析 (二) – 商业板块(11) – 在线活动(1)
  18. 读vue-0.6-text-parser.js源码
  19. BZOJ.4031.[HEOI2015]小Z的房间(Matrix Tree定理 辗转相除)
  20. 理解 NgModelController 中相关方法和属性

热门文章

  1. Git commit时提示错误时 解决办法
  2. MySQL日期/时间函数
  3. holiday05
  4. luogu 4886
  5. turtle 画照片
  6. pads:数据格式不正确,网络必须包含一个以上管脚
  7. 将本地文件复制到docker 容器中
  8. 内存、cpu、硬盘使用率测试方法
  9. WEB应用中配置和使用springIOC容器是成功的
  10. idea :不支持发行版本11问题