posts - 8, comments - 0, trackbacks - 0, articles - 11

          2012年9月7日

          一程序員家的水管壞了,他打電話叫來一個水管工修理。 水管工鼓搗了一個小時,終于把管子修好了,他遞給程序員一張600元的帳單。 “600元!”程序員憤怒地說:“我當程序員一天都賺不了這么多錢!” “是啊。”水管工平靜地說,“我當程序員的時候也是。”

          posted @ 2012-10-29 14:04 a_alter 閱讀(556) | 評論 (0)編輯 收藏

          例  如下
          表  A 
          (1--->n) 表B (B 可能為空)
          (n---->n)表C
          (n---->n)表D

          現在有如下問題  在查詢的時候我們允許b為空的A數據
          Select * from A,B where A.B_AID = B.AID(+)

          擴展查詢  如果進行B關聯C級別的條件過濾
          Select * from A,B, C where A.B_AID = B.AID(+) and B.C_AID = C.AID;  

          這個時候C能夠知道B是可以為空的, 這個時候的join效果是, 如果在A關聯B  B存在的情況下 在使用 C的join 條件進行篩選。 這個時候B為空的A條件還是可以擺查出來的。 只不過數據列B為空而已

          再進行擴展篩選  進行C關聯D級別的條篩選
          Select * from A,B,C,D where A.B_AID = B.AID(+) and B.C_AID = C.AID and C.D_AID = D.AID;  

          這樣的D級別的篩選就會破壞B級別的賽選。
          這個時候測試效果就是 D 級別的join條件 會破壞 B的left join 效果。

          你可能想到改寫條件如下
          Select * from A,B,C,D where A.B_AID = B.AID(+) and B.C_AID = C.AID and C.D_AID(+) = D.AID;  

          可惜我測試結果和full join 的效果是一樣的,不是oracle高手, 誰知道的留個言火鏈接  謝謝

          =======================================================================
          后來找同學幫忙  得知他以前也遇到這情況
          改寫為如下條件
          select * from (Select ....,C.D_AID from A,B,C where A.B_AID = B.AID(+) and B.C_AID = C.AID ) E,D where E.D_AID(+) = D.AID
          這樣就不會破壞B(+) 效果。  

          個人理解就是 select 的組織數據效果。具體不清楚 歡迎發言。

          =======================================================================
          補充:
          今天我才知道  left join 和 inner join 欄位是否必填還有關系。

          在這個問題上有個地方被欺騙了 

          就是在 A Left join B  inner JOIN C 的時候   如果 B 的 C 字段是必填的話  那么就相當于  left join。 如果不是必填的話 你必須手動的指示 left join (+)  。
          =====================================================================
          補充 2012/10/19   發現以上的理解不全面

          A--B(+) 意思指B 端可為空, 如果 對B -- C 下面的元素進行賽選, 在局部看 B 和 C 的關系是兩段都必須存在的, 但是在A -- B(+) 的前提下 C可以為空的,  所以需要使用 B --- C(+) 來進行關聯  這樣的壞處是可能會加載出 B  (存在)-- C (不存在) 這樣的錯誤數據。 當然如果系統中有對這種數據有確實保障的時候可以忽略該問題

          如果沒有確切的保障的話
          可能就需要使用 A --- D(+) 其中D 為  select * from B,C where B = C 這樣的過濾方式, 但是這樣就增加了復雜度, 你需要將可能用到的查詢條件和查詢結果集在D中 select 一一列出來

          在 Select A.*,R1,R2,R3 from A ,(select B.A_Aid,c1,c2,c3,R1,R2,R3 from B,C where B.C_AID= C.Aid) D where A.Aid = B.A_Aid and c1 = ? and c2 = ? ....

          Sql 復雜度高了一點。





          posted @ 2012-10-09 10:15 a_alter 閱讀(633) | 評論 (0)編輯 收藏

          本文用途:因為暫時沒有時間去具體看oracle sql的官方文檔 ,紀錄oracle的一些特殊寫法。 (不斷更新)
          1. with ...  as ...
          with querya as (select * from TB_Test)
          2  case .. (when .. then) .... (when ..  then) .. else ... end
              SELECT FO_FULFILL_TRX_STRING.SEQUENCE_NO, AC_TYPE_ORDER.CODE, CASE
              WHEN AC_TYPE_ORDER.CODE = 'SO'
              THEN ( SELECT ORDER_NUMBER FROM SO_ORDER WHERE SO_ORDER.AID = FO_FULFILL_TRX_STRING.AID_ORDER_SO )
              ELSE ( SELECT ORDER_NUMBER FROM PO_ORDER WHERE PO_ORDER.AID = FO_FULFILL_TRX_STRING.AID_ORDER_PO )
              END ORDER_NUMBER
              FROM FO_FULFILL_TRX_STRING, AC_TYPE_ORDER.CODE
          ------------------------------------------------------------------------------------------------------------------------------
          MYSQL 正則支持
          select * from tb_rule_list where expression regexp '^.*\\$\\{0}\\[3].*$';
          Oracle  正則函數支持
          ORACLE中的支持正則表達式的函數主要有
              REGEXP_LIKE :與LIKE的功能相似
              REGEXP_INSTR :與INSTR的功能相似
              REGEXP_SUBSTR :與SUBSTR的功能相似
              REGEXP_REPLACE :與REPLACE的功能相
           
          ------------------------------------------------------------------------------------------------------------------------------
          在MYSQL 中 select 可以顯示 不是group by 中的分組字段, 可以是任意的數據列,具體數據顯示的是分組后的第一行數據
          在ORACLE中 select 是嚴格的 只能顯示group by 中的字段。
          同樣效果的兩行sql --- 讓自己注意提高自己的使用靈活性
          1. select a.aid AAid,nvl(b.cot,0) countline from po_draft_order a,(select AID_DRAFT_ORDER_PO BAID,count(*) cot from  po_draft_line group by AID_DRAFT_ORDER_PO) b WHERE A.AID = B.BAID(+);
          2. select a.aid, (select count(*) from po_draft_line where AID_DRAFT_ORDER_PO = a.aid ) c from po_draft_order a;
          -------------------------------------------------------------------------------------------------------------------------------
          oracle 分級
          rank()/dense_rank()  over(partition by ... order by ...)  加強對分組排序之后的數據的控制力。
          over:  over(...)
          partition by :  相當于group by
          order by e.sal desc:  按工資從高到低排序(使用rank()/dense_rank() 時,必須要帶order by否則非法)
          rank()/dense_rank():  分級
          整個語句的意思就是:在按部門劃分的基礎上,按工資從高到低對雇員進行分級,“級別”由從小到大的數字表示(最小值一定為1)。 
          那么rank()和dense_rank()有什么區別呢?
          rank():  跳躍排序,如果有兩個第一級時,接下來就是第三級。
          dense_rank():  連續排序,如果有兩個第一級時,接下來仍然是第二級。
          min()/max() over(partition by ...)  // 分組最大最小值
          lead()/lag() over(partition by order by) // 前后數據比較使用
          lead(列名,n,m):  當前記錄后面第n行記錄的<列名>的值,沒有則默認值為m;如果不帶參數n,m,則查找當前記錄后面第一行的記錄<列名>的值,沒有則默認值為null。
          lag(列名,n,m):  當前記錄前面第n行記錄的<列名>的值,沒有則默認值為m;如果不帶參數n,m,則查找當前記錄前面第一行的記錄<列名>的值,沒有則默認值為null。
          主要是各個函數和over的配合使用。
          -----------------------------------------------------------------------------------------------------------------------------------------------------
          Oracle 的集合運算
          UNION 用來合并結果集 要求返回字段是一樣的。
          JOIN 用來合并字段。
          并集
          UNION ALL, FULL JOIN -- 重復出現
          UNION, INNER JOIN minus -- 一次出現
          交集
          intersect
          差集
          minus 
          笛卡爾積
          CROSS JOIN
          ------------------------------------------------------------------------------------------------------------------------------
          INNER JOIN oracle 特殊的寫法 不知道在sqlserver 是否支持。
          SELECT
          *
          FROM (
            SO_WEC_SODL_DESPATCH_HEADER AS SO_WEC_SODL_DESPATCH_HEADER_1
              INNER JOIN (
                (
                  SO_WARRANTY_ENTITLEMENT WET_1
                  INNER JOIN (SO_WARRANTY_ENTITLEMENT INNER JOIN SO_WEC_SODL
                  ON SO_WARRANTY_ENTITLEMENT.AID = SO_WEC_SODL.AID_WARRANTY_ENTITLEMENT_SO
                  ) ON (WET_1.AID_COMPANY = SO_WARRANTY_ENTITLEMENT.AID_COMPANY)
                  AND (WET_1.SEQ_ITEM_NUM = SO_WARRANTY_ENTITLEMENT.PARENT_SEQ_ITEM)
                  AND (WET_1.ITEM_LINE_NUM = SO_WARRANTY_ENTITLEMENT.PARENT_ITEM_NUM)
                  AND (WET_1.SO_LINE_NUM = SO_WARRANTY_ENTITLEMENT.PARENT_SOLINE_NUM)
                  AND (WET_1.SO_NUM = SO_WARRANTY_ENTITLEMENT.SO_NUM)
                )
                INNER JOIN SO_WEC_SODL AS SO_WEC_SODL_1 ON (SO_WEC_SODL.LINE_DELIVERY_NUMBER = SO_WEC_SODL_1.LINE_DELIVERY_NUMBER)
                AND (WET_1.AID = SO_WEC_SODL_1.AID_WARRANTY_ENTITLEMENT)
              ) ON SO_WEC_SODL_DESPATCH_HEADER_1.AID_WEC_SODL = SO_WEC_SODL_1.AID
          ) INNER JOIN SO_WEC_SODL_DESPATCH_HEADER ON SO_WEC_SODL.AID = SO_WEC_SODL_DESPATCH_HEADER.AID_WEC_SODL

          ===


          posted @ 2012-09-12 12:57 a_alter 閱讀(226) | 評論 (0)編輯 收藏

          今天看Richface4.2文檔的時候 發現變動很大 紀錄下

          RichFaces has been developed with an open architecture to be compatible with a wide variety of environments.

          Developing applications with the RichFaces framework requires the Java Development Kit (JDK), an implementation of JavaServer Faces (JSF), and a development environment.

          Java Development Kit (JDK)

          RichFaces supports the following JDK versions:

          JavaServer Faces (JSF)

          RichFaces supports the following JSF implementations and frameworks:

          Development environment

          RichFaces can be developed using most Java development environments. The following are recommended, and used for examples in this guide:







          posted @ 2012-09-10 17:20 a_alter 閱讀(344) | 評論 (0)編輯 收藏

            在Eclipse 編輯器中加入xmln 提示功能支持

            是針對項目設定的, 右擊項目選擇 Properties --》 Project Facets 勾選你需要使用的 schema定義、

          posted @ 2012-09-07 14:30 a_alter 閱讀(469) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 祥云县| 绥滨县| 陈巴尔虎旗| 海林市| 辽宁省| 邳州市| 那曲县| 托克托县| 桓仁| 科技| 章丘市| 丰城市| 诸城市| 太和县| 兴安盟| 台南市| 化德县| 永登县| 汉源县| 苏州市| 微博| 遂溪县| 当涂县| 枣强县| 河源市| 蚌埠市| 宁南县| 枣庄市| 科技| 安仁县| 河北区| 大余县| 甘孜县| 房山区| 晋江市| 定南县| 神农架林区| 响水县| 安吉县| 霍邱县| 土默特右旗|