strapi 创建表并插入数据 实现分页 排序 字段查询 模糊 精准 时间范围等 --前端再也不需要后端 看这一篇就足够了

创建一个表并且插入一些数据

创建表

插入表字段

创建完字段以后进入到下面进行创建数据

创建完数据以后按照我下面的打开视图的查询权限

把查询勾选上

保存以后调用接口查看是否能拿到数据

比如我创建了一个student的视图访问就能看到数据了

javascript 复制代码
http://localhost:1337/api/students

分页

获取第 1 页,每页 10 条数据(默认)

javascript 复制代码
GET /api/students?pagination[page]=1&pagination[pageSize]=10

获取第 2 页,每页 10 条数据

javascript 复制代码
GET /api/students?pagination[page]=2&pagination[pageSize]=10

获取所有数据(禁用分页)

javascript 复制代码
GET /api/students?pagination[pageSize]=-1

查询年龄为 20 的学生

javascript 复制代码
GET /api/students?filters[age][$eq]=20

查询名称为张三的学生

javascript 复制代码
GET /api/students?filters[name][$eq]=张三

多条件精准查询(并且关系)

javascript 复制代码
GET /api/students?filters[age][$eq]=20&filters[name][$eq]=张三

查询姓名包含 "张" 的学生

javascript 复制代码
GET /api/students?filters[name][$contains]=张

不区分大小写的模糊查询

javascript 复制代码
GET /api/students?filters[name][$containsi]=zhang

时间查询

假设存在 birthDate 或 createdAt 时间字段:

查询 2000 年之后出生的学生

javascript 复制代码
GET /api/students?filters[birthDate][$gt]=2000-01-01

查询 2000-2005 年之间出生的学生

javascript 复制代码
GET /api/students?filters[birthDate][$gte]=2000-01-01&filters[birthDate][$lte]=2005-12-31

查询今天创建的学生

javascript 复制代码
GET /api/students?filters[createdAt][$gte]=2023-10-05&filters[createdAt][$lte]=2023-10-05T23:59:59

常用时间操作符:

$gt: 大于

$gte: 大于等于

$lt: 小于

$lte: 小于等于

其他常用条件查询

查询年龄在 18-22 之间的学生

javascript 复制代码
GET /api/students?filters[age][$between][0]=18&filters[age][$between][1]=22

查询年龄为 18、20、22 的学生

javascript 复制代码
GET /api/students?filters[age][$in][0]=18&filters[age][$in][1]=20&filters[age][$in][2]=22

查询年龄不为 18 的学生

javascript 复制代码
GET /api/students?filters[age][$ne]=18

排序

按年龄升序排列(默认)

javascript 复制代码
GET /api/students?sort=age

按年龄降序排列

javascript 复制代码
GET /api/students?sort=age:desc

先按年龄降序,再按姓名升序

javascript 复制代码
GET /api/students?sort[0]=age:desc&sort[1]=name:asc

组合查询

可以将分页、过滤、排序等参数组合使用:

组合示例:查询姓名含"张"、年龄20-25岁的学生,按年龄降序,取第1页10条

javascript 复制代码
GET /api/students?filters[name][$contains]=张&filters[age][$between][0]=20&filters[age][$between][1]=25&sort=age:desc&pagination[page]=1&pagination[pageSize]=10
相关推荐
二哈赛车手4 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
栗子~~5 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8295 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
之歆6 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
星星也在雾里6 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控
数据库·postgresql
Maimai108086 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
candyTong6 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
未若君雅裁6 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手7 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记7 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring