MongoDB学习记录

32 篇文章 2 订阅
1 篇文章 0 订阅

MongoDB学习记录

MongoRepository使用

@Repository
public interface SysMenuRepository extends MongoRepository<SysMenu,String> {

    /**
     * 模糊查询
     * StartsWith    起始位置开始匹配
     * EndsWith      结束位置
     * @param code 匹配内容
     * @return
     */
    List<SysMenu> findByCodeStartsWith(String code);

}

示例

@Service
public class SysMenuService {
    @Autowired
    private SysMenuRepository sysMenuRepository;
    @Autowired
    private MgRepository mgRepository;
    /**
 * 新增
 * @param sysMenu
 * @return
 */
public SysMenu save(SysMenu sysMenu){
    return sysMenuRepository.save(sysMenu);
}

/**
 * 查询所有并分页
 * @return
 */
public Page<SysMenu> findAll(Pageable pageable) {
    return sysMenuRepository.findAll(pageable);
}

/**
 * 模糊查询所有 分页
 * @param pageable
 * @return
 */
public Page<SysMenu> findPag(Pageable pageable) {
    SysMenu sysMenu = new SysMenu();
    sysMenu.setCode("e");
    sysMenu.setId("e");
    sysMenu.setPcode("qqqqq");
    Example<SysMenu> example = Example.of(sysMenu,generater());
    return sysMenuRepository.findAll(example,pageable);
}
/**
 * 删除
 * @param id
 * @return
 */
public String delete(String id){
    sysMenuRepository.deleteById(id);
    boolean exists = sysMenuRepository.existsById(id);
    return exists == false ? "1":"0";
}

/**
 * StartsWith    起始位置开始匹配
 * EndsWith      结束位置
 * @param code
 * @return
 */
public List<SysMenu> findByCodeStartsWith(String code){
    return sysMenuRepository.findByCodeStartsWith(code);
}

private ExampleMatcher generater() {
    return ExampleMatcher.matching() //构建对象
            .withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING) //改变默认字符串匹配方式:模糊查询
            .withIgnoreCase(true) //改变默认大小写忽略方式:忽略大小写
            .withMatcher("pcode", match->match.exact()) // 精确查询pcode,模糊查询其他
//                .withMatcher("code", ExampleMatcher.GenericPropertyMatchers.regex()) // 查询
//                .withMatcher("id", ExampleMatcher.GenericPropertyMatchers.regex()) // 查询
//                .withMatcher("pcode", ExampleMatcher.GenericPropertyMatchers.regex()) // 查询
            .withIgnoreNullValues();//hu忽略null
}

MongoTemplate 使用

public abstract class MongodbBaseDao<T extends Serializable>{

    /**
     * spring mongodb 集成操作类 
     */
    @Autowired
    private MongoTemplate mongoTemplate;

    /**
     * 通过条件查询实体(集合)
     *
     * @param query
     */
    public List<T> find(Query query) {
        return mongoTemplate.find(query,this.getEntityClass());
    }

    /**
     * 通过一定的条件查询一个实体
     *
     * @param query
     * @return
     */
    public T findOne(Query query) {
        return mongoTemplate.findOne(query, this.getEntityClass());
    }

    /**
     * 通过条件查询更新数据
     *
     * @param query
     * @param update
     * @return
     */
    public void update(Query query, Update update) {
        mongoTemplate.upsert(query, update, this.getEntityClass());
    }

    /**
     * 保存一个对象到mongodb
     *
     * @param bean
     * @return
     */
    public T save(T bean) {
        mongoTemplate.save(bean);
        return bean;
    }

    /**
     * 通过ID获取记录
     *
     * @param id
     * @return
     */
    public T get(String id) {
        return mongoTemplate.findById(id, this.getEntityClass());
    }

    /**
     * 通过ID获取记录,并且指定了集合名(表的意思)
     *
     * @param id
     * @param collectionName
     *            集合名
     * @return
     */
    public T get(String id, String collectionName) {
        return mongoTemplate.findById(id, this.getEntityClass(), collectionName);
    }

    /**
     * 获取需要操作的实体类class
     *
     * @return
     */
    protected abstract Class<T> getEntityClass();

}

Criteria 说明

在这里插入图片描述

示例:
/**
 * 使用  Criteria 示例
 * @param id
 * @return
 */
public SysMenu find(String id){
    Criteria criteria = new Criteria();
    criteria.where("id").is(id);
    Query query = Query.query(criteria);
    return mgRepository.findOne(query);
} 

详细请看:https://github.com/Dylan-haiji/javayh-cloud/tree/master/javayh-mongodb

更多学习资料请看这里

如遇到问题可以联系小编。微信:372787553,互相学习

技术博客:https://blog.csdn.net/weixin_38937840

SpringCloud学习代码: https://github.com/Dylan-haiji/javayh-cloud

Redis、Mongo、Rabbitmq、Kafka学习代码: https://github.com/Dylan-haiji/javayh-middleware

AlibabaCloud学习代码:https://github.com/Dylan-haiji/javayh-cloud-nacos

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小杨同学~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值