gpt4 book ai didi

sql - 按前缀/起始字母对表变量进行排序

转载 作者:行者123 更新时间:2023-12-01 10:11:36 25 4
gpt4 key购买 nike

这是针对 SAS 表的,因此 SQL 命令也可以使用。

我有一个包含 300 个变量的表;它们有 5 个不同的前缀,我想按这些前缀对它们进行排序。我希望它们按特定顺序排列(mtr 前缀在日期前缀之前),但字母顺序是可以接受的。

我在想 SQL 应该是这样的:

Select mtr*, date* from Table

Select mtr%, date% from Table

最佳答案

正如 gbn 所说,您需要获取列名并动态构建一些 sql(或数据步骤代码)。

这是一个从自动 SAS View 中检索列名称的解决方案,该 View 包含有关 session 的元数据(按字母顺序排列)到单个宏变量中,您稍后可以在代码中使用该变量:

proc sql noprint;
select name into :orderedVarNames separated by ','
from sashelp.vcolumn
where libname='WORK' and memname='YOUR_TABLE_NAME'
order by name
;
quit;

(显然,您需要将引用的值替换为您的表的正确库名和表名。)然后您可以在另一个步骤中使用此宏变量,如下所示:

proc sql;
select &orderedVarNames
from YOUR_TABLE_NAME
;
quit;

在这里,“&orderedVarNames”被解析为列名列表。您可以通过将其输出到日志来检查变量中的内容:%put &orderedVarNames;

还有其他方法可以实现您的想法,但这可能是最快的并且适用于任何表格。如果您打算将此技术用于数据步骤中的变量列表,请将分隔符更改为 separated by ' '

掌握了这一点后,您就可以通过生成多个宏变量并过滤从 sashelp.vcolumn 检索的内容来定制解决方案以获得所需的确切顺序。像这样:

proc sql noprint;
select name into :orderedMTRvars separated by ','
from sashelp.vcolumn
where libname='WORK' and memname='MYTABLE' and substr(name,1,3)='MTR'
order by name
;
select name into :orderedDATEvars separated by ','
from sashelp.vcolumn
where libname='WORK' and memname='MYTABLE' and substr(name,1,4)='DATE'
order by name
;
quit;

proc sql;
select &orderedMTRVars, &orderedDATEVars
from MYTABLE
;
quit;

关于sql - 按前缀/起始字母对表变量进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4548939/

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