使用squirrel进行sql拼接不生效问题及解决

 更新时间:2023年09月18日 10:53:57   作者:love666666shen  
这篇文章主要介绍了使用squirrel进行sql拼接不生效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

使用squirrel拼接sql不生效

拼接sql的时候,一般使用同一个变量不断拼接连接。

但是,在使用github.com/Masterminds/squirrel包进行sql拼接时,

需要多加注意:在使用变量添加sql语句后,还需要重新再赋值给该变量,否则达不到想要的结果。

如下代码:

import 	sq "github.com/Masterminds/squirrel"
func FindProviderProduct(providerID int, keyWord string) (products []*ProductInfo, err error) {
	db, err := GetDB()
	if err != nil {
		return
	}
	buffer := sq.Select("PP.product_id", "P.product_name").From("provider_product as PP").
		LeftJoin("provider as PV on PV.id = PP.provider_id").
		LeftJoin("product as P on P.id = PP.product_id").
		Where(sq.Eq{"P.is_deleted": 0, "PV.is_deleted": 0})
	if providerID != 0 {
		buffer.Where(sq.Eq{"PP.provider_id": providerID})     // 这里拼接完sql后,没有重新赋值给buffer变量,相当于这句sql没有拼接到原buffer语句中
	}
	keyWord = easy.ReplaceSpecialStr(keyWord)
	if len(keyWord) != 0 {
		buffer.Where(sq.Like{"P.product_name": keyWord})   // 这里拼接完sql后,没有重新赋值给buffer变量,相当于这句sql没有拼接到原buffer语句中
	}
	sqlStr, args, _ := buffer.ToSql()
	if err = db.Debug().Raw(sqlStr, args...).Find(&products).Error; err != nil {
		return
	}
	return
}

上面的代码,在进行如下赋值后:

buffer := sq.Select("PP.product_id", "P.product_name").From("provider_product as PP").
		LeftJoin("provider as PV on PV.id = PP.provider_id").
		LeftJoin("product as P on P.id = PP.product_id").
		Where(sq.Eq{"P.is_deleted": 0, "PV.is_deleted": 0})

即使,后面的两个if语句满足条件,但是没有将其中的sql重新赋值给buffer变量,也不会把if里面的筛选条件添加到buffer中,

最终的sql结果仅仅是如下sql:

SELECT PP.product_id, P.product_name
FROM provider_product as PP
LEFT JOIN provider as PV on PV.id = PP.provider_id
LEFT JOIN product as P on P.id = PP.product_id
WHERE P.is_deleted = 0 AND PV.is_deleted = 0;

解决方式

在两个if条件中,处于使用buffer继续添加筛选条件外,还需要将添加后的筛选条件重新赋值给buffer变量即可。

修改后的代码如下:

import 	sq "github.com/Masterminds/squirrel"
func FindProviderProduct(providerID int, keyWord string) (products []*ProductInfo, err error) {
	db, err := GetDB()
	if err != nil {
		return
	}
	buffer := sq.Select("PP.product_id", "P.product_name").From("provider_product as PP").
		LeftJoin("provider as PV on PV.id = PP.provider_id").
		LeftJoin("product as P on P.id = PP.product_id").
		Where(sq.Eq{"P.is_deleted": 0, "PV.is_deleted": 0})
	if providerID != 0 {
		buffer = buffer.Where(sq.Eq{"PP.provider_id": providerID})   // 这里在使用buffer拼接后,需要重新赋值给buffer
	}
	keyWord = easy.ReplaceSpecialStr(keyWord)
	if len(keyWord) != 0 {
		buffer = buffer.Where(sq.Like{"P.product_name": keyWord}) // 这里在使用buffer拼接后,需要重新赋值给buffer
	}
	sqlStr, args, _ := buffer.ToSql()
	if err = db.Debug().Raw(sqlStr, args...).Find(&products).Error; err != nil {
		return
	}
	return
}

使用squirrel中的First

squirrel中的First取1条查询数据,相当于在查询结果中添加limit 1。

例如,现有如下sql拼接:

SELECT IFNULL(MAX(update_time), 0) as max_update_time FROM product WHERE user_id = xxx AND product_status IN (1,2) 

现对如上sql使用First方法,相当于:

SELECT IFNULL(MAX(update_time), 0) as max_update_time FROM product WHERE user_id = xxx AND product_status IN (1,2)  LIMIT 1

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog

    如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog

    这篇文章主要介绍了如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2021-02-02
  • mysql 5.7.25 安装配置方法图文教程

    mysql 5.7.25 安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql 5.7.25 安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • MySQL建表(create table)命令解读

    MySQL建表(create table)命令解读

    这篇文章主要介绍了MySQL建表(create table)命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • cmd命令提示符输入:mysql -u root -p报错提示"mysql 不是内部或外部命令,也不是可运行的程序"问题解决

    cmd命令提示符输入:mysql -u root -p报错提示"mysql 不是内部或外部命令,也不是

    这篇文章主要给大家介绍了关于cmd命令提示符输入:mysql -u root -p报错提示"mysql 不是内部或外部命令,也不是可运行的程序"问题的解决办法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • 五分钟让你快速弄懂MySQL索引下推

    五分钟让你快速弄懂MySQL索引下推

    ICP(Index Condition Pushdown)是在MySQL 5.6版本上推出的查询优化策略,把本来由Server层做的索引条件检查下推给存储引擎层来做,下面这篇文章主要给大家介绍了关于MySQL索引下推的相关资料,需要的朋友可以参考下
    2021-09-09
  • MySQL中使用游标触发器的方法

    MySQL中使用游标触发器的方法

    这篇文章主要介绍了MySQL中使用游标-触发器的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Linux下如何通过MySQL二进制包安装MySQL5.7

    Linux下如何通过MySQL二进制包安装MySQL5.7

    这篇文章主要介绍了Linux下如何通过MySQL二进制包安装MySQL5.7,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • MySQL字符集不一致导致索引失效的解决办法

    MySQL字符集不一致导致索引失效的解决办法

    本文分析了一个由于字符集不一致,导致增加了索引但是无法使用的案例,通过索引进行查找时需要进行数据的比较,字符集不一致时需要使用 convert 函数进行转换,从而导致索引失效,文中有详细的解决办法,需要的朋友可以参考下
    2024-04-04
  • 在MySQL中按字符串中的数字排序的详细教程

    在MySQL中按字符串中的数字排序的详细教程

    本文将详细介绍如何在MySQL中利用正则表达式提取字符串中的数字并按这些数字进行排序,以一个具体的例子来说明,使得即使是数据库操作的初学者也能轻松理解和应用,需要的朋友可以参考下
    2024-07-07
  • MySQL下使用Inplace和Online方式创建索引的教程

    MySQL下使用Inplace和Online方式创建索引的教程

    这篇文章主要介绍了MySQL下使用Inplace和Online方式创建索引的教程,针对InnoDB为存储引擎的情况,需要的朋友可以参考下
    2015-11-11

最新评论