Spring Boot集成mongodb数据库过程解析

网友投稿 253 2023-04-22

Spring Boot集成mongodb数据库过程解析

一.认识mongodb

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

二.Spring boot项目集成mongodb

1.添加mongodb依赖

org.springframework.boot

spring-boot-starter-data-mongodb

2.配置mongodb的连接

spring:

data:

mongodb:

#uri: mongodb://localhost:27017/data_exploration

uri: mongodb://root:dhcc-mongodb@192.168.100.87:27017/data_exploration?authSource=admin&authMechanism=SCRAM-SHA-1

解析:以上uri分别代表本地配置和远程连接

3.操作数据库

(1)保存

@Repository

public class ExplorationJobDao {

@Autowired

MongoTemplate mongoTemplate;

public void save(ExplorationJob explorationJob) {

mongoTemplate.save(explorationJob);

}

}

(2)根据ID修改一条数据(其原理先符合ID的数据,然后删除查询结果的第一条)

public void updateExecutionStatusById(int executionStatus, String jobId) {

Query query = new Query(Criteria.where("jobId").is(jobId));

Update update = new Update().set("executionStatus", executionStatus);

mongoTemplate.updateFirst(query, update, ExplorationJob.class);

}

(3)根据条修改多条数据(查询符合ID的所有数据,然后将所有数据修改)

public void update(BusinessExploration businessExploration) {

Query query = new Query(Criteria.where("_id").is(businessExploration.getId()));

Update update = new Update().set("sourceUnit", businessExploration.getSourceUnit())

.set("appSystem", businessExploration.getAppSystem())

.set("businessImplication", businessExploration.getBusinessImplication())

.set("safetyRequire", businessExploration.getSafetyRequire());

mongoTemplate.updateMulti(query, update, TableExploration.class);

}

(4)删除(根据ID删除)

public void delExplorationJobById(String jobId) {

Query query=new Query(Criteria.where("jobId").is(jobId));

mongoTemplate.remove(query,ExplorationJob.class);

}

(5)根据条件查询(根据ID查询)

public ExplorationJob getExplorationJobByJobId(String jobId) {

Query query = new Query(Criteria.where("jobId").is(jobId));

ExplorationJob explorationJob = mongoTemplate.findOne(query, ExplorationJob.class);

return explorationJob;

}

(6)查询所有

mongoTemplate.findAll(TableExploration.class);

(7)多条件动态查询

public List getExplorationByCondition(ExplorationJob explorationJob) {

Query query = new Query();

if (explorationJob.getJobName() != null) {

Pattern pattern = Pattern.compile("^.*" + explorationJob.getJobName() + ".*$", Pattern.CASE_INSENSITIVE);

query.addCriteria(Criteria.where("jobName").regex(pattern));

}

if (explorationJob.getDsType() != null) {

query.addCriteria(Criteria.where("dsType").is(explorationJob.getDsType()));

}

if (explorationJob.getExecutionStatus() != null) {

query.addCriteria(Criteria.where("executionStatus").lte(explorationJPRKowJwJsob.getExecutionStatus()));

}

List explorationJobs=mongoTemplate.find(query, ExplorationJob.class);

return explorationJobs;

}

(8)查询最大值

public Date getMaxExplorationDate(String tableName) {

FindIterable iterable = mongoTemplate.getCollection("tableExploration")

.find(new BasicDBObject("tableName", tableName)).sort(new BasicDBObject("explorationDate", -1)).skip(0)

.limit(1);

Document doc =null;

if (getDocuments(iterable).size()>0) {

doc=getDocuments(iterable).get(0);

Date date = doc.getDate("explorationDate");

return date;

}else {

return null;

}

}

/**

* 工具方法

*

* @param iterable

* @return

*/

public static List getDocuments(FindIterable iterable) {

List results = new ArrayList();

if (null != iterable) {

MongoCursor cursor = iterable.iterator();

Document doc = null;

while (cursor.hasNext()) {

doc = cursor.next();

results.add(doc);

}

}

return results;

}

(9)分组查询(这里还是用到了排序)

public List getAllTableExplorationGroupByTableName(String jobId){

Aggregation aggregation = Aggregation.newAggregation(

Aggregation.match(Criteria.where("jobId").is(jobId)),

Aggregation.sort(new Sort(Direction.DESC,"explorationDate")),

Aggregation.group("tableName")

.first("_id").as("tableName")

.first("databaseType").as("databaseType")

.first("databaseName").as("databaseName")

.first("networkSituation").as("networkSituation")

.first("userName").as("userName")

.first("password").as("PRKowJwJspassword")

.first("url").as("url")

.first("dataStorage").as("dataStorage")

.first("dataIncrement").as("dataIncrement")

.first("explorationDate").as("explorationDate")

//.push("columnExplorations").as("columnExplorations")

.first("jobId").as("jobId")

);

AggregationResults aggregationResults= mongoTemplate.aggregate(aggregation, "tableExploration", TableExploration.class);

List tableExplorations=aggregationResults.getMappedResults();

return tableExplorations;

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java模仿实现QQ登录界面
下一篇:java实现简单年龄计算器
相关文章

 发表评论

暂时没有评论,来抢沙发吧~