详解如何在Oracle中连接输出结果
但是也可能遇到需要下面这样的结果。department enamepurchasing raphely,khoo,baida,tobias,himuro,colmenaresit hunol
一个偶然的机会,看到ASK TOM上的一个问题(?p=100:11:0::::P11_QUESTION_ID:229614022562),是关于查询结果字符串连接的。下图是对一个视图(视图代码附后,全部操作是在Oracle 10g中的HR schema中完成的)进行查询得到的常见的结果。
department enamemarketing hartstein
marketing fay
purchasing raphaely
purchasing khoo
...
it hunold
it ernst
...
但是也可能遇到需要下面这样的结果。
department enamepurchasing raphely,khoo,baida,tobias,himuro,colmenares
it hunold,ernst,austin,pataballa,lorentz
marketing hartstein,fay
CREATEORREPLACEVIEWd_employeeAS
SELECTd.department_name department,
e.last_name ename
FROMdepartments d,
employees e
WHEREd.department_id = e.department_idAND
d.department_nameIN('IT','Marketing','Purchasing');
为此,Tom大师提供了两种解决方案,如下:
方法一:
使用静态的SQL从表中选出需要进行连接的所有数据。
CREATEORREPLACEFUNCTIONCONCAT(P_DEPINVARCHAR2)RETURNVARCHAR2IS
L_STRVARCHAR2(200)DEFAULTNULL;
L_SEPVARCHAR2(200)DEFAULTNULL;
BEGIN
FORRCIN(SELECTENAMEFROMD_EMPLOYEEWHEREDEPARTMENT = P_DEP)LOOP
L_STR := L_STR || L_SEP || RC.ENAME;
L_SEP :=',';
ENDLOOP;
RETURNL_STR;
END;
使用下列查询语句查询:
SELECTd.department, hr.concat(d.department) employeesFROMd_employee d
GROUPBYdepartment;
方法二:
使用动态SQL,传入关键列(需求中的department)和那一列的一个值,以及需要实际进行连接的列(需求中的ename)以及表。
CREATEORREPLACEFUNCTIONCONCAT2(P_KEY_NAME INVARCHAR2,
P_KEY_VAL INVARCHAR2,
P_OTHER_COL_NAMEINVARCHAR2,
P_TNAME INVARCHAR2)
RETURNVARCHAR2AS
TYPERCISREFCURSOR;
L_STRVARCHAR2(4000);
L_SEPVARCHAR2(200);
L_VALVARCHAR2(4000);
L_CUR RC;
BEGIN
OPENL_CURFOR'select '|| P_OTHER_COL_NAME ||' from '|| P_TNAME ||' where '|| P_KEY_NAME ||' = :x '
USINGP_KEY_VAL;
LOOP
FETCHL_CUR
INTOL_VAL;
EXITWHENL_CUR%NOTFOUND;
L_STR := L_STR || L_SEP || L_VAL;
L_SEP :=',';
ENDLOOP;
CLOSEL_CUR;
RETURNL_STR;
END;
使用下列查询语句查询:
SELECTd.department, concat2('department', d.department,'ename','d_employee')FROMd_employee d
GROUPBYd.department;
Tom大师还提到,,如果你已经确切知道了需要连接显示的字段所包含的值的列表(比如,只包含A、T、L三个值),那么建议使用DECOD()方法。可以查看下面这个链接:?p=100:11:::::P11_QUESTION_ID:124812348063

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Oracle データベース ログの保存期間は、次のようなログのタイプと構成によって異なります。 REDO ログ: 「LOG_ARCHIVE_DEST」パラメータで構成された最大サイズによって決定されます。アーカイブ REDO ログ: 「DB_RECOVERY_FILE_DEST_SIZE」パラメータで構成された最大サイズによって決まります。オンライン REDO ログ: アーカイブされず、データベースの再起動時に失われます。保持期間はインスタンスの実行時間と一致します。監査ログ: 「AUDIT_TRAIL」パラメータによって構成され、デフォルトで 30 日間保持されます。

Oracle データベース サーバーのハードウェア構成要件: プロセッサ: マルチコア、少なくとも 2.5 GHz のメイン周波数 大規模なデータベースの場合は、32 コア以上が推奨されます。メモリ: 小規模データベースの場合は少なくとも 8 GB、中規模のデータベースの場合は 16 ~ 64 GB、大規模なデータベースまたは重いワークロードの場合は最大 512 GB 以上。ストレージ: SSD または NVMe ディスク、冗長性とパフォーマンスのための RAID アレイ。ネットワーク: 高速ネットワーク (10GbE 以上)、専用ネットワーク カード、低遅延ネットワーク。その他: 安定した電源、冗長コンポーネント、互換性のあるオペレーティング システムとソフトウェア、放熱と冷却システム。

Oracle が必要とするメモリーの量は、データベースのサイズ、アクティビティー・レベル、および必要なパフォーマンス・レベル (データ・バッファー、索引バッファーの保管、SQL ステートメントの実行、およびデータ・ディクショナリー・キャッシュの管理) によって異なります。正確な量は、データベースのサイズ、アクティビティ レベル、および必要なパフォーマンス レベルによって影響されます。ベスト プラクティスには、適切な SGA サイズの設定、SGA コンポーネントのサイズ設定、AMM の使用、メモリ使用量の監視などが含まれます。

Oracle で 1 日に 1 回実行されるスケジュールされたタスクを作成するには、次の 3 つの手順を実行する必要があります。 ジョブを作成します。ジョブにサブジョブを追加し、そのスケジュール式を「INTERVAL 1 DAY」に設定します。ジョブを有効にします。

Oracle データベースに必要なメモリの量は、データベースのサイズ、ワークロードの種類、同時ユーザーの数によって異なります。一般的な推奨事項: 小規模データベース: 16 ~ 32 GB、中規模データベース: 32 ~ 64 GB、大規模データベース: 64 GB 以上。考慮すべきその他の要素には、データベースのバージョン、メモリ最適化オプション、仮想化、ベスト プラクティス (メモリ使用量の監視、割り当ての調整) などがあります。

Oracle Databaseのメモリー要件は、データベースのサイズ、アクティブ・ユーザーの数、同時問合せ、有効な機能、およびシステム・ハードウェア構成の要素によって異なります。メモリ要件を決定する手順には、データベース サイズの決定、アクティブ ユーザー数の推定、同時クエリの理解、有効な機能の検討、システム ハードウェア構成の調査が含まれます。

MySQLi を使用して PHP でデータベース接続を確立する方法: MySQLi 拡張機能を含める (require_once) 接続関数を作成する (functionconnect_to_db) 接続関数を呼び出す ($conn=connect_to_db()) クエリを実行する ($result=$conn->query()) 閉じる接続 ( $conn->close())

Oracle リスナーは、クライアント接続リクエストを管理するために使用されます。起動手順は次のとおりです。 Oracle インスタンスにログインします。リスナー構成を見つけます。 lsnrctl start コマンドを使用してリスナーを開始します。 lsnrctl status コマンドを使用して起動を確認します。
