gpt4 book ai didi

sql - PostgreSQL Concat 2 数字给我错误

转载 作者:行者123 更新时间:2023-11-29 14:21:41 26 4
gpt4 key购买 nike

我正在尝试连接来自两个不同列的 2 个数字,它们是 chain_code 和 shop_code。

enter image description here

我试过这个:

SELECT CONCAT(`shop_code`, `shop_code`) AS myid FROM {table}

但是我得到一个错误:

ERROR:  operator does not exist: ` integer
LINE 1: SELECT CONCAT(`shop_code`, `shop_code`) AS myid FROM...
^
HINT: No operator matches the given name and argument type(s). You might need to add explicit type casts.

我什至尝试将它转换为字符串,但不能 ... CONCAT(to_char(chain_code, '999')...) ... 但它说没有这样的名为“to_sting”的函数(在 PostgreSQL Documentation 上找到)

最佳答案

首先:不要使用那些可怕的反引号 ` ,那是无效的(标准)SQL。

要引用标识符,请使用双引号:"shop_code"not `shop_code`

但是由于这些标识符不需要任何引号,所以完全将它们排除在外。一般来说,您应该避免使用带引号的标识符。它们造成的麻烦远远超过它们的值(value)。

有关指定 SQL 标识符的详细信息,请参阅手册:http://www.postgresql.org/docs/current/static/sql-syntax-lexical.html#SQL-SYNTAX-IDENTIFIERS

concat() 仅适用于 text/varchar 值,因此您首先需要将整数值转换/转换为 varchar:

SELECT CONCAT(chain_code::text, shop_code::text) AS myid FROM...

but it says there is no such a function called 'to_sting'

嗯,这个函数是to_char(),而不是to_sting()

使用 to_char() 是转换运算符 ::text 的替代方法,但在这种情况下有点复杂:

SELECT CONCAT(to_char(chain_code,'999999'), to_char(shop_code, '999999')) AS myid FROM...

在此上下文中,to_string() 的问题在于,您需要指定一个格式掩码,以处理该列中所有可能的值。使用 cast 运算符更容易,也同样好。


更新(感谢mu)

正如 mu 所指出的那样,concat 实际上不需要任何类型转换或转换:

SELECT CONCAT(chain_code, shop_code) AS myid FROM...

会工作得很好。


这是一个显示所有可能解决方案的 SQLFiddle:http://sqlfiddle.com/#!15/2ab82/3

关于sql - PostgreSQL Concat 2 数字给我错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23231083/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com