目录
3.编写一个简单增删改查类(这里使用mongotemplate操作)
4.编写一个简单增删改查类(这里使用mongorepository操作)
这期讲如何使用java操作mongodb
1.简介
spring-data-mongodb提供了MongoTemplate与MongoRepository两种方式访问mongodb,MongoRepository操作简单,MongoTemplate操作灵活,我们在项目中可以灵活适用这两种方式操作mongodb,MongoRepository的缺点是不够灵活,MongoTemplate正好可以弥补不足。
2.环境搭建
2.1引入pom依赖
<!--web包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--测试包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> <exclusions> <exclusion> <groupId>org.junit.vintage</groupId> <artifactId>junit-vintage-engine</artifactId> </exclusion> </exclusions> </dependency> <!--springboot整合得mongodb--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency>
2.2配置yaml
spring: data: mongodb: uri: mongodb://127.0.0.1:27017/test
3.编写一个简单增删改查类(这里使用mongotemplate操作)
3.1常用方法
mongoTemplate.insert(User): 新增
mongoTemplate.save(User): 新增
mongoTemplate.upsert(query, update, User.class): 修改
mongoTemplate.remove(query, User.class): 删除
mongoTemplate.findAll(User.class): 查询User文档的全部数据
mongoTemplate.findById(<id>, User.class): 查询User文档id为id的数据
mongoTemplate.find(query, User.class);: 根据query内的查询条件查询
3.2解释说明
观看下列代码可以发现,经常使用到俩个对象一个是Query一个是Criteria,这里对这俩个对象做一个小小的解释:
Query:可以把他理解为一个条件语句,把他当作mybatis中的<selecte>的标签来看待,里面封装的是条件语句,用于处理对数据库的增删改查操作
Criteria:可以把它理解为一个具体的条件语句,当作是sql中的where、and、or、like等等这类特殊条件语句
3.3代码实现
实体对象类:
import com.fasterxml.jackson.annotation.JsonIgnore;
import lombok.Data;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;
@Data
@Document("User")
public class User {
@Id
@JsonIgnore // 隐藏该字段,不在前台swagger中展示
private String id;
private String name;
private Integer age;
private String sex;
private String address;
private String email;
@JsonIgnore // 隐藏该字段,不在前台swagger中展示
private String createDate;
@JsonIgnore // 隐藏该字段,不在前台swagger中展示
private String updateDate;
@Override
public String toString() {
return "User{" +
"用户名 = " + name +
", 年龄 = " + age +
", 性别 = " + sex +
", 地址 = " + address +
", 邮箱 = '" + email +
'}';
}
}
接口类:
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.example.mongodemo.domain.User;
import org.example.mongodemo.service.MongoDemoService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.Map;
@RestController("/mongodemo")
@Api(tags = "MongoDemo测试接口")
public class MongoDemoContrller {
@Autowired
private MongoDemoService mongoDemoService;
@GetMapping("/getUsers")
@ApiOperation(value = "获取用户列表", notes = "获取所有用户列表信息")
public String getUsers() {
return mongoDemoService.getUsers();
}
@GetMapping("/getUser/{id}")
@ApiOperation(value = "根据id获取用户", notes = "根据id获取用户详细信息")
public String getUserById(@PathVariable String id) {
return mongoDemoService.getUserById(id);
}
@DeleteMapping("/delUser/{id}")
@ApiOperation(value = "根据id删除用户", notes = "根据id删除用户详细信息数据")
public String delUserById(@PathVariable String id) {
return mongoDemoService.delUserById(id);
}
@PutMapping("/addUser")
@ApiOperation(value = "添加用户", notes = "添加用户信息")
public String addUser(@RequestBody User user) {
return mongoDemoService.addUser(user);
}
@PostMapping("/updateUser")
@ApiOperation(value = "编辑用户", notes = "编辑用户信息")
public String updateUser(
@RequestParam String id,
@RequestBody User user) {
return mongoDemoService.updateUser(id, user);
}
@PostMapping("/getUserByCondition")
@ApiOperation(value = "条件模糊查询用户", notes = "条件模糊查询用户信息")
public String getUserByCondition(@RequestBody Map data) {
return mongoDemoService.getUserByCondition(data);
}
}
service接口:
import org.example.mongodemo.domain.User;
import org.springframework.stereotype.Service;
import java.util.Map;
@Service
public interface MongoDemoService {
String getUsers();
String addUser(User user);
String getUserById(String id);
String delUserById(String id);
String updateUser(String id, User user);
String getUserByCondition(Map data);
}
service实现类:
import com.alibaba.fastjson.JSON;
import com.mongodb.client.result.DeleteResult;
import org.apache.commons.lang3.StringUtils;
import org.example.mongodemo.domain.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import org.springframework.stereotype.Service;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.ListIterator;
import java.util.Map;
import java.util.Optional;
import java.util.regex.Pattern;
@Service
public class MongoDemoServiceImpl implements MongoDemoService {
@Autowired
private MongoTemplate mongoTemplate;
private final String dbName = "user.userdata";
@Override
public String getUsers() {
List<User> userList = mongoTemplate.findAll(User.class, dbName);
ListIterator<User> iterator = userList.listIterator();
while (iterator.hasNext()) {
System.out.println("====>>> 对象数据打印: " + iterator.next());
}
return JSON.toJSON(userList).toString();
}
@Override
public String addUser(User user) {
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String format = dateFormat.format(new Date(System.currentTimeMillis()));
user.setCreateDate(format);
user.setUpdateDate(format);
User saveUser = mongoTemplate.save(user, dbName);
System.out.println(saveUser);
return "添加成功,生成id: "+saveUser.getId();
}
@Override
public String getUserById(String id) {
User user = mongoTemplate.findById(id, User.class, dbName);
if (Optional.ofNullable(user).isEmpty()){
return "查无此人!";
}
return user.toString();
}
@Override
public String delUserById(String id) {
// 使用mongodb包中得Criteria组装查询条件
Criteria criteria = Criteria.where("_id").is(id);
// 封装Query查询对象
Query query = new Query().addCriteria(criteria);
// 删除
DeleteResult remove = mongoTemplate.remove(query, dbName);
long count = remove.getDeletedCount();
if (count == 1){
return "删除成功";
}
return "删除失败";
}
@Override
public String updateUser(String id, User user) {
User oldUser = mongoTemplate.findById(id, User.class, dbName);
if (Optional.ofNullable(oldUser).isEmpty()) {
return "用户不存在,请检查id是否输入正确";
}
// 构造mongo更新对象
Update update = new Update();
update.set("name", StringUtils.isNotBlank(user.getName())? user.getName() : oldUser.getName());
update.set("age", StringUtils.isNotBlank(user.getAge().toString())? user.getAge() : oldUser.getAge());
update.set("email", StringUtils.isNotBlank(user.getEmail())? user.getEmail() : oldUser.getEmail());
update.set("sex", StringUtils.isNotBlank(user.getSex())? user.getSex() : oldUser.getSex());
update.set("address", StringUtils.isNotBlank(user.getAddress())? user.getAddress() : oldUser.getAddress());
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String format = dateFormat.format(new Date(System.currentTimeMillis()));
update.set("updateDate", format);
// 更新
try {
mongoTemplate.upsert(Query.query(Criteria.where("_id").is(id)), update, dbName);
return "更新成功";
}catch (Exception e){
return "更新失败";
}
}
@Override
public String getUserByCondition(Map data) {
// 获取动态的条件列表
List list = new ArrayList();
for (Object o : data.keySet()) {
list.add(o);
}
// 构建条件对象
List<Criteria> criteriaList = new ArrayList<>();
for (int i=0; i<list.size(); i++){
Criteria criteria = new Criteria().andOperator(Criteria.where(list.get(i).toString()).regex(Pattern.compile(data.get(list.get(i).toString()).toString(), Pattern.CASE_INSENSITIVE)));
criteriaList.add(criteria);
}
// 构建查询query条件
Query query = new Query();
query.addCriteria(new Criteria().orOperator(criteriaList.toArray(new Criteria[0])));
try {
List<User> users = mongoTemplate.find(query, User.class, dbName);
return JSON.toJSON(users).toString();
} catch (Exception e){
System.out.println(e.getMessage());
return "模糊条件查询失败!";
}
}
}
4.编写一个简单增删改查类(这里使用mongorepository操作)
使用repository很简单,只需要添加一个继承了MongoRepository的类,指定范型,然后将上面代码中的所有mongoTemplate换成该Repository的类即可
创建repository类示例:
import org.example.mongodemo.domain.User;
import org.springframework.data.mongodb.repository.MongoRepository;
public interface UserRepository extends MongoRepository<User,String> {
}