Oracle では、"order by" 句を指定した listagg 関数を使用して、複数の行を 1 つの行に変換できます。このステートメントは、データを並べ替えて、並べ替えられた結果を結合することができます。構文は "listagg (列名) ,'区切り文字') グループ内 (列名順)」。
このチュートリアルの動作環境: Windows 10 システム、Oracle 11g バージョン、Dell G3 コンピューター。
oracleで複数行を1行に変換する方法
必要に応じて、取得した組織配下の下位組織を1行のデータにまとめる必要があり、Oracle独自の機能です。 used
listagg (列名、'区切り文字') グループ内 (列名順)
つまり、各グループ内で、LISTAGG は次に従って列を並べ替えます。 order by 句と並べ替え 最終結果は結合されます
私の組織構造はツリー構造であり、次の SQL は現在の部門の下にあるすべてのサブ部門の名前をクエリします。
SELECT LISTAGG(O.ORGNAME,',') WITHIN GROUP(ORDER BY LEVEL) FROM ORGANIZATION O START WITH O.ORGID = 1000 CONNECT BY PRIOR O.ORGID = O.PID AND LEVEL<blockquote><p>注: 上記の SQL では、ツリー構造内のデータがどのレベルにあるかを示す Oracle キーワード LEVEL が使用されています。 <br> 上記の SQL では、Oracle ツリー クエリ ステートメント START WITH … CONNECT も使用されています。 BY PRIOR …<br> クエリがノードのすべての親ノードに対するものである場合、上記の START WITH SQL を <br><code>START WITH O.ORGID = 1000 CONNECT BY PRIOR O.PID = O に変更する必要があります。 ORGID</code> (PRIOR 以降のフィールドは前の順序と同じではありません)</p></blockquote><p>ORGANIZATION テーブルのデータは次のとおりです</p>
ORGID | ORGNAME | PID |
---|---|---|
小学校 | 0 | |
1 年生 | #1000 | |
2 年生 | 1000 | |
101 クラス | 1100 | ##1102 |
1100 | 1103 | |
1100 | 1201 | |
1200 |
1 年生 | |
##2 年生 | |
101 クラス | |
クラス 102 | |
クラス 103 | |
201Class | |
2.LISTAGG…グループ内… |
#3. 親ノードの下にあるすべての子ノードを 1 行にまとめます
SELECT LISTAGG(O.ORGNAME,',') WITHIN GROUP(ORDER BY LEVEL) FROM ORGANIZATION O START WITH O.ORGID = 1000 CONNECT BY PRIOR O.ORGID = O.PID AND LEVEL <p>実行結果は以下のとおりです。<br> 小学校、1年、2年、101クラス、102クラス、103クラス、201クラス </p># 推奨チュートリアル: 「<p>Oracle Video Tutorial#」 ##"</p>
以上がOracle で複数の行を 1 つの行に変換する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ホットトピック



