liuyang000 2020-06-26
生产环境的操作系统和数据库可能是英文版的,而我们的母语是中文,如果英语能力差点,可能有时对英语环境下的数据库脚本报错的英文提示看不懂,如果直接拿英语错误提示通过翻译工具去翻译,也不一定就是完全翻译得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
脚本运行结果(以英语、中文(简体、繁体)、日语、朝鲜语(韩语)为例):