动态将表名传递给查询db2

时间:2019-08-13 09:39:23

标签: db2

我需要从表中执行COUNT,该表是动态建立并存储值的

尝试了两种方法,但均未成功:

test := make(map[string]int64)

1 个答案:

答案 0 :(得分:1)

如果它是DB2 for LUW,请尝试以下操作:

select DISTINCT(only_ids from url_name) as ids from test_dataset.test_table

# Output
ids
1234567
2345678
etc

您甚至可以将任意--#SET TERMINATOR @ CREATE OR REPLACE FUNCTION GET_COUNT(P_TABNAME VARCHAR(256)) RETURNS BIGINT BEGIN DECLARE V_RC BIGINT; PREPARE S1 FROM 'SET ? = (SELECT COUNT(1) FROM '||P_TABNAME||')'; EXECUTE S1 INTO V_RC; RETURN V_RC; END@ VALUES GET_COUNT('SYSCAT.TABLES')@ VALUES GET_COUNT('SYSCAT.COLUMNS')@ VALUES GET_COUNT('(SELECT 1 FROM SYSCAT.TABLES WHERE TABSCHEMA LIKE ''SYS%'')')@ 语句传递给函数作为参数。