mysql存储过程中,delete语句未根据where条件进行筛选,求救了。

每次执行时,product_view这个表里的数据都会被全部清空。请问这是为什么?还是我没写对?求解决啦。CREATEPROCEDURE`product_view_sp`... 每次执行时,product_view 这个表里的数据都会被全部清空。
请问这是为什么?还是我没写对?
求解决啦。
CREATE PROCEDURE `product_view_sp`(IN product_id BIGINT)
BEGIN
set @product_id=product_id;

DELETE FROM product_view where `product_id`=@product_id;

INSERT into product_view(`product_id`,
`product_key`,
`product_value`,
`key_name`,
`keyword`,
`category_id`,
`category_name`,
`display`,
`search`,
`serial_number`,
`field_type`,
`default`,
`do_group`,
`cid`) select product.product_id,
product_extend.product_key,
product_extend.product_value,
product_mould.another_name,
product_mould.keyword,
product.category_id,
pcategory.category_name,
product_mould.dispaly,
product_mould.search,
product_mould.serial_number,
product_mould.field_type,
product_mould.defalut,
product_mould.do_group,
pcategory.cid
from product,product_extend,product_mould,pcategory
WHERE product.product_id=product_extend.product_id
and product_mould.id=product_extend.product_key
and product.category_id=pcategory.category_id
and product_mould.isdel=0
and product.product_id=@product_id
ORDER BY product.product_id,product_mould.serial_number;
END
已解决。

删除:set @product_id=product_id;
输入参数改成pid,其它对应的地方都改了,就可以了。具体原因不明,工作太忙,不深究了
展开
 我来答
txlaok
2015-06-07 · TA获得超过1035个赞
知道小有建树答主
回答量:476
采纳率:100%
帮助的人:183万
展开全部
in 参数product_id 跟字段product_id 名字可以定义为不一样的试试~
西蒙先生
2017-10-21 · 超过16用户采纳过TA的回答
知道答主
回答量:68
采纳率:0%
帮助的人:23.1万
展开全部
如果参数名和表的字段名相同的话,系统就不认为那是参数了,造成查询条件变成 字段名=字段名,这个在sql里面跟where 1=1没什么区别。所以改成不同于任何字段名字的参数名称就不会有问题了,pid就不会和任何字段名重复,就没问题了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式