关于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/imghwm/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

MySQLstringtypesimpactstorageandperformanceasfollows:1)CHARisfixed-length,alwaysusingthesamestoragespace,whichcanbefasterbutlessspace-efficient.2)VARCHARisvariable-length,morespace-efficientbutpotentiallyslower.3)TEXTisforlargetext,storedoutsiderows,

MySQLstringtypesincludeVARCHAR,TEXT,CHAR,ENUM,andSET.1)VARCHARisversatileforvariable-lengthstringsuptoaspecifiedlimit.2)TEXTisidealforlargetextstoragewithoutadefinedlength.3)CHARisfixed-length,suitableforconsistentdatalikecodes.4)ENUMenforcesdatainte

MySQLoffersvariousstringdatatypes:1)CHARforfixed-lengthstrings,2)VARCHARforvariable-lengthtext,3)BINARYandVARBINARYforbinarydata,4)BLOBandTEXTforlargedata,and5)ENUMandSETforcontrolledinput.Eachtypehasspecificusesandperformancecharacteristics,sochoose

TograntpermissionstonewMySQLusers,followthesesteps:1)AccessMySQLasauserwithsufficientprivileges,2)CreateanewuserwiththeCREATEUSERcommand,3)UsetheGRANTcommandtospecifypermissionslikeSELECT,INSERT,UPDATE,orALLPRIVILEGESonspecificdatabasesortables,and4)

ToaddusersinMySQLeffectivelyandsecurely,followthesesteps:1)UsetheCREATEUSERstatementtoaddanewuser,specifyingthehostandastrongpassword.2)GrantnecessaryprivilegesusingtheGRANTstatement,adheringtotheprincipleofleastprivilege.3)Implementsecuritymeasuresl

ToaddanewuserwithcomplexpermissionsinMySQL,followthesesteps:1)CreatetheuserwithCREATEUSER'newuser'@'localhost'IDENTIFIEDBY'password';.2)Grantreadaccesstoalltablesin'mydatabase'withGRANTSELECTONmydatabase.TO'newuser'@'localhost';.3)Grantwriteaccessto'

The string data types in MySQL include CHAR, VARCHAR, BINARY, VARBINARY, BLOB, and TEXT. The collations determine the comparison and sorting of strings. 1.CHAR is suitable for fixed-length strings, VARCHAR is suitable for variable-length strings. 2.BINARY and VARBINARY are used for binary data, and BLOB and TEXT are used for large object data. 3. Sorting rules such as utf8mb4_unicode_ci ignores upper and lower case and is suitable for user names; utf8mb4_bin is case sensitive and is suitable for fields that require precise comparison.

The best MySQLVARCHAR column length selection should be based on data analysis, consider future growth, evaluate performance impacts, and character set requirements. 1) Analyze the data to determine typical lengths; 2) Reserve future expansion space; 3) Pay attention to the impact of large lengths on performance; 4) Consider the impact of character sets on storage. Through these steps, the efficiency and scalability of the database can be optimized.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver CS6
Visual web development tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Linux new version
SublimeText3 Linux latest version

Zend Studio 13.0.1
Powerful PHP integrated development environment

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
