CONVERT函数不能实现货币格式化,仅支持类型转换;FORMAT函数才是SQL Server中唯一原生支持区域设置的货币格式化方法,但性能较差且需注意文化包安装与精度截断问题。
SQL Server 的 CONVERT 函数不能直接输出带千分位、货币符号或本地化小数点的“显示格式”。它只负责类型转换(比如把 money 转成 varchar),但转出来的字符串是原始数值表示,例如 1234567.89 会变成 '1234567.89',不带 $、€ 或逗号分隔符。
真正控制格式的是后续的字符串拼接或 FORMAT(SQL Server 2012+),而 CONVERT 只是中间一环。误以为 CONVERT 能格式化货币,是常见误解源头。
FORMAT 是 SQL Server 中唯一原生支持区域设置(culture)的格式化函数,能按指定国家/地区规则输出货币符号、分组符和小数位数。
FORMAT(123456.78, 'C', 'de-DE') → '123.456,78 €'
FORMAT(123456.78, 'C', 'en-US') → '$123,456.78'
FORMAT(123456.78, 'C', 'ja-JP') → '¥123,457'(四舍五入到整数)注意:FORMAT 返回 varchar,且性能比 CONVERT 差不少,不适合在大数据量 SELECT 中频繁使用;若仅需简单千分位+小数点,可用 CONVERT 配合 REPLACE 和字符串拼接,但无法自动适配文化规则。
有人尝试用 CONVERT(varchar, @amount, 1)(样式 1 表示带千分位的 money 转换),但这只适用于 money 或 smallmoney 类型,且结果固定为英语格式(如 ',234.56'),无法切换成欧元或日元符号。
0、1、2 仅影响 datetime 和 money 的输出,对 decimal 无效CONVERT(varchar, CAST(123456.78 AS money), 1) 输出 '$123,456.78',硬编码美元符号Latin1_General_CI_AS,样式 1 可能报错或返回空字符串'($123.45)' 括号格式,而非 '-$123.45',不符合部分地区的习惯格式化应尽量交给应用层(如 C# 的 ToString("C", culture) 或前端 Intl.NumberFormat),数据库只存精确数值(decimal(19,4)),避免格式逻辑分散、难以维护。
如果必须在 SQL 中输出格式化结果:
FORMAT(..., 'C', @culture),传入变量 @culture 控制区域FORMAT,会导致索引失效CONVERT 样式参数实现多语言货币——它没这个能力999999999999999.9999),FORMAT 对精度截断行为与 CONVERT 不同文化字符串(如 'fr-FR')必须是系统已安装的语言包,否则 FORMAT 报错 Argument 3 for function FORMAT is not a valid culture。