张工的SQL Server经验心得

主要分享一些个人的SQL Server编程开发优化经验心得。个人公众号【SQL数据库编程】(微信号:zhang502219048)

博客园 首页 新随笔 联系 订阅 管理

问题:
生产环境的操作系统和数据库可能是英文版的,而我们的母语是中文,如果英语能力差点,可能有时对英语环境下的数据库脚本报错的英文提示看不懂,如果直接拿英语错误提示通过翻译工具去翻译,也不一定就是完全翻译得100%准确。

解决方案:
通过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://docs.microsoft.com/zh-cn/sql/t-sql/statements/set-language-transact-sql?view=sql-server-2017

【转载请注明博文来源:https://www.cnblogs.com/zhang502219048/p/12826544.html

posted on 2020-05-04 15:18  张工502219048  阅读(931)  评论(1编辑  收藏  举报