案例:
查看陌陌的动态,依次可以按照发布时间,性别,城市进行筛选
如图进行筛选
gorm链式操作
Method Chaining,Gorm 实现了链式操作接口,所以你可以把代码写成这样:
// 创建一个查询 tx := db.Where("name = ", "jinzhu") // 添加更多条件 if someCondition { tx = tx.Where("age = ", 20) } else { tx = tx.Where("age = ", 30) } if yetAnotherCondition { tx = tx.Where("active = ", 1) }
结合筛选动态的案例,代码如下:
func (xy *Topic) GetTopicListByTimeGenderAddress(createTime, gender int, date, cityName string, adsID int64) (TopicList []Topic) { //先创建一个查询 tx := Db.Model(&xy).Where("ads_id = ", adsID) //分类 if adsID > 0 { tx = tx.Where("ads_id = ", adsID) } //按照创建时间筛选 if createTime > 0 { tx = tx.Order("create_time desc") } else { //按照活动时间筛选 tx = tx.Order("date_timestamp asc") } if gender > 0 { tx = tx.Where("gender = ", gender) } if cityName != "" { tx = tx.Where("city_name = ", cityName) } tx = tx.Preload("TopicImagesList") tx.Find(&TopicList).RecordNotFound() return TopicList }
补充:golang: gorm不定条件查询和分页操作
gorm+gin不定条件查询和分页操作
gorm+gin不定条件查询
不定参数参数多用于table在后端的多条件筛选,这样的场景是无法预知用户需要使用那些筛选条件.只有当参数传递给后端时才清楚.所以后端需要根据传递的参数动态生成符合查询条件的sql语句或者orm操作.
在gorm可以分别任选上述两种中的任意一种:
1.orm操作;
2.拼接原生sql语句;
本文建议大家使用orm操作,以用户结构user为例,假设user的格式如下:
type User struct { gorm.Model Birthday time.Time Age int Name string `gorm:"size:255"` Num int `gorm:"AUTO_INCREMENT"` Sex string `gorm:"size:"` }
假设age,name和num是不定查询条件,前端的请求格式如下:
http://127.0.0.1:10090/user/"htmlcode">
var db *gorm.DB // 已经进行了db的初始化操作,db为全局变量 func getUsers(c *gin.Context) { users := make([]User, 0) Db := db if age, isExist := c.GetQuery("age"); isExist == true { ageInt, _ := strconv.Atoi(age) Db = Db.Where("age = ", ageInt) } if num, isExist := c.GetQuery("num"); isExist == true { numInt, _ := strconv.Atoi(num) Db = Db.Where("num = ", numInt) } if name, isExist := c.GetQuery("name"); isExist == true { Db = Db.Where("name = ", name) } if err := Db.Find(&users).Error; err != nil { fmt.Println(err.Error()) } c.JSON(http.StatusOK, gin.H{ "data": users, }) }
请求url后,可以看到在调试模式下sql的执行语句是:
[2018-09-03 18:47:26] [1.03ms] SELECT * FROM `users` WHERE `users`.`deleted_at` IS NULL AND ((age = '26') AND (name = 'zhangchi')) [13 rows affected or returned ] [GIN] 2018/09/03 - 18:47:26 | 200 | 1.263889ms | 127.0.0.1 | GET /user/"htmlcode">func getUsers(c *gin.Context) { users := make([]User, 0) Db := db page, _ := strconv.Atoi(c.Query("page")) pageSize, _ := strconv.Atoi(c.Query("page_size")) if age, isExist := c.GetQuery("age"); isExist == true { ageInt, _ := strconv.Atoi(age) Db = Db.Where("age = ", ageInt) } if num, isExist := c.GetQuery("num"); isExist == true { numInt, _ := strconv.Atoi(num) Db = Db.Where("num = ", numInt) } if name, isExist := c.GetQuery("name"); isExist == true { Db = Db.Where("name = ", name) } if page > 0 && pageSize > 0 { Db = Db.Limit(pageSize).Offset((page - 1) * pageSize) } if err := Db.Find(&users).Error; err != nil { fmt.Println(err.Error()) } c.JSON(http.StatusOK, gin.H{ "data": users, }) }最核心的代码如下:
if page > 0 && pageSize > 0 { Db = Db.Limit(pageSize).Offset((page - 1) * pageSize) }limit定位每页大小, Offset定位偏移的查询位置.并且先进行条件筛选,最后做分页操作.
小结
分页和不定条件查询主要是配合前端的table进行操作,用户可以根据所需的条件进行筛选.为了提高访问效率,可以指定table的每页大小.
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]