1. 获取上条插入数据 LAST_INSERT_ID()
2. 获取update影响行数. ROW_COUNT()mysql>UPDATE t ->SET address = 'be ...
mysql存储过程支持用表作为参数。这个问题在MySQL 5.0以前非常麻烦,但是在MySQL 5.0.13版之后,由于引入了PREPARE语句,一切变得简单了。
例子如下(已验证):
DROP PROCEDURE IF EXISTS `newtable`
CREATE PROCEDURE `newtable`(IN tname varchar(64))
BEGIN
SET @sqlcmd = CONCAT('CREATE TABLE ', tname, ' (id int NOT NULL AUTO_INCREMENT, name varchar(64) DEFAULT NULL, PRIMARY KEY (`id`))')
PREPARE stmt FROM @sqlcmd
EXECUTE stmt
DEALLOCATE PREPARE stmt
END
call newtable('abc')
1064是SQL的语法错误,最简单最低级的错误而已。你这个update语句本身就有问题:
UPDATE woic SET seq=comments WHERE seq='000' AND check_passed=0
这里的comments 应该是传进来的吧?你如果不传进来就要给常量。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)