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;

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值