Heim Datenbank MySQL-Tutorial 【ORACLE】用FUNCTION动态获得结果集

【ORACLE】用FUNCTION动态获得结果集

Jun 07, 2016 pm 05:38 PM
function oracle

主要说明RETURNPIPELINED,经验者请绕道。最近我得到了一个需求:要求为method传入String,内容如用户ID0,用户ID1,用户ID2...,然后根据这些ID返回一个结果集作

正好ORACLE方面博客还没有这方面内容,趁此机会便写一小段。

既然我们要返回一个结果集,那便是要得到一个TABLE OF XXX类型,XXX可以是VARCHAR2或者INTEGER或者某个表的%ROWTYPE,但我的情况稍微复杂一点,我要自己创建一个OBJECT TYPE。

于是我们要写的FUNCTION的RETURN类型是这样创建的:

CREATE OR REPLACE TYPE TYP_USER_RECORD AS OBJECT (USER_ID CHAR(40),USER_NUM VARCHAR2(200),CREATE_DATE DATE); CREATE OR REPLACE TYPE TYP_USER_TBL AS TABLE OF TYP_USER_RECORD;


下面是FUNCTION的创建:

CREATE OR REPLACE FUNCTION REGROUP_USER_BY_USERIDSTR(USERIDSTR IN VARCHAR2) RETURN TYP_USER_TBL PIPELINED IS --参数声明开始 TYPE USER_CURSOR IS REF CURSOR; USER_INFO_LIST USER_CURSOR; --用来获得检索结果的CURSOR TYPE USER_ROW IS RECORD( USER_ID CHAR(40),USER_NUM VARCHAR2(200),CREATE_DATE DATE); USER_INFO USER_ROW; --用于提取CURSOR中的记录的RECORD USER_ROW4RESULT TYP_USER_RECORD; --我们要返回的数据集的数据行对象 QUERYSTR VARCHAR2(2000); --拼接后的SELECT语句 --参数声明结束 BEGIN --此处根据传入的ID进行了各种判断拼接SELECT语句 并给QUERYSTR赋值 OPEN USER_INFO_LIST FOR QUERYSTR; --打开CURSOR --循环从CURSOR获得结果 并将结果变成TYP_USER_RECORD对象 再将对象放到PIPE里 LOOP FETCH USER_INFO_LIST INTO USER_INFO; EXIT WHEN USER_INFO_LIST%NOTFOUND; USER_ROW4RESULT := TYP_USER_RECORD(USER_INFO.USER_ID, USER_INFO.USER_NUM, USER_INFO.CREATE_DATE); PIPE ROW(USER_ROW4RESULT); END LOOP; CLOSE USER_INFO_LIST; RETURN; END;


既然RETURN TYPE是TABLE类型的,调用时便可以使用TABLE()函数进行查询。

SELECT * FROM TABLE(REGROUP_USER_BY_USERIDSTR)

另外,本人目前工程中使用的持久化框架是myBatis,此语句运行无误。


参数虽然可以直接传入SELECT * FROM XX IN ()进行查询,但也可能需要进行截取变成COLLECION,下面附上该功能的FUNCTION:

CREATE OR REPLACE TYPE TBL_VARCHAR2 AS TABLE OF VARCHAR2(400); CREATE OR REPLACE FUNCTION STR2TBL( PARAM_STR IN VARCHAR2 ) RETURN TBL_VARCHAR2 AS TMP_RECORD LONG DEFAULT PARAM_STR || ','; ROW_INDEX NUMBER; TMP_TBL TBL_VARCHAR2 := TBL_VARCHAR2(); BEGIN LOOP ROW_INDEX := INSTR( TMP_RECORD, ',' ); EXIT WHEN (NVL(ROW_INDEX,0) = 0); TMP_TBL.EXTEND; TMP_TBL( TMP_TBL.COUNT ) := LTRIM(RTRIM(SUBSTR(TMP_RECORD,1,ROW_INDEX-1))); TMP_RECORD := SUBSTR( TMP_RECORD, ROW_INDEX+1 ); END LOOP; RETURN TMP_TBL; END;



本文出自 “It's SWFUpload!!” 博客,,请务必保留此出处

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So importieren Sie die Oracle -Datenbank So importieren Sie die Oracle -Datenbank Apr 11, 2025 pm 08:06 PM

Datenimportmethode: 1. Verwenden Sie das SQLLoader -Dienstprogramm: Datendateien vorbereiten, Steuerdateien erstellen und SQLLOADER ausführen. 2. Verwenden Sie das IMP/Exp -Tool: Daten exportieren, Daten importieren. Tipp: 1. Empfohlener SQL*Loader für Big -Data -Sets; 2. Die Zieltabelle sollte vorhanden und die Spaltendefinition entspricht. 3. Nach dem Import muss die Datenintegrität überprüft werden.

So erstellen Sie primäre Schlüsselbeschränkungen in Oracle So erstellen Sie primäre Schlüsselbeschränkungen in Oracle Apr 11, 2025 pm 07:15 PM

Ein Primärschlüssel ist eine spezielle Spalte oder Kombination von Spalten, die jede Zeile in einer Tabelle eindeutig identifizieren. Es stellt sicher, dass die Datensätze in der Tabelle eindeutig sind und erstellt werden können durch: Angabe des Tabellennamens mithilfe der Änderungstabelle Anweisung. Fügen Sie das Schlüsselwort der Primärschlüssel hinzu, gefolgt vom Spaltennamen, um als Primärschlüssel anzugeben. Primärschlüsseleinschränkungen tragen dazu bei, die Einzigartigkeit der Daten zu gewährleisten, die Abfragegeschwindigkeiten zu verbessern, doppelte Datensätze zu verhindern und die Tabellenverbindungen zu vereinfachen.

So konfigurieren Sie Umgebungsvariablen in Oracle So konfigurieren Sie Umgebungsvariablen in Oracle Apr 11, 2025 pm 07:18 PM

Oracle -Umgebungsvariablen -Konfigurationshandbuch: Erstellen Sie eine Variable der Oracle_Home -Umgebungsvariable, wobei Sie auf das Oracle Home -Verzeichnis verweisen. Fügen Sie das Oracle -Binärverzeichnis der Pfadumgebungsvariable hinzu. Setzen Sie die Umgebungsvariable TNS_ADMIN (wenn die Datei mit TNS benannt ist). Überprüfen Sie die Umgebungsvariableneinstellungen, um sicherzustellen, dass die Ausgabe die festgelegten Variablen anzeigt.

So fügen Sie Oracle Tabellenfelder hinzu So fügen Sie Oracle Tabellenfelder hinzu Apr 11, 2025 pm 07:30 PM

Verwenden Sie die Anweisung für die Änderung der Tabelle, die spezifische Syntax lautet wie folgt: Alter table table_name add column_name data_type [Constraint-Clause]. Wo: table_name der Tabellenname ist, Spalten_Name ist der Feldname, Data_Type ist der Datentyp, und die Einschränkungsklausel ist eine optionale Einschränkung. Beispiel: Änderung der Tabelle Mitarbeiter Fügen Sie der Mitarbeitertabelle eine E -Mail -Varchar2 (100) hinzu.

So überprüfen Sie die Tabellenraumgröße von Oracle So überprüfen Sie die Tabellenraumgröße von Oracle Apr 11, 2025 pm 08:15 PM

Um die Oracle -Tablespace -Größe abzufragen, führen Sie die folgenden Schritte aus: Bestimmen Sie den Namen Tablespace, indem Sie die Abfrage ausführen: Wählen Sie Tablespace_Name aus dba_tablespaces. Abfragen Sie die Tablespace -Größe durch Ausführen der Abfrage: Summe (Bytes) als Total_Size, sum (bytes_free) als verfügbare_space, sum

Wie man verstümmelte Code in Oracle löst Wie man verstümmelte Code in Oracle löst Apr 11, 2025 pm 10:09 PM

Oracle -verstümmelte Probleme können gelöst werden, indem der Datenbankzeichen gesetzt wird, um sicherzustellen, dass sie mit den Daten übereinstimmen. Legen Sie den Client -Zeichen für die Datenbank fest. Konvertieren Sie Daten oder ändern Sie Spaltenzeichen -Sets so, dass sie Datenbankzeichen -Sets übereinstimmen. Verwenden Sie Unicode -Zeichensätze und vermeiden Sie Multibyte -Zeichensätze. Überprüfen Sie, ob die Spracheinstellungen der Datenbank und des Clients korrekt sind.

Wie man Orakel wiedergegeben Wie man Orakel wiedergegeben Apr 11, 2025 pm 07:33 PM

Oracle bietet mehrere Deduplication -Abfragemethoden: Das bestimmte Schlüsselwort gibt für jede Spalte einen eindeutigen Wert zurück. Die Gruppe nach Klausel gruppiert die Ergebnisse und gibt für jede Gruppe einen nicht repetitiven Wert zurück. Das eindeutige Schlüsselwort wird verwendet, um einen Index mit nur eindeutigen Zeilen zu erstellen, und das Abfragen des Index wird automatisch dedupliziert. Die Funktion row_number () weist eindeutige Zahlen und filtert Ergebnisse aus, die nur Zeile 1 enthalten. Die Funktion min () oder max () gibt nicht repetitive Werte einer numerischen Spalte zurück. Der Schnittbetreiber gibt die gemeinsamen Werte der beiden Ergebnissätze zurück (keine Duplikate).

So ändern Sie Feldnamen von Oracle So ändern Sie Feldnamen von Oracle Apr 11, 2025 pm 07:21 PM

Die Schritte zur Änderung des Feldnamens in einer Oracle -Tabelle sind wie folgt: Verbindung zur Datenbank herstellen. Verwenden Sie die Anweisung für die Änderung der Tabelle, um den Feldnamen zu ändern. Geben Sie den Tabellennamen und den alten Feldnamen an. Geben Sie den neuen Feldnamen an. Änderungen einreichen.

See all articles