<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

    2012年10月29日

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

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

    2012年10月9日

    例  如下
    表  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 閱讀(627) | 評論 (0)編輯 收藏

    2012年9月12日

    本文用途:因為暫時沒有時間去具體看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 閱讀(223) | 評論 (0)編輯 收藏

    2012年9月10日

    今天看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 閱讀(341) | 評論 (0)編輯 收藏

    2012年9月7日

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

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

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

    2012年8月30日

    前序

    用了seam也快一年了, 可惜一直是在做開發, 今天決定回頭總結下, 并且去看一下JSF , SEAM 的配置。

    seam 簡單介紹

    直接看英文吧, 翻譯的不行

    Seam is a powerful open source development platform for building rich Internet applications in Java. Seam integrates technologies such as Asynchronous JavaScript and XML (AJAX), JavaServer Faces (JSF), Java Persistence (JPA), Enterprise Java Beans (EJB 3.0) and Business Process Management (BPM) into a unified full-stack solution, complete with sophisticated tooling.

    Seam has been designed from the ground up to eliminate complexity at both architecture and API levels. It enables developers to assemble complex web applications using simple annotated Java classes, a rich set of UI components, and very little XML. Seam's unique support for conversations and declarative state management can introduce a more sophisticated user experience while at the same time eliminating common bugs found in traditional web applications.


    我們可以看到seam 和 jsf,jpa,ejb 結合比較緊密,提供了annotation 方式支持, 提供了大量的 ui components 支持。

    想說的一點是, seam不是一個框架, 而是一個平臺。


    附:
    JSF 資料查詢  http://caterpillar.onlyfun.net/Gossip/JSF/IntroduceJSF.htm

    http://docs.oracle.com/javaee/5/tutorial/doc/bnaph.html

    ==== seam 提供了一個定制的eclipse版本用于seam開發,省了很多事

    posted @ 2012-08-30 09:38 a_alter 閱讀(193) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 久久青青草原亚洲av无码| 青草草在线视频永久免费| 亚洲人成网站在线观看播放| 亚洲av中文无码字幕色不卡| 毛片免费全部免费观看| 亚洲一区免费视频| 精品久久久久成人码免费动漫| 91在线亚洲精品专区| 中文字幕免费在线| 亚洲国产精品美女| 日本免费一区二区在线观看| 亚洲国产精品综合久久久| 91精品免费久久久久久久久| 亚洲熟妇av一区二区三区下载| 亚洲网站免费观看| 亚洲最大的成人网站| 女人18毛片免费观看| 爱情岛论坛亚洲品质自拍视频网站| 免费大片在线观看网站| 国产精品极品美女自在线观看免费| 亚洲人午夜射精精品日韩| a视频免费在线观看| 亚洲欧洲日产韩国在线| 久久久久久99av无码免费网站| 久久水蜜桃亚洲AV无码精品 | www一区二区www免费| 亚洲一区二区三区自拍公司| 无码日韩精品一区二区三区免费| 麻豆亚洲av熟女国产一区二| 欧美三级在线电影免费| 搜日本一区二区三区免费高清视频| 亚洲午夜久久久久久久久电影网| 久久伊人免费视频| 亚洲一卡2卡三卡4卡无卡下载| 免费乱码中文字幕网站| 中文字幕无码日韩专区免费| 亚洲AV成人噜噜无码网站| 四虎影库久免费视频| 午夜视频免费在线观看| 亚洲精华国产精华精华液好用 | 1000部拍拍拍18勿入免费视频软件|