logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

实体的创建

/**
 * 后台管理员
 */
@Data
@Document
@Accessors(chain = true)
public class SystemAdminUser {

    /**
     * ID
     */
    @Id
    private ObjectId id;

    /**
     * 账号
     */
    private String username;

    /**
     * 密码(加密)
     */
    private String password;

    /**
     * 用户名
     */
    private String nick;

    /**
     * 状态
     * @see com.gxzn.comEnum.GlobalStatusEnum
     */
    private Integer status;

    /**
     * 学校ID,仅学校账号有
     */
    private ObjectId schoolId;

    /**
     * 创建时间
     */
    private Date createTime;

    /**
     * 更新时间
     */
    private Date updateTime;

}

@Document:指定文档(表)名
@Transient:不会在文档中插入该字段
@Id:指定id字段

注意:不建议使用包装对象类型数据,可能在表中出现null字段

自带对象

BasicDBObject

类似于Object,但是是JSON格式

示例:

@RequestParam(defaultValue = "{}") String extend

BasicDBObject.parse("{}")

查询

<T> List<T> find(Query query, Class<T> entityClass)
<T> List<T> find(final Query query, Class<T> entityClass, String collectionName)

根据id查询文档

<T> T findById(Object id, Class<T> entityClass)
<T> T findById(Object id, Class<T> entityClass, String collectionName)

查询并修改

<T> T findAndModify(Query query, Update update, Class<T> entityClass)
<T> T findAndModify(Query query, Update update, Class<T> entityClass, String collectionName)
<T> T findAndModify(Query query, Update update, FindAndModifyOptions options, Class<T> entityClass)
<T> T findAndModify(Query query, Update update, FindAndModifyOptions options, Class<T> entityClass, String collectionName)

查询并删除

<T> T findAndRemove(Query query, Class<T> entityClass)
<T> T findAndRemove(Query query, Class<T> entityClass, String collectionName)

总数统计

long count(Query query, Class<?> entityClass)
long count(final Query query, String collectionName)
long count(Query query, Class<?> entityClass, String collectionName)

添加

void insert(Object objectToSave)
void insert(Object objectToSave, String collectionName)

修改

WriteResult upsert(Query query, Update update, Class<?> entityClass)
WriteResult upsert(Query query, Update update, String collectionName)
WriteResult upsert(Query query, Update update, Class<?> entityClass, String collectionName)
WriteResult updateFirst(Query query, Update update, Class<?> entityClass)
WriteResult updateFirst(final Query query, final Update update, final String collectionName)
WriteResult updateFirst(Query query, Update update, Class<?> entityClass, String collectionName)
WriteResult updateMulti(Query query, Update update, Class<?> entityClass) 
WriteResult updateMulti(final Query query, final Update update, String collectionName)
WriteResult updateMulti(final Query query, final Update update, Class<?> entityClass, String collectionName)

删除

WriteResult remove(Object object)
WriteResult remove(Object object, String collection)
WriteResult remove(Query query, String collectionName)
WriteResult remove(Query query, Class<?> entityClass)
WriteResult remove(Query query, Class<?> entityClass, String collectionName)

存在

boolean exists(Query query, Class<?> entityClass)
boolean exists(Query query, String collectionName)
boolean exists(Query query, Class<?> entityClass, String collectionName)

boolean exists = mongoTemplate.exists(new Query(Criteria.where("enterpriseId").is(enterpriseId)), EnterpriseToken.class);

Query

new Query(Criteria criteria)

Criteria

where
and
is
ne
lt      // 小于
lte     // 小于等于
gt      // 大于
gte     // 大于等于
in
nin
mod
all
size
exists
type
not
regex
withinSphere
within

findAndModify

findAndModify(query,update,options,entityClass)

StrUtil.isNotBlank(Str):判断非空,含空字符串

currentDate

update.currentDate("updateDate");

$currentDate操作符是只用在更新操作上,不可以用在insert操作,更新日期类型的字段时建议使用$currentDate操作符,因为它是直接取的数据库服务端的时间,而使用new Date()设置日期取的是当前服务器上的时间,容易造成误差。

Query query = new Query();
query.addCriteria(where("keyword").is(keyword).and("app_no").is(Constant.APP_NO));
Update update = new Update();
update.inc("number", 1);
update.currentDate("updateDate");
update.setOnInsert("createDate", new Date());
mongoTemplate.findAndModify(query, update, FindAndModifyOptions.options().upsert(true), SearchKeyword.class);

排序查询

Query query = new Query();
query.with(new Sort(Sort.Direction.DESC, "number"));
query.limit(pageSize);
List<SearchKeyword> searchKeywordList = mongoTemplate.find(query, SearchKeyword.class);

注意:springboot2.2.1(含)以上的版本Sort已经不能再实例化了,构造方法已经是私有的了,使用Sort.by构造

List<Role> roles = mongoTemplate.find(query.skip((pageIndex - 1) * pageSize).limit(pageSize).with(
        Sort.by(Sort.Direction.DESC, "_id")
), Role.class);

按中文排序

List<DepartmentListRespVo> list = mongoTemplate.find(
        new Query(
                Criteria.where(FieldUtil.get(Department::getStatus)).is(GlobalStatusEnum.STATUS_NORMAL.value())
        ).with(Sort.by(Sort.Direction.ASC, FieldUtil.get(Department::getName)))
                .collation(Collation.of(Locale.CHINESE).numericOrdering(true)),
        DepartmentListRespVo.class,
        ClassUtil.getTableName(Department.class)
);

多个排序条件

// 查员工
List<DepartmentUserRespVo> user = mongoTemplate.find(
        new Query(
                Criteria.where(FieldUtil.get(User::getDepartmentId)).is(item.getId())
                        .and(FieldUtil.get(User::getStatus)).is(GlobalStatusEnum.STATUS_NORMAL.value())
        ).with(Sort.by(Sort.Direction.DESC, FieldUtil.get(User::getPrincipal)))
                .with(Sort.by(Sort.Direction.ASC, FieldUtil.get(Department::getName)))
                .collation(Collation.of(Locale.CHINESE).numericOrdering(true)),
        DepartmentUserRespVo.class,
        ClassUtil.getTableName(User.class)
);

Criteria

多条件或

Criteria c1 = null;
c1.orOperator(
    where("usr.realname").regex(keyword),
    where("user.info.name").regex(keyword),
    where("user.weId").is(weId),
    where("user.mobile").regex(keyword)
    );

顺序

注意sort -> skip -> limit的顺序

数组字段长度过滤

Criteria.where("circleIdList.0").exists(true)

批量添加

mongoTemplate.insert(list, Finance.COLLECTION_NAME);

字段不含字符匹配

// regex具有正则匹配功能,比如字段不以班主任开头
and("jobTitle").regex("^(?!班主任)")

打印执行日志

logging:
    level:
        org.springframework.data.mongodb.core.MongoTemplate: DEBUG

SpringBoot配置

# 数据
spring:
  data:
    mongodb:
      host: 192.168.137.100
      port: 27017
      database: gxzn
      username: gxzn
      password: gxzn
实体的创建
自带对象
查询
添加
修改
删除
存在
Query
Criteria
findAndModify
currentDate
排序查询
按中文排序
多个排序条件
顺序
数组字段长度过滤
批量添加
字段不含字符匹配
打印执行日志
SpringBoot配置