我创建了一个MySQL函数,如果传递给参数的值无效,则想引发一个错误。在MySQL函数中引发错误的方法有哪些?
Answers:
MySQL 5.5引入了信号,类似于其他语言中的异常:
http://dev.mysql.com/doc/refman/5.5/en/signal.html
例如,在mysql
命令行客户端中:
mysql> SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Custom error';
ERROR 1644 (45000): Custom error
它实际上是所有三个答案的组合。您调用一个不存在的过程来引发错误,然后声明一个捕获您所生成的错误的退出处理程序。这是一个示例,如果要删除的行设置了外键ID,则使用SQLSTATE 42000(过程不存在)在删除前引发错误:
DROP PROCEDURE IF EXISTS decount_test;
DELIMITER //
CREATE DEFINER = 'root'@'localhost' PROCEDURE decount_test ( p_id bigint )
DETERMINISTIC MODIFIES SQL DATA
BEGIN
DECLARE EXIT HANDLER FOR SQLSTATE '42000'
SELECT 'Invoiced barcodes may not have accounting removed.';
IF (SELECT invoice_id
FROM accounted_barcodes
WHERE id = p_id
) THEN
CALL raise_error;
END IF;
DELETE FROM accounted_barcodes WHERE id = p_id;
END //
DELIMITER ;
输出:
call decount_test(123456);
+----------------------------------------------------+
| Invoiced barcodes may not have accounting removed. |
+----------------------------------------------------+
| Invoiced barcodes may not have accounting removed. |
+----------------------------------------------------+
为什么不只将a存储VARCHAR
在声明的INTEGER
变量中?
DELIMITER $$ DROP FUNCTION IF EXISTS `raise_error` $$
CREATE FUNCTION `raise_error`(MESSAGE VARCHAR(255))
RETURNS INTEGER DETERMINISTIC BEGIN
DECLARE ERROR INTEGER;
set ERROR := MESSAGE;
RETURN 0;
END $$ DELIMITER ;
-- set @foo := raise_error('something failed'); -- or within a query
错误信息是:
错误的整数值:第1行的“ ERROR”列的“ something failed”
它不是完美的,但是它给出了一个漂亮的描述性消息,您不必编写任何扩展DLL。
call raise_error_life_sucks();
,然后随着我需要的地方逐渐发展,我不能仅仅称之为proc)
在MySQL 5中,您可以通过调用不存在的存储过程(CALL raise_error)或将无效值传递给查询(例如null到NOT NULL禁忌字段)来引发错误。这是Roland Bouman撰写的有趣的帖子,内容涉及从MySQL函数中引发错误:
http://rpbouman.blogspot.com/2005/11/using-udf-to-raise-errors-from-inside.html
您也可以使用无效数量的参数调用现有函数。
SELECT
处理程序内的会导致有关无法从函数返回集合的神秘错误。