Java操作MongoDB的增删改查,完整项目分享

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password;

}

}

4.3dao代码


@Service

public class UserDao {

@Autowired

private MongoTemplate mongoTemplate;

public User save(User user) {

mongoTemplate.insert(user);

return user;

}

public User getById(String id) {

return mongoTemplate.findById(id, User.class);

}

public User deleteById(String id) {

User user = mongoTemplate.findById(id, User.class);

mongoTemplate.remove(user);

return user;

}

public User update(User user) {

mongoTemplate.save(user);

return user;

}

public List getAllUsers() {

return mongoTemplate.findAll(User.class);

}

public Map<String, Object> query(String userName, int page, int size) {

// 条件

Criteria criteria1 = Criteria.where(“name”).is(userName);

Query query = new Query();

if (userName!= null) {

query.addCriteria(criteria1);

}

// 数量

long total = mongoTemplate.count(query, User.class);

// 分页

query.skip((page - 1) * size).limit(size);

List data = mongoTemplate.find(query, User.class);

Map<String, Object> map = new HashMap<String, Object>();

map.put(“data”, data);

map.put(“total”, total);

return map;

}

}

4.4service代码


@Service

public class UserService {

@Autowired

private UserDao userDao;

public User save(User user) {

return userDao.save(user);

}

public User getById(String id) {

return userDao.getById(id);

}

public User deleteById(String id) {

return userDao.deleteById(id);

}

public User update(User user) {

return userDao.update(user);

}

public List getAllUsers() {

return userDao.getAllUsers();

}

public Map<String, Object> query(String userName, int page, int size) {

return userDao.query(userName,page,size);

}

}

4.5controller代码


@RestController

@RequestMapping(“/user”)

@EnableSwagger2

public class UserController {

@Autowired

private UserService userService;

/**

  • 增加

  • @param user

  • @return

*/

@PostMapping(“/insert”)

@ApiOperation (value = “insert”,notes = “插入”)

public User insertUser(User user) {

return userService.save(user);

}

/**

  • 查询

  • @param id

  • @return

*/

@GetMapping(“/get/{id}”)

@ApiOperation (value = “get”,notes = “查询”)

public User getUserById(@PathVariable String id) {

return userService.getById(id);

}

/**

  • 删除

  • @param id

  • @return

*/

@DeleteMapping(“/delete/{id}”)

@ApiOperation (value = “delete”,notes = “删除”)

public User deleteUserById(@PathVariable String id) {

return userService.deleteById(id);

}

/**

  • 修改

  • @param user

  • @return

*/

@PutMapping(“/update”)

@ApiOperation (value = “update”,notes = “修改”)

public User updateUser(User user) {

return userService.update(user);

}

/**

  • 查询所有的用户

  • @return

*/

@GetMapping(“/get/all”)

@ApiOperation (value = “getAll”,notes = “获取所有”)

public List getAllUsers() {

return userService.getAllUsers();

}

/**

  • 分页查询用户

  • @param userName

  • @param page

  • @param size

  • @return

*/

@GetMapping(“/select/{page}/{size}”)

@ApiOperation (value = “select”,notes = “分页查询”)

public Map<String, Object> selectUserByProperty(String userName, @PathVariable int page, @PathVariable int size) {

return userService.query(userName,page,size);

}

}

4.6pom.xml


<?xml version="1.0" encoding="UTF-8"?>

<project xmlns=“http://maven.apache.org/POM/4.0.0” xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”

xsi:schemaLocation=“http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd”>

4.0.0

org.springframework.boot

spring-boot-starter-parent

2.5.6

com.example

mongodb

0.0.1-SNAPSHOT

mongodb

Demo project for Spring Boot

<java.version>1.8</java.version>

io.springfox

springfox-swagger2

2.9.2

io.springfox

springfox-swagger-ui

2.6.1

org.springframework.boot

spring-boot-starter-data-mongodb

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

spring-boot-starter-test

test

org.springframework

spring-web

5.3.14

org.springframework

spring-webmvc

5.3.14

org.springframework.boot

spring-boot-maven-plugin

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值