为了项目在长期使用过程中,数据库仍能够保持较好的性能,考虑将数据库表分为当前表和历史表。当前表针对不同客户,分别存储在不同的表中。因为需要在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;
后继的条件判断与上类似,不同的地方是如果是多条语句,不能带参数,否则会报执行错误。