SpringBoot集成Mongodb

前言

  在学了用MongoDB之后,总感觉直接操作那个客户端比较痛苦。咱是程序员啊,咱能干的就是将自己的想法以代码的形式展示出来。用Navicat连接MongoDB,那么就开始上java代码,毕竟SpringBoot不是白学的啊!!!!


开搞

  1.创建完一个空的maven项目之后就开始导包了(springboot的MongoDB)。

    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-mongodb</artifactId>
    </dependency>

  2.在src/main/resource下创建一个application.yml

server:
  port: 9006  #端口自定义
spring:
  application:
    name: tensquare-spit     #项目的名称,可写可不写
  data:
    mongodb:
      host: localhost     #mongodb所在的那个主机,最好写成localhost或127.0.0.1或固定的IP,我在换了无线网之后报了个超时的错,还找了半天,看着配置都没错,就IP错了
      port: 27017            #开放的端口
      database: spitdb        #数据库名

  3.创建实体类(包括get,set和toString)

import org.springframework.data.annotation.Id;

import java.io.Serializable;
import java.util.Date;
public class Spit implements Serializable {
  @Id //和_id相对应,自动映射为_id
  private String _id;
  private String content;
  private Date publishtime;
  private String userid;
  private String nickname;
  private Integer visits;
  private Integer thumbup;
  private Integer share;
  private Integer comment;
  private String state;
  private String parentid;

  //空参有参,get,set和toSring
    ....
}

  4.创建Dao,从而操作数据库

import com.tensquare.spit.pojo.Spit;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.mongodb.repository.MongoRepository;

public interface SpitDao extends MongoRepository<Spit,String> {

  public Page<Spit> findByParentid(String parentid, Pageable pageable);

}

  5.创建service层,用于操作 Dao

import com.tensquare.spit.dao.SpitDao;
import com.tensquare.spit.pojo.Spit;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
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.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;
import util.IdWorker;

import java.util.Date;
import java.util.List;

@Service
public class SpitService {

  @Autowired
  private SpitDao spitDao;//注入的Dao

  @Autowired
  private IdWorker idWorker;//用于动态生成id

  @Autowired
  private MongoTemplate mongoTemplate;//使用的Mongo的模板,在springboot整合mongodb的时候只用到了简单的逻辑,有些复杂的逻辑倒是需要自己用自带的模板写

//查找所有
  public List<Spit> findAll(){
    return spitDao.findAll();
  }
//通过id查询
  public Spit findById(String id){
    return spitDao.findById(id).get();
  }
//保存一个
  public void save(Spit spit){
    spit.set_id(String.valueOf(idWorker.nextId()));
    spit.setPublishtime(new Date());//发布日期
    spit.setVisits(0);//浏览量         
    spit.setShare(0);//分享数         
    spit.setThumbup(0);//点赞数         
    spit.setComment(0);//回复数         
    spit.setState("1");//状态
    System.out.println("parentid:"+spit.getParentid());
    spitDao.save(spit);
    //如果当前添加的吐槽有父节点,那么父节点的吐槽数+1
    if (spit.getParentid() != null && !"".equals(spit.getParentid())){
      Query query = new Query();
      query.addCriteria(Criteria.where("_id").is(spit.get_id()));
      Update update = new Update();
      update.inc("comment",1);
      mongoTemplate.updateFirst(query,update,"spit");
      System.out.println("comment:"+spit.getComment());
    }
    System.out.println(spit);
  }
//更新一个
  public void update(Spit spit){
     spitDao.save(spit);
  }
//通过id删除一个
  public void deleteById(String id){
    spitDao.deleteById(id);
  }
//分页
  public Page<Spit> findPage(int page,int size){
    PageRequest of = PageRequest.of(page-1, size);
    return spitDao.findAll(of);
  }
//通过某些条件分页
  public Page<Spit> findByParentid(String parentid, int page,int size){
    PageRequest of = PageRequest.of(page-1, size);
    return spitDao.findByParentid(parentid,of);
  }
//通过id更新一条数据的字段
  public void thumbupById(String id){
    Query query = new Query();
    query.addCriteria(Criteria.where("_id").is(id));
    Update update = new Update();
    update.inc("thumbup",1);
    mongoTemplate.updateFirst(query,update,"spit");
  }
}

  6.创建controller,用以和service进行交互

import com.tensquare.spit.pojo.Spit;
import com.tensquare.spit.service.SpitService;
import entity.PageResult;
import entity.Result;
import entity.StatusCode;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.web.PageableDefault;
import org.springframework.web.bind.annotation.CrossOrigin;
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.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController //两个注解的合体
@CrossOrigin //用于跨域
@RequestMapping("/spit")
public class SpitController {

  @Autowired
  private SpitService spitService;
  @Autowired
  private RedisTemplate redisTemplate;

  @GetMapping("findAll")
  public Result findAll() {
    return new Result(true, StatusCode.OK, "查找成功", spitService.findAll());
  }

  @GetMapping("findById/{id}")
  public Result findById(@PathVariable String id) {
    return new Result(true, StatusCode.OK, "查找成功", spitService.findById(id));
  }

  @PostMapping("saveOne")
  public Result save(@RequestBody Spit spit) {
    spitService.save(spit);
    return new Result(true, StatusCode.OK, "添加成功");
  }

  @PutMapping("updateOne")
  public Result update(@RequestBody Spit spit) {
    spitService.update(spit);
    return new Result(true, StatusCode.OK, "修改成功");
  }


  @DeleteMapping("deleteById/{id}")
  public Result deleteById(@PathVariable String id) {
    spitService.deleteById(id);
    return new Result(true, StatusCode.OK, "删除成功");
  }

  @GetMapping("findPage/{page}/{size}")
  public Result findPage(@PageableDefault(sort = {"id"}, direction = Sort.Direction.DESC) @PathVariable int page, @PathVariable int size) {
    Page<Spit> page1 = spitService.findPage(page, size);
    return new Result(true, StatusCode.OK, "查找成功", new PageResult<>(page1.getTotalElements(), page1.getContent()));
  }


  @GetMapping("findByParentid/{parentid}/{page}/{size}")
  public Result findByParentid(@PathVariable String parentid, @PathVariable int page, @PathVariable int size) {
    Page<Spit> byParentid = spitService.findByParentid(parentid, page, size);
    return new Result(true, StatusCode.OK, "查找成功", new PageResult<>(byParentid.getTotalElements(), byParentid.getContent()));
  }

  @PutMapping("thumbup/{spitid}")
  public Result thumbupById(@PathVariable String spitid) {
    //判断当前是否已经点赞,还没做认证,暂时把user写死
    String userid = "111111";
    if (redisTemplate.opsForValue().get("thumbup_" + userid) != null) {
      return new Result(true, StatusCode.REPERROR, "不能重复点赞");
    }
    spitService.thumbupById(spitid);
    redisTemplate.opsForValue().set("thumbup_" + userid, 1);
    return new Result(true, StatusCode.OK, "点赞成功");
  }
}

  7.数据库图片


图片

  8.开始操作

    1.添加数据
添加数据

成功
image.png
    2.查看
查看所有
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343