MYSQL - 准备好的语句 NULL 处理

Posted

技术标签:

【中文标题】MYSQL - 准备好的语句 NULL 处理【英文标题】:MYSQL - Prepared Statement NULL handling 【发布时间】:2013-10-19 10:25:39 【问题描述】:

我的 mysql 存储过程中有大量准备好的语句。该语句有可能变为 NULL(动态生成的 SQL 语句),因此为避免运行时异常,我始终使用以下方法。但由于我经常使用准备好的语句,因此在每个地方都进行 NULL 检查看起来很嘈杂。

   SET @s10=CONCAT('UPDATE tlist  SET total_count=total_count-1 WHERE group_id =',in_location_id,' AND sub_type=',COMPANY_COUNT,' AND sub_id in (',var_companies,')' );
   IF(@s10 is NOT NULL) THEN
        PREPARE stmt FROM @s10;
        EXECUTE stmt;       
   END IF; 

那么我可以采用其他方法将上述代码简化为一两行吗? (在一个步骤中创建语句并一起执行和Null处理?)

我知道我可以运行小子程序并将准备好的语句传递给它并进行上述检查,但想知道是否有任何内置的 MYSQL 功能。

谢谢

【问题讨论】:

【参考方案1】:

试试

SET @s10=CONCAT('UPDATE tlist  SET total_count=total_count-1 WHERE group_id =',in_location_id,' 
AND sub_type=',COMPANY_COUNT,' AND sub_id in (',var_companies,')' );
IF(!ISNULL(@s10) && LENGTH(trim(@s10)) > 0) THEN
    PREPARE stmt FROM @s10;
    EXECUTE stmt;       
END IF;

【讨论】:

感谢您的回复。事实上,我想缩短上面的代码行。再次感谢

以上是关于MYSQL - 准备好的语句 NULL 处理的主要内容,如果未能解决你的问题,请参考以下文章

在 MySQL 中使用准备好的语句可以防止 SQL 注入攻击吗?

MySQL 准备好的语句

我对 Java 中的准备好的语句有问题 - Mysql 8.0 [重复]

MySql“视图”、“准备好的语句”和“准备好的语句需要重新准备”

设置准备好的语句参数 where NOT NULL java

如果我总是在准备好的语句中使用 varchar 设置 null 会发生啥?