mysql触发器取消insert_如何中止INSERT操作在MySql触发器?

我有一个表包含一个url和一个表示其参数的字符串。问题是我想要一个url和parameterstring作为表的唯一约束 – 也就是说没有条目可以有相同的url和参数字符串。参数字符串可以是任意长度(长于800bytes左右,这是MySql键的最大长度,所以我不能使用Unique(url,params),因为它抛出一个错误…)。

我想过使用触发器来做到这一点,但是如果触发器发现插入是要插入一个重复的条目,如何抛出异常/提出错误?我想我想有一个MySqlException抛出像MySql重复的主键等,所以我可以抓住它在我的C#代码。

我有两个在触发器我需要得到帮助:

…中止抛出异常C#…如何抛出异常等到C#?

…允许插入… – 如果没有重复条目,我如何允许插入?

触发代码:

CREATE TRIGGER urls_check_duplicates

BEFORE INSERT ON urls

FOR EACH ROW

BEGIN

DECLARE num_rows INTEGER;

SELECT COUNT(*)

INTO num_rows

FROM urls

WHERE url = NEW.url AND params = NEW.params;

IF num_rows > 0 THEN

... ABORT/throw exception to C# ...

ELSE

... Allow insert ...

END

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值