青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

SQL 統計體驗

Posted on 2007-07-13 09:32 小蘇 閱讀(687) 評論(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是一個判斷,嗯,寫這個破東西也婆婆媽媽的寫了半個小時,到此收筆。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品热久久久久夜色精品三区| 亚洲欧洲日本一区二区三区| 国产精品午夜电影| 欧美激情国产日韩| 久色婷婷小香蕉久久| 久久亚洲欧美国产精品乐播| 久久亚洲综合| 欧美高清在线观看| 欧美日韩在线亚洲一区蜜芽| 欧美三级资源在线| 国产精品羞羞答答| 红桃视频国产一区| 91久久国产综合久久蜜月精品 | 国产精品一区二区三区成人| 国产视频一区二区在线观看| 激情成人av在线| 亚洲精品孕妇| 亚洲综合色丁香婷婷六月图片| 午夜精品一区二区三区在线视| 久久久成人精品| 亚洲国产精品久久久久婷婷884| aa级大片欧美三级| 久久成人免费电影| 欧美人成在线| 国产一区二区高清| 亚洲精品欧美| 欧美一区二区日韩| 欧美激情精品久久久久久大尺度| 99综合在线| 亚洲欧洲一区二区在线观看| 欧美91大片| 国产精品入口麻豆原神| 一区二区三区我不卡| 日韩视频在线观看免费| 香蕉久久a毛片| 欧美寡妇偷汉性猛交| 亚洲一区欧美一区| 欧美xx69| 亚洲成在人线av| 欧美亚洲视频一区二区| 亚洲国产精品va在线看黑人动漫| 亚洲一区二区三区四区在线观看| 免费看黄裸体一级大秀欧美| 国产精品区一区二区三区| 亚洲国产美女| 久久蜜臀精品av| 美女露胸一区二区三区| 亚洲一区二区免费视频| 欧美精彩视频一区二区三区| 亚洲东热激情| 久久综合伊人77777蜜臀| 亚洲在线黄色| 欧美日本一区| 亚洲精品欧美激情| 欧美成人免费网站| 久久精品免费| 国产日韩欧美在线看| 亚洲女人av| 在线一区观看| 欧美午夜一区二区| 在线一区二区三区做爰视频网站 | 国产精品亚洲激情| 亚洲一区二区黄| 亚洲精品小视频在线观看| 欧美77777| 亚洲欧洲日产国产网站| 亚洲电影自拍| 欧美成人免费一级人片100| 亚洲国产午夜| 欧美激情aaaa| 欧美精品日日鲁夜夜添| 日韩一级精品视频在线观看| 亚洲国产二区| 欧美二区乱c少妇| 亚洲欧洲一区二区在线观看| 亚洲国产精品一区在线观看不卡 | 亚洲午夜精品久久久久久app| 国产精品盗摄久久久| 先锋影音网一区二区| 久久高清一区| 亚洲欧洲在线观看| 亚洲精品久久久久中文字幕欢迎你 | 最新日韩中文字幕| 亚洲国产一区二区三区a毛片| 欧美精品一卡二卡| 亚洲免费婷婷| 久久黄色小说| 亚洲七七久久综合桃花剧情介绍| 亚洲区中文字幕| 欧美午夜免费影院| 久久精品中文| 你懂的视频欧美| 99www免费人成精品| 亚洲美女淫视频| 国产精品99久久不卡二区| 国产一区二区三区免费观看| 久久久午夜视频| 久久久国产精品一区二区三区| 尤物九九久久国产精品的分类| 欧美福利一区| 久久se精品一区二区| 亚洲另类一区二区| 亚洲视频精品| 国产一区二区欧美日韩| 欧美成人精品福利| 欧美日本免费| 久久本道综合色狠狠五月| 免费在线播放第一区高清av| 国产精品va在线播放| 久久精品一本| 欧美成人一区二区| 欧美一级久久久久久久大片| 久久精品国产77777蜜臀| 亚洲人成小说网站色在线| 亚洲人成亚洲人成在线观看图片| 欧美国产日韩一区二区在线观看| 亚洲小说春色综合另类电影| 亚洲欧美日韩国产| 亚洲激情中文1区| 亚洲素人一区二区| 在线观看三级视频欧美| 99riav久久精品riav| 亚洲精品视频啊美女在线直播| 亚洲一区二区成人| 亚洲国产一区二区精品专区| 亚洲天堂成人在线视频| 在线观看精品| 亚洲一区在线看| 国产在线精品成人一区二区三区| 一本高清dvd不卡在线观看| 有码中文亚洲精品| 亚洲午夜电影| 9色国产精品| 久久亚洲一区二区三区四区| 亚洲免费在线播放| 欧美成人午夜激情在线| 久久久久久香蕉网| 国产精品成人v| 亚洲动漫精品| 在线观看国产精品网站| 香蕉成人久久| 久久精品一二三| 国产精品久久久久久久久| 亚洲国产婷婷香蕉久久久久久99 | 美女视频黄a大片欧美| 国产精品高潮呻吟久久| 欧美伊人久久久久久久久影院| 欧美亚洲不卡| 亚洲欧洲在线一区| 亚洲国产中文字幕在线观看| 久久精品毛片| 久久亚洲一区二区| 国产欧美日韩视频| 亚洲一区精彩视频| 亚洲欧美日韩国产中文| 欧美午夜视频网站| 这里只有精品在线播放| 亚洲自拍偷拍网址| 久久久久国产一区二区三区四区| 久久久久久久欧美精品| 亚洲激精日韩激精欧美精品| 蜜臀久久久99精品久久久久久 | 亚洲国产视频一区| 99精品热视频| 欧美日韩视频一区二区三区| 久久成人在线| 亚洲精选视频在线| 欧美精品激情| 一本大道久久a久久精品综合| 正在播放亚洲| 国产精品视频999| 久久亚洲春色中文字幕久久久| 免费看成人av| 国产真实久久| 亚洲午夜女主播在线直播| 一本久久青青| 欧美视频精品在线| 亚洲欧美视频一区二区三区| 欧美专区亚洲专区| 国产一区二区久久久| 久久久久国产精品午夜一区| 欧美高清在线精品一区| 在线亚洲激情| 国产一区二区精品久久91| 一区二区三区日韩| 亚洲福利视频在线| 亚洲欧美成人| 亚洲福利在线看| 欧美性大战久久久久久久蜜臀| 日韩一级在线观看| 亚洲电影一级黄| 亚洲制服少妇| 亚洲第一偷拍| 欧美日韩和欧美的一区二区| 最新亚洲电影| 欧美插天视频在线播放| 亚洲一区二区三区在线视频| 国产自产女人91一区在线观看| 欧美另类69精品久久久久9999| 亚洲一区二区三区在线|