gpt4 book ai didi

sql - Oracle 相当于 T-SQL SET @var = @var + ' ' ;

转载 作者:行者123 更新时间:2023-12-04 23:31:02 26 4
gpt4 key购买 nike

从 SQL Server 切换到 Oracle。如何将字符串连接到循环内的变量?在 SQL Server 中,我会写类似

DECLARE @var varchar(max);
WHILE ([I'm doing something or whatever on a table])
BEGIN
SET @var = @var + ' additional text';
END
SELECT @var AS 'result';

这是我目前在 Oracle 中的存储过程。 (打算将其发展为 NHibernate 的 ClassMap 文件的自动生成器)

CREATE OR REPLACE PROCEDURE WWNA.UT_MAPPINGHELPER
(
TABLE_NAME IN ALL_TABLES.TABLE_NAME%TYPE
, OWNER_NAME IN ALL_TABLES.OWNER%TYPE
, CLASS_DEFINITION IN OUT VARCHAR2
)
IS
CURSOR TABLE_INFO_CUR
IS
SELECT
T.TABLE_NAME
, C.COLUMN_NAME
,C.DATA_TYPE
,C.DATA_LENGTH
,C.DATA_PRECISION
,C.NULLABLE
FROM
ALL_TABLES T
JOIN
ALL_TAB_COLUMNS C
ON T.TABLE_NAME = C.TABLE_NAME
AND T.OWNER = C.OWNER
WHERE
T.TABLE_NAME = :TABLE_NAME
AND T.OWNER = :OWNER_NAME;
TABLE_INFO_ROW TABLE_INFO_CUR%ROWTYPE;
build_sql varchar2;
BEGIN
--VARIABLE build_sql varchar2(4000);
:build_sql := '';
OPEN TABLE_INFO_CUR;

LOOP
FETCH TABLE_INFO_CUR INTO TABLE_INFO_ROW;
EXIT WHEN TABLE_INFO_CUR%NOTFOUND;
SELECT (:build_sql || ' ' || TABLE_INFO_ROW.TABLE_NAME || ' ' || TABLE_INFO_ROW.COLUMN_NAME || ' ' || TABLE_INFO_ROW.DATA_TYPE) INTO :build_sql;
END LOOP;
:CLASS_DEFINITION := :build_sql;

--DBMS_OUTPUT.put_line (CLASS_DEFINITION);


END;

谢谢

最佳答案

CREATE OR REPLACE PROCEDURE WWNA.UT_MAPPINGHELPER
(
TABLE_NAME IN ALL_TABLES.TABLE_NAME%TYPE
, OWNER_NAME IN ALL_TABLES.OWNER%TYPE
, CLASS_DEFINITION IN OUT VARCHAR2
)
IS
CURSOR TABLE_INFO_CUR
IS
SELECT
T.TABLE_NAME
, C.COLUMN_NAME
,C.DATA_TYPE
,C.DATA_LENGTH
,C.DATA_PRECISION
,C.NULLABLE
FROM
ALL_TABLES T
JOIN
ALL_TAB_COLUMNS C
ON T.TABLE_NAME = C.TABLE_NAME
AND T.OWNER = C.OWNER
WHERE
T.TABLE_NAME = :TABLE_NAME
AND T.OWNER = :OWNER_NAME;

build_sql varchar2(32767);
BEGIN
--build_sql := ''; --Not needed, build_sql is already initialised to NULL


FOR cur_rec IN TABLE_INFO_CUR
LOOP
build_sql := build_sql || ' ' ||
cur_rec.TABLE_NAME || ' ' ||
cur_rec.COLUMN_NAME || ' ' ||
cur_rec.DATA_TYPE;
END LOOP;
CLASS_DEFINITION := build_sql;

--DBMS_OUTPUT.put_line (CLASS_DEFINITION);


END;

您需要定义变量 CLASS_DEFINITION

使用 CURSOR FOR LOOP负责为您打开和关闭游标以及批量获取结果。

您还可以使用 CONCAT函数而不是 ||功能。

关于sql - Oracle 相当于 T-SQL SET @var = @var + ' ' ;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17328224/

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