sql-server – 迁移到SQL Server 2012后的RAISERROR问题

移动服务器后,我正在处理网站和数据库的一些问题.该数据库以前是sql Server Express 2005,但现在正在sql Server Express 2012上运行.

这些问题与2012年的RAISERROR命令和更改有关.我查看了新语法的文档,但不确定如何将错误号和消息传递给网站.

存储过程和触发器中的RAISERROR命令的一些示例是:

RAISERROR 50000 'Member with same Email address already exists.'

RAISERROR 44447 'The record can''t be added or changed. referential integrity rules require a related record in table ''tblBrand''.'

RAISERROR 44446 'The record can''t be added or changed. referential integrity rules require a related record in table ''tblFragranceHouse''.'

我已经改变了一些新的语法,但我不确定我是否正确地做了这个.我明白,如果我只是传递错误文本,它会传递错误号50000.但我不知道如何处理其他错误代码.

关于如何将这些命令翻译成2012的任何建议?

解决方法

sql 2012不支持Raiserror的未记录版本
支持的语法是
RAISERROR(@Message,Serverity,state);

– @Message可能是消息ID,但它应该存在于sysmessages中,所以如果你想发送自定义消息,我想你应该添加它们sysmessages

http://msdn.microsoft.com/en-us/library/ms178592.aspx

或者另一种选择是使用THROW

http://technet.microsoft.com/en-us/library/ee677615.aspx

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...