• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            SQL 統計體驗

            Posted on 2007-07-13 09:32 小蘇 閱讀(684) 評論(0)  編輯 收藏 引用

            今日見小王同志眉頭微皺,心想這兄臺必然遇到難題,遂問其故。果不其然,他在通過日志表統計用戶使用情況時創建試圖屢屢失敗。
            我以前也沒有做過類似的SQL,但又想這實現總該不難,于是拿來分析,情況如下:
            表1-日志表,表結構如下:
            ID,F_LOGIN,MTime,ManageName 這ID是主鍵(ID在我看來都是主鍵,下文不再贅述),F_LOGIN是用戶的登陸名縮寫,MTime是用戶的操作時間,ManageName是用戶操作的模塊名稱
            表2-用戶表,結構如下:
            ID,F_ORDER,F_LOGIN,F_USERNAME,F_DEPTNAME...,F_ORDER是用戶的順序號,F_LOGIN是用戶的登陸名縮寫,F_USERNAME是用戶的中文名,F_DEPTNAME是用戶所在單位的名稱
            表3-部門表,結構如下:
            ID,F_DEPTORDER,F_DEPTNAME F_DEPTORDER是部門順序號,F_DEPTNAME是部門名稱。

            好了,就是這么三個表,客戶要求根據統計用戶對每個模塊的使用次數,并要求按照部門順序進行排序,并且統計結果排除管理帳號admin:
            怎么辦? 看到小王以前的視圖是:

            SELECT  用戶表.F_DEPTNAME, COUNT(*)
                  AS count, 部門表.F_ORDER
            FROM 日志表 INNER JOIN
                  用戶表 ON
                  日志表.F_login = 用戶表.F_LOGIN INNER JOIN
                  部門表 ON
                  用戶表.F_DEPTNAME = 部門表.F_DEPATNAME
            WHERE (日志表.F_login <> 'admin')
            GROUP BY 用戶表.F_DEPTNAME,
                  部門表.F_NO
            ORDER BY 部門表.F_NO

            郁悶,這試圖看起來沒什么問題啊,但是一運行問題就來了:
            考,如果部門A的用戶都沒有使用,也就是日志表里沒有記錄,那么視圖里根本就不會顯示該單位,但是很明顯這樣不對,我們需要沒有使用的單位顯示次數為0嘛,
            我想辦法不是明擺著的嘛,把"INNER JOIN 部門表"改為"RIGHT JOIN"部門表不就ok了么,好,改變:

            SELECT  用戶表.F_DEPTNAME, COUNT(*)
                  AS count, 部門表.F_ORDER
            FROM 日志表 INNER JOIN
                  用戶表 ON
                  日志表.F_login = 用戶表.F_LOGIN RIGHT JOIN
                  部門表 ON
                  用戶表.F_DEPTNAME = 部門表.F_DEPATNAME
            WHERE (日志表.F_login <> 'admin')
            GROUP BY 用戶表.F_DEPTNAME,
                  部門表.F_NO
            ORDER BY 部門表.F_NO

            運行,又郁悶,怎么還是沒有出現,抓耳撓腮半晌弄不明白,心想反正老子最不怕的就是困難(最怕的是美女放電^_^),我一句一句來,調試、調試,終于發現問題所在:
            "WHERE (日志表.F_login <> 'admin')"
            當Right join以后,沒有操作的部門會在視圖留下一條記錄,而這條記錄只包含部門表的信息,用戶表和日志表均為NULL,NULL是沒有辦法和'admin'比較的,也就是說NULL <> 'admin' 返回的是false,怎么辦?調整視圖join的次序,如下:
            SELECT  用戶表.F_DEPTNAME, COUNT(*)
                  AS count, 部門表.F_ORDER
            FROM 用戶表 INNER JOIN
                  部門表 ON
                  用戶表.F_DEPTNAME = 部門表.F_DEPATNAME LEFT JOIN
                  日志表 ON
                  日志表.F_login = 用戶表.F_LOGIN
            WHERE (用戶表.F_login <> 'admin')
            GROUP BY 用戶表.F_DEPTNAME,
                  部門表.F_NO
            ORDER BY 部門表.F_NO

            這樣不管怎么變,這所有用戶和部門都是有的,而且admin也過濾的,但是....不對啊,怎么沒有用戶的單位使用次數都很大啊,哦,原來是我用的count(*)
            有問題,肯定得用sum函數啦。查查聯機叢書,最后定稿如下:
            SELECT  用戶表.F_DEPTNAME,
            SUM(CASE WHEN 統計表.F_login IS NULL THEN 0 ELSE 1 END) as count,
            部門表.F_ORDER
            FROM 用戶表 INNER JOIN
                  部門表 ON
                  用戶表.F_DEPTNAME = 部門表.F_DEPATNAME LEFT JOIN
                  日志表 ON
                  日志表.F_login = 用戶表.F_LOGIN
            WHERE (用戶表.F_login <> 'admin')
            GROUP BY 用戶表.F_DEPTNAME,
                  部門表.F_NO
            ORDER BY 部門表.F_NO


            終于搞定了,萬歲!!不過CASE的使用也分兩種,一種是簡單CASE函數,一種是CASE搜索函數,聯機從書中關于when_expression 和Boolean_expression 寫的很籠統,我的理解when_expression就是一個值,而Boolean_expression是一個判斷,嗯,寫這個破東西也婆婆媽媽的寫了半個小時,到此收筆。

            国产亚洲精久久久久久无码77777| 狠狠色婷婷久久综合频道日韩 | 久久er99热精品一区二区| 性欧美大战久久久久久久久| 国产一久久香蕉国产线看观看| 天天爽天天爽天天片a久久网| 亚洲一级Av无码毛片久久精品| 久久综合亚洲欧美成人| 久久久久国产精品麻豆AR影院| 亚洲综合日韩久久成人AV| 久久e热在这里只有国产中文精品99 | 国产V亚洲V天堂无码久久久| 色综合合久久天天给综看| 久久无码av三级| 亚洲色婷婷综合久久| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久最近最新中文字幕大全| 免费久久人人爽人人爽av| 国产精品久久久久久久久久免费| 无码AV波多野结衣久久| 午夜精品久久久久久影视777| 一级做a爰片久久毛片人呢| MM131亚洲国产美女久久| 伊人久久综合成人网| 亚洲欧洲中文日韩久久AV乱码| 99精品久久精品一区二区| 日韩人妻无码精品久久久不卡| 久久笫一福利免费导航 | 国产精品免费福利久久| 久久综合噜噜激激的五月天 | 久久香蕉一级毛片| 国产综合久久久久| 熟妇人妻久久中文字幕| 日本强好片久久久久久AAA | 亚洲国产精品综合久久一线| 色综合久久久久综合99| 免费精品久久久久久中文字幕| 久久久久女教师免费一区| 蜜桃麻豆www久久国产精品| 性做久久久久久久久浪潮| 国内精品伊人久久久久777|