Oracle Ê÷µÄʹÓÃ(Connect By)
±í¡¡¡¡¡¡¡¡tree
¡¡¡¡×ֶΡ¡¡¡¡¡master
¡¡¡¡¡¡¡¡¡¡¡¡¡¡sub
¡¡¡¡¡¡¡¡¡¡¡¡¡¡sales
¡¡¡¡insert into tree values
¡¡¡¡('Ö÷1',¡¡¡¡ 'Ö÷2',¡¡ 15);¡¡
¡¡¡¡insert into tree values¡¡¡¡¡¡
¡¡¡¡('Ö÷1',¡¡¡¡ 'Ö÷3',¡¡ 20);¡¡¡¡¡¡¡¡¡¡
¡¡¡¡insert into tree values
¡¡¡¡('Ö÷2',¡¡¡¡ 'Ö÷4',¡¡¡¡5);¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡insert into tree values
¡¡¡¡('Ö÷2',¡¡¡¡ 'Ö÷5',¡¡ 10);
¡¡¡¡insert into tree values
¡¡¡¡('Ö÷3',¡¡¡¡ 'Ö÷5',¡¡ 30);
¡¡¡¡insert into tree values
¡¡¡¡('Ö÷3',¡¡¡¡ 'Ö÷6',¡¡ 40);
¡¡¡¡
¡¡¡¡SQL> select * from tree;
¡¡¡¡MASTER¡¡¡¡ SUB¡¡¡¡¡¡¡¡¡¡¡¡ SALES
¡¡¡¡---------- ---------- ----------
¡¡¡¡Ö÷1¡¡¡¡¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡15
¡¡¡¡Ö÷1¡¡¡¡¡¡¡¡Ö÷3¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡20
¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡Ö÷4¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡ 5
¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡Ö÷5¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡10
¡¡¡¡Ö÷3¡¡¡¡¡¡¡¡Ö÷5¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡30
¡¡¡¡Ö÷3¡¡¡¡¡¡¡¡Ö÷6¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡40¡¡
¡¡¡¡
¡¡¡¡Èç¹ûÓÃÊ÷Ðͽṹ±íʾÈçÏÂ:
¡¡¡¡¡¡'Ö÷1'¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡¡¡¡¡¡¡-'Ö÷2'¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡¡¡¡¡¡¡¡¡ --'Ö÷4'
¡¡¡¡¡¡¡¡¡¡¡¡ --'Ö÷5'
¡¡¡¡¡¡'Ö÷1'¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡¡¡¡¡¡¡-'Ö÷3'¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡¡¡¡¡¡¡¡¡ --'Ö÷5'
¡¡¡¡¡¡¡¡¡¡¡¡ --'Ö÷6'
¡¡¡¡
¡¡¡¡SQL> select * from tree¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡start with sub='Ö÷2'¡¡¡¡¡¡¡¡¡¡--Ï൱ÓÚÆÕͨsqlµÄwhereÌõ¼þ
¡¡¡¡connect by prior master=sub;¡¡--±éÀúµÄ˳ÐòÊÇsubÏÈÓÚmaster±éÀú£¬Ò²¾ÍÊÇ˵´ÓsubÍùÉϱéÀúÒ»Ö±µ½master(¸ù½Úµã)
¡¡¡¡¡¡2¡¡
¡¡¡¡MASTER¡¡¡¡ SUB¡¡¡¡¡¡¡¡¡¡¡¡ SALES
¡¡¡¡---------- ---------- ----------
¡¡¡¡Ö÷1¡¡¡¡¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡15
¡¡¡¡
¡¡¡¡
¡¡¡¡SQL> select * from tree¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡start with master='Ö÷2'
¡¡¡¡connect by prior master=sub; --subÍùÉϱéÀúÖÁ¸ù½Úµã£¨²Î¿¼Ò»ÏÂÊ÷ÐÍͼ£©¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡¡¡2¡¡¡¡3¡¡
¡¡¡¡MASTER¡¡¡¡ SUB¡¡¡¡¡¡¡¡¡¡¡¡ SALES¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡---------- ---------- ----------¡¡¡¡¡¡¡¡¡¡¡¡
¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡Ö÷4¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡ 5¡¡ --ÕâÌõÊÇ×Ô¼º±¾Éí£¬Ò²¾ÍÊǵÚÒ»±é±éÀú
¡¡¡¡Ö÷1¡¡¡¡¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡15¡¡ --ÕâÊǵÚ2´Î±éÀú£¬ÎÒÃÇ´ÓÊ÷ÐÍͼ¿ÉÒÔ¿´µ½£¬'Ö÷2'ÍùÉϱéÀúÊÇ'Ö÷1'¡¡¡¡¡¡¡¡
¡¡¡¡Ö÷2¡¡¡¡¡¡¡¡Ö÷5¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡10¡¡¡¡¡
Ïà¹ØÎĵµ£º
OleDbConnectioncon=newOleDbConnection(cnnstr);
try
{
con.Open();
}
catch
{}
OleDbCommandcmd=newOleDbCommand(strSQL,con);
System.Data.OleDb.OleDbDataReaderdr=cmd.ExecuteReader();
while(dr.Read())
{
stringdd=dr["gggg"].ToString();
byte[]ooo=(byte[])dr["hhhh"];
stringstr;
str=Sys ......
ÓбíA(×Ö¶ÎA1,A2)ºÍ±íB(×Ö¶ÎB1,B2).
×Ö¶ÎA2,B2É϶¼ÓÐË÷Òý.
A,B ±íÁª²é
sql1 Õâ¸ösql ·Ç³£¿ì 2ÃëµÄÑù×Ó
select * from A,B where A.A1=B.B1(+) and A2='Öµ1'
sql2 Õâ¸ösql Âýµ½ÈÃÈËÎÞ·¨ÈÌÊÜ
select * from A,B where A.A1=B.B1(+) and B2='Öµ1'
ÍâÁªÒÔºó ±íBÉϵÄË÷Òý²»Æð×÷ÓÃÁË.
Èç¹û»»³ÉÄÚÁª ËٶȺܿì.
sel ......
SQLµÄÓÅ»¯Ó¦¸Ã´Ó5¸ö·½Ãæ½øÐе÷Õû£º
1.È¥µô²»±ØÒªµÄ´óÐͱíµÄÈ«±íɨÃè
2.»º´æÐ¡ÐͱíµÄÈ«±íɨÃè
3.¼ìÑéÓÅ»¯Ë÷ÒýµÄʹÓÃ
4.¼ìÑéÓÅ»¯µÄÁ¬½Ó¼¼Êõ
5.¾¡¿ÉÄܼõÉÙÖ´Ðмƻ®µÄCost
SQLÓï¾ä£º
ÊǶÔÊý¾Ý¿â(Êý¾Ý)½øÐвÙ×÷µÄΩһ;¾¶£»
ÏûºÄÁË70%~90%µÄÊý¾Ý¿â×ÊÔ´£»¶ÀÁ¢ÓÚ³ÌÐòÉè¼ÆÂß¼£¬Ïà¶ÔÓÚ¶Ô³ÌÐòÔ´´úÂëµÄÓÅ»¯£¬¶ÔSQLÓï¾äµÄÓÅ»¯Ô ......
ÈÕ³£¿ª·¢»î¶¯ÖУ¬ÓÐʱºòÐèÒª¶ÔoracleÖ´Ðмƻ®½øÐÐ¼à¿Ø£¬ÒÔ´ËÀ´µ÷ÓųÌÐòºÍÊý¾Ý¿â·½ÃæµÄÐÔÄÜ¡£
³£Ó÷½·¨ÓÐÒÔϼ¸ÖÖ£º
Ò»¡¢Í¨¹ýPL/SQL Dev¹¤¾ß
1¡¢Ö±½ÓFile->New->Explain Plan Window£¬ÔÚ´°¿ÚÖÐÖ´ÐÐsql¿ÉÒԲ鿴¼Æ»®½á¹û¡£ÆäÖУ¬Cost±íʾcpuµÄÏûºÄ£¬µ¥Î»Îªn%£¬Cardinality±íʾִÐеÄÐÐÊý£¬µÈ¼ÛRow ......
SQLPlusÊÇoracleÌṩµÄÒ»¸öÃüÁîÐÐÖ´ÐеŤ¾ß
SQLPlusÖÐÓÃÁ½ÖÖÃüÁ
sqlplus£ºÒÔÃüÁîÐеķ½Ê½½øÈëÊý¾Ý¿âÁ¬½Ó
sqlplusw£ºÒÔ´°¿ÚµÄÐÎʽÆô¶¯ÃüÁîÐй¤¾ß ×¢£ºÖ÷»ú×Ö·û´®£¬ÊäÈëÊý¾Ý¿âÃû³Æ
&n ......