mysql预处理语句提取变量,实现动态执行SQL语句

为了项目在长期使用过程中,数据库仍能够保持较好的性能,考虑将数据库表分为当前表和历史表。当前表针对不同客户,分别存储在不同的表中。因为需要在mysql的存储过程中实现动态的指向不同的表进行操作。

首先,mysql的预处理语句如果带参数,每次只能执行一个语句。带参数的写法是下面的样子。注意,这里有一个select变量的语句。可以方便地将预处理语句执行结果放入变量中,为后继判断提供条件。

SET _sql=CONCAT('SELECT 1,PackLayer INTO  @num,@packlayer FROM  CODE_',_CompanyId,' WHERE  PackCode=?  AND  CompanyId=?');
  SET @PackCode=_PackCode;
  SET @CompanyId=_CompanyId;

  SET @sql=_sql;
  PREPARE sentence FROM @sql;
  EXECUTE sentence  USING @PackCode, @CompanyId ;
  DEALLOCATE PREPARE sentence;
#SELECT @num,@packlayer,@isactive;

后继的条件判断与上类似,不同的地方是如果是多条语句,不能带参数,否则会报执行错误。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章