有人可以建议我如何在不使用 TO_CHAR 函数的情况下使用逗号分隔来显示数字。
NUMBER 3455678.05 应显示为 3,455,678.05 NUMBER 3455678 应显示为 3,455,678
不使用 TO_CHAR() 是不可能的,除非它可以在客户端程序中处理。
例如,在 SQL*Plus 中,您可以执行以下操作:
set numformat 999,999,999,999,999.00
但这不是一个完整的示例,因为 3455678.05 将打印为 3,455,678.05,但 3455678 将打印为 3,455,678.00。
正确的解决方案是使用 TO_CHAR() 函数,同时设置 NLS_TERRITORY 和/或 NLS_NUMERIC_CHARACTERS 以正确格式化输出。
希望有帮助。
显示格式应该在您的应用程序或表示层中完成,而不是通过 SQL。
如果您坚持这样做,那么正如 Mark J. Bobak 所说,to_char 是您唯一的选择。