sql server利用不同语种语言显示报错错误消息的方法示例

liuyang000 2020-06-26

[ftc=#FFFFFF ]解决方案[/ft]
问题:

生产环境的操作系统和数据库可能是英文版的,而我们的母语是中文,如果英语能力差点,可能有时对英语环境下的数据库脚本报错的英文提示看不懂,如果直接拿英语错误提示通过翻译工具去翻译,也不一定就是完全翻译得100%准确。
<style type="text/css">
a:link{color:#fff;}
a:visited{color:#fff;}
a:hover{color:#fff;}
a:active{color:#fff;}
</style>
解决方案:

通过set language指定语种语言,使sql server的报错以该语种语言的形式呈现。

脚本:

说明:通过set language指定语种语言,使sql server的报错以该语种语言的形式呈现
脚本来源:https://www.cnblogs.com/zhang502219048/p/12826544.html
参考:https://docs.microsoft.com/zh-cn/sql/t-sql/statements/set-language-transact-sql?view=sql-server-2017
参考表:select from sys.syslanguages
/

--Divide by zero error encountered.
set language US_ENGLISH
begin try
declare @i int = 1 / 0
end try
begin catch
select ERROR_MESSAGE() as ErrorInfo
end catch
go

--遇到以零作除数错误。
set language 简体中文
begin try
declare @i int = 1 / 0
end try
begin catch
select ERROR_MESSAGE() as ErrorInfo
end catch
go

--發現除以零的錯誤。
set language 繁體中文
begin try
declare @i int = 1 / 0
end try
begin catch
select ERROR_MESSAGE() as ErrorInfo
end catch
go

--0 除算エラーが発生しました。
set language 日本語
begin try
declare @i int = 1 / 0
end try
begin catch
select ERROR_MESSAGE() as ErrorInfo
end catch
go

--0?? ??? ??? ??????.
set language ???
begin try
declare @i int = 1 / 0
end try
begin catch
select ERROR_MESSAGE() as ErrorInfo
end catch
go
脚本运行结果(以英语、中文(简体、繁体)、日语、朝鲜语(韩语)为例):

参考微软官方文档:
https://so.csdn.net/so/search/s.do?q=%E5%B9%B3%E5%BF%83%E5%9C%A8%E7%BA%BF_%E7%94%B5%E5%BE%AE_13887222585_
总结

相关推荐