我有一个非常简单的问题,我无法解决。我需要这样做:
select distinct * from (1, 1, 1, 2, 5, 1, 6).
谁都能帮忙??
编辑
数据以文本文件的形式来自我们的一个客户。它是完全没有格式的(它是一个很长的文本行),但在Excel中可以这样做。但这对我来说并不实际,因为我需要在sql查询中使用这些值。每次需要运行查询时这样做并不方便。
我有一个非常简单的问题,我无法解决。我需要这样做:
select distinct * from (1, 1, 1, 2, 5, 1, 6).
谁都能帮忙??
编辑
数据以文本文件的形式来自我们的一个客户。它是完全没有格式的(它是一个很长的文本行),但在Excel中可以这样做。但这对我来说并不实际,因为我需要在sql查询中使用这些值。每次需要运行查询时这样做并不方便。
当前回答
从用户id列表中选择用户id: SELECT * FROM my_table WHERE user_id IN (1,3,5,7,9,4);
其他回答
如果您只想从单个表中选择某些值,您可以尝试这样做
select distinct(*) from table_name where table_field in (1,1,2,3,4,5)
eg:
select first_name,phone_number from telephone_list where district id in (1,2,5,7,8,9)
如果你想从多个表中选择,那么你必须选择UNION。
如果你只是想选择值1,1,1,2,5,1,6,那么你必须这样做
select 1
union select 1
union select 1
union select 2
union select 5
union select 1
union select 6
我知道这是一个相当老的线程,但我正在寻找类似的东西,然后想到了这个。
假设您有一个逗号分隔的字符串,您可以使用string_split
select distinct value from string_split('1, 1, 1, 2, 5, 1, 6',',')
这应该会返回
1
2
5
6
字符串分割接受两个参数,字符串输入和分隔符。
您可以添加一个可选的where语句,使用value作为列名
select distinct value from string_split('1, 1, 1, 2, 5, 1, 6',',')
where value > 1
生产
2
5
6
使用SQL In函数
就像这样:
SELECT * FROM mytable WHERE:
"VALUE" In (1,2,3,7,90,500)
在ArcGIS中工作
总的来说:
SELECT
DISTINCT
FieldName1, FieldName2, ..., FieldNameN
FROM
(
Values
( ValueForField1, ValueForField2,..., ValueForFieldN ),
( ValueForField1, ValueForField2,..., ValueForFieldN ),
( ValueForField1, ValueForField2,..., ValueForFieldN ),
( ValueForField1, ValueForField2,..., ValueForFieldN ),
( ValueForField1, ValueForField2,..., ValueForFieldN )
) AS TempTableName ( FieldName1, FieldName2, ..., FieldNameN )
在你的情况下:
Select
distinct
TempTableName.Field1
From
(
VALUES
(1),
(1),
(1),
(2),
(5),
(1),
(6)
) AS TempTableName (Field1)
您尝试过使用下面的语法吗?
select * from (values (1), (2), (3), (4), (5)) numbers(number)