Oracle 11g中CTE应用示例
关于SQL SERVER中的CTE中的CTE应用,请看这里:http://blog.csdn.net/downmoon/archive/2009/10/23/4715814.aspx 其实,ORACLE的CTE语法完全一样,看示例: 一、创建示例数据表如下: View Code declare tableExistedCount number; begin select count(1) in
关于SQL SERVER中的CTE中的CTE应用,请看这里:http://blog.csdn.net/downmoon/archive/2009/10/23/4715814.aspx
其实,ORACLE的CTE语法完全一样,看示例:
一、创建示例数据表如下:
View Code declare tableExistedCount number; begin select count(1) into tableExistedCount from user_tables where TABLE_NAME ='DemoOrganization'; if tableExistedCount =1 then execute immediate ' drop table DemoOrganization cascade constraints'; end if; end; /*==============================================================*/ /* Table: DemoOrganization */ /*==============================================================*/ create table DemoOrganization ( OrgID NUMBER(20,0) not null, OrgCode VARCHAR2(100), OrgName NVARCHAR2(100), OrgPath VARCHAR2(500), ParentID INTEGER, OLevel INTEGER default 0, OrderID NUMBER(10,0), CurState INTEGER default 0, AddUser VARCHAR2(50), AddTime DATE, constraint PK_DEMOORGANIZATION primary key (OrgID) ); comment on table DemoOrganization is '演示组织机构'; comment on column DemoOrganization.OrgID is '机构ID'; comment on column DemoOrganization.OrgCode is '机构编码'; comment on column DemoOrganization.OrgName is '机构名称'; comment on column DemoOrganization.OrgPath is '机构路径'; comment on column DemoOrganization.ParentID is '上级ID'; comment on column DemoOrganization.OLevel is '级别'; comment on column DemoOrganization.OrderID is '排序'; comment on column DemoOrganization.CurState is '当前状态'; comment on column DemoOrganization.AddUser is '创建人'; comment on column DemoOrganization.AddTime is '创建时间';
并插入测试数据:
View Code drop sequence SEQ_DEMOORGANIZATION; -- Create sequence create sequence SEQ_DEMOORGANIZATION minvalue 1 maxvalue 999999999999999 start with 1 increment by 1 cache 201; create or replace trigger TRI_SEQ_DEMOORGANIZATION before insert on DEMOORGANIZATION for each row begin select SEQ_DEMOORGANIZATION.NEXTVAL into:new.ORGID from dual; end; truncate table DEMOORGANIZATION; INSERT INTO DEMOORGANIZATION(ORGNAME,OLEVEL,ORGPATH,PARENTID ,ADDTIME ,ADDUSER, ORDERID ,CURSTATE) select '组织机构1',1,'0',0,sysdate,'testUser',13,0 from dual union all select '组织机构2',1,'0',0,sysdate,'testUser',12,0 from dual union all select '组织机构3',1,'0',0,sysdate,'testUser' ,10,0 from dual union all select '组织机构4',2,'1',1,sysdate,'testUser' ,19,0 from dual union all select '组织机构5',2,'2',2,sysdate,'testUser' ,17,0 from dual union all select '组织机构6',3,'1/4',4,sysdate,'testUser' ,16,0 from dual union all select '组织机构7',3,'1/4',4,sysdate,'testUser' ,4,0 from dual union all select '组织机构8',3,'2/5',5,sysdate,'testUser' ,3, 0 from dual union all select '组织机构9',4,'1/4/6',6,sysdate,'testUser' ,5,0 from dual union all select '组织机构10',4,'1/4/6',6,sysdate,'testUser' ,63,0 from dual union all select '组织机构11',4,'1/4/6',6,sysdate,'testUser' ,83,0 from dual union all select '组织机构12',4,'2/5/8',8,sysdate,'testUser' ,3,0 from dual union all select '组织机构13',4,'2/5/8',8,sysdate,'testUser', 1,0 from dual; select * from DEMOORGANIZATION;
二、示例:
1、--查询ORGID为2的机构包含所有子机构,且级别不大于2
WITH SimpleRecursive(ORGNAME, ORGID, ORGPATH,PARENTID,OLEVEL) AS (SELECT ORGNAME, ORGID, ORGPATH,PARENTID,0 FROM DEMOORGANIZATION WHERE ORGID = 2 UNION ALL SELECT P.ORGNAME, P.ORGID, P.ORGPATH,P.PARENTID,P.OLEVEL+1 FROM DEMOORGANIZATION P INNER JOIN SimpleRecursive A ON A.ORGID = P.PARENTID ) SELECT sr.ORGNAME as ORGNAME, c.ORGNAME as PARENTIDName,sr.ORGPATH as PARENTIDCode FROM SimpleRecursive sr inner join DEMOORGANIZATION c on sr.PARENTID=c.ORGID where c.OLEVEL<p><img src="/static/imghw/default1.png" data-src="pic/20151007/sdsgj5s52f2.png" class="lazy" alt="Oracle 11g中CTE应用示例" ></p><p>2、--查询ORGID为2的机构包含所有子机构,且级别不大于3</p><pre class="brush:php;toolbar:false">SELECT ORGNAME as ORGNAME, (Select ORGNAME from DEMOORGANIZATION s where c.PARENTID=s.ORGID) as PARENTNAME, ORGPATH as ORGPATH,OLEVEL from DEMOORGANIZATION c where ORGPATH like'2/%' and OLEVEL<p>3、--查找某个ORGID为12的部门对应的所有树级部门<br></p><pre class="brush:php;toolbar:false">SELECT ORGID, OLEVEL, ORGNAME, PARENTID FROM DEMOORGANIZATION D START WITH ORGID IN (SELECT ORGID FROM DEMOORGANIZATION WHERE ORGID = 12 AND ROWNUM = 1) CONNECT BY PRIOR D.PARENTID = ORGID;

4、--查找某个ORGID为12的部门对应的顶级部门
SELECT * FROM (SELECT FIRST_VALUE(ORGNAME) OVER(ORDER BY LEVEL DESC ROWS UNBOUNDED PRECEDING) AS FIRSTID FROM DEMOORGANIZATION START WITH ORGID = 12 CONNECT BY PRIOR PARENTID = ORGID) T WHERE ROWNUM = 1
助人等于自助! 3w@live.cn

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











Oracleのソリューションを開くことはできません。1。データベースサービスを開始します。 2。リスナーを開始します。 3.ポートの競合を確認します。 4.環境変数を正しく設定します。 5.ファイアウォールまたはウイルス対策ソフトウェアが接続をブロックしないことを確認してください。 6.サーバーが閉じているかどうかを確認します。 7. RMANを使用して破損したファイルを回復します。 8。TNSサービス名が正しいかどうかを確認します。 9.ネットワーク接続を確認します。 10。Oracleソフトウェアを再インストールします。

Oracle Cursorの閉鎖問題を解決する方法には、次のものが含まれます。 Scopeが終了した後に自動的に閉じるように、for update句のカーソルを宣言します。使用句のカーソルを宣言して、関連するPL/SQL変数が閉じられたときに自動的に閉じるようにします。例外処理を使用して、例外の状況でカーソルが閉じていることを確認します。接続プールを使用して、カーソルを自動的に閉じます。自動送信を無効にし、カーソルの閉鎖を遅延させます。

Oracleでは、forループループは動的にカーソルを作成できます。手順は次のとおりです。1。カーソルタイプを定義します。 2。ループを作成します。 3.カーソルを動的に作成します。 4。カーソルを実行します。 5。カーソルを閉じます。例:カーソルをサイクルごとに作成して、上位10人の従業員の名前と給与を表示できます。

Oracleログファイルがいっぱいになると、次のソリューションを採用できます。1)古いログファイルをクリーンします。 2)ログファイルサイズを増やします。 3)ログファイルグループを増やします。 4)自動ログ管理をセットアップします。 5)データベースを再発射化します。ソリューションを実装する前に、データの損失を防ぐためにデータベースをバックアップすることをお勧めします。

CENTOSシステムにHadoop分散ファイルシステム(HDFS)を構築するには、複数のステップが必要です。この記事では、簡単な構成ガイドを提供します。 1.初期段階でJDKをインストールする準備:すべてのノードにJavadevelopmentKit(JDK)をインストールすると、バージョンはHadoopと互換性がある必要があります。インストールパッケージは、Oracleの公式Webサイトからダウンロードできます。環境変数構成: /etc /プロファイルファイルを編集し、JavaおよびHadoop環境変数を設定して、システムがJDKとHadoopのインストールパスを見つけることができるようにします。 2。セキュリティ構成:SSHパスワードなしログインSSHキーを生成する:各ノードでSSH-KeyGenコマンドを使用する

Oracleはデータベース会社だけでなく、クラウドコンピューティングとERPシステムのリーダーでもあります。 1。Oracleは、データベースからクラウドサービスおよびERPシステムへの包括的なソリューションを提供します。 2。Oraclecloudは、AWSとAzureに挑戦し、IAAS、PAAS、SAASサービスを提供します。 3. e-businesssuiteやfusionApplicationsなどのOracleのERPシステムは、企業がオペレーションを最適化するのに役立ちます。

Oracleデータベースを停止するには、次の手順を実行します。1。データベースに接続します。 2。すぐにシャットダウンします。 3.シャットダウンは完全に中止します。

SQLステートメントは、Oracleの動的SQLを使用して、ランタイム入力に基づいて作成および実行できます。手順には、次のものが含まれます。動的に生成されたSQLステートメントを保存するための空の文字列変数を準備します。 executeを即座に使用するか、ステートメントを準備して、動的なSQLステートメントをコンパイルおよび実行します。バインド変数を使用して、ユーザー入力またはその他の動的値を動的SQLに渡します。実行するか、実行するか、動的SQLステートメントを実行します。
