第十二章 springboot + mongodb(复杂查询)
2024-10-19 13:39:00
- 简单查询:使用自定义的XxxRepository接口即可。(见 第十一章 springboot + mongodb(简单查询))
- 复杂查询:使用MongoTemplate以及一些查询条件构建类(BasicDBList、BasicDBObject、Criteria等)
1、application.properties
#mongodb note:mongo3.x will not use host and port,only use uri
#spring.data.mongodb.host=192.168.22.110
#spring.data.mongodb.port=27017
#spring.data.mongodb.database=myfirstMongodb
spring.data.mongodb.uri=mongodb://192.168.22.110:27017/myfirstMongodb
说明:
- mongo2.x支持以上两种配置方式
- mongo3.x仅支持uri方式
2、Admin
package com.xxx.firstboot.domain; import org.springframework.data.annotation.Id; /**
* 测试复杂的mongo查询
*/
public class Admin {
@Id
private String adminId;
private String name;
private Integer sex;
private String address; public String getAdminId() {
return adminId;
} public void setAdminId(String adminId) {
this.adminId = adminId;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getSex() {
return sex;
} public void setSex(Integer sex) {
this.sex = sex;
} public String getAddress() {
return address;
} public void setAddress(String address) {
this.address = address;
} }
注意:
- @Id必须有
3、AdminRepository
package com.xxx.firstboot.mongo; import org.springframework.data.mongodb.repository.MongoRepository; import com.xxx.firstboot.domain.Admin; public interface AdminRepository extends MongoRepository<Admin, String> {
}
说明:该接口用于简单查询。这里是一个空接口,具有CRUD功能。
4、CustomerController
/*********************测试复杂的mongo查询**********************/
@Autowired
private AdminRepository adminRepository;
@Autowired
private MongoTemplate mongoTemplate; @ApiOperation("增加一个Admin")
@RequestMapping(value = "/addAdmin", method = RequestMethod.GET)
public Admin addAdmin(@RequestParam("name") String name,
@RequestParam("sex") Integer sex,
@RequestParam("address") String address) {
Admin admin = new Admin();
admin.setName(name);
admin.setSex(sex);
admin.setAddress(address);
return adminRepository.save(admin);
} @ApiOperation("获取所有的Admin")
@RequestMapping(value = "/getAllAdmin", method = RequestMethod.GET)
public List<Admin> getAllAdmin() {
return adminRepository.findAll();
} @ApiOperation("复杂的admin查询")
@RequestMapping(value = "/getAdminByNameAndSexOrAddress", method = RequestMethod.GET)
public Admin getAdminByNameAndSexOrAddress(@RequestParam("name") String name,
@RequestParam(value="sex",required=false) Integer sex,
@RequestParam(value="address",required=false) String address) {
/**
* OR
*/
BasicDBList orList = new BasicDBList(); //用于记录
if (sex != null) {
orList.add(new BasicDBObject("sex", sex));
}
if (StringUtils.isNotBlank(address)) {
orList.add(new BasicDBObject("address", address));
}
BasicDBObject orDBObject = new BasicDBObject("$or", orList); /**
* and
*/
BasicDBList andList = new BasicDBList();
andList.add(new BasicDBObject("name", name));
andList.add(orDBObject);
BasicDBObject andDBObject = new BasicDBObject("$and", andList); return mongoTemplate.findOne(new BasicQuery(andDBObject), Admin.class); }
说明:
- getAdminByNameAndSexOrAddress要实现select * from admin where name = ? and (sex = ? or address = ?)
- 通过BasicDBList、BasicDBObject构建查询参数
- findOne返回第一个符合条件的结果、find返回符合条件的结果列表
- 以上查询的collection是admin(VO的简单类名),也可以指定从某一个collection中查询(查看find、findOne等方法)
注意:mongodb的查询字段必须是小写。
测试:
启动mongo,启动应用,打开swagger,访问即可。
参考:
http://blog.csdn.net/congcong68/article/details/47183209
最新文章
- sql评估期已过如何解决该问题
- Photoshop如何实现UI自动切图?
- Mysql 解决left join 数据重复的问题
- C#5.0 .net 4.5示例
- Hadoop2.6.0(2.4~2.7)完全分布式搭建-入门向 新手向 详细流程
- WPF Radio组的绑定
- Swift互用性:与 Cocoa 数据类型共舞(Swift 2.0版)-b
- 高逼格UI-ASD(Android Support Design)
- 解决阿里云服务器3306端口无法访问的问题(windows server 2008r2)
- ESP32搭建4.esp32官方程序下载与串口读取
- APP界面设计 大概总结
- Pycharm 2018 Activation code 在线激活
- Java IO--BIO
- 解决PHP使用POST提交数据不完整,数据不全的问题
- Pandas 库中excel的读写方法介绍
- Linux监控命令整理(top,free,vmstat,iostat,mpstat,sar,netstat)
- GBDT原理详解
- Mysql在master上查看有哪些slave
- Spring Boot入门第四天:使用Thymeleaf模板引擎
- python 爬虫数据准换时间格式
热门文章
- 第一个iOS程序:Hello iOS
- Xcode的快捷键及代码格式化
- 使用UniBeast安装Hackintosh(黑苹果)
- 为了增强团队的协作和高效开发,提升代码质量,TGideas团队一起制订的代码规范。主要包括五部分内容:PC规范、移动端规范、性能优化、CP规范、其他项目规范
- 【WIN10】使用VS生成appx安裝包,並安裝測試
- 使用IIS实现反向代理
- 鸟哥的私房菜:Bash shell(二)-变量的丰富功能
- Java发送HTTP POST请求示例
- URAL 1881 Long problem statement
- Codeforces Round #294 (Div. 2)D - A and B and Interesting Substrings 字符串