亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

sql 多條件組合查詢,并根據指定類別找出所有最小子類別的SQL語句備忘

2020-07-25 13:34:33
字體:
來源:轉載
供稿:網友
復制代碼 代碼如下:

DECLARE @PAGESIZE INT
DECLARE @PAGEINDEX INT

DECLARE @PAGECOUNT INT
DECLARE @RECORDCOUNT INT

SELECT @PAGESIZE=5
SELECT @PAGEINDEX=1

DECLARE @FIELDNAME VARCHAR(50)
DECLARE @FIELDVALUE VARCHAR(50)
DECLARE @OPERATION VARCHAR(50)

--組合條件
DECLARE @WHERE NVARCHAR(1000)
SELECT @WHERE=' WHERE NOTDISPLAY=0 '

DECLARE ABC CURSOR FOR
SELECT FIELDNAME,FIELDVALUE,OPERATION FROM TBPARAMETERS
OPEN ABC
FETCH NEXT FROM ABC INTO @FIELDNAME,@FIELDVALUE,@OPERATION
WHILE @@FETCH_STATUS=0
BEGIN
    IF(@OPERATION = 'Like')
        SELECT @WHERE=@WHERE + ' AND ' + @FIELDNAME + ' Like ''%'+@FIELDVALUE+'%'''
    ELSE
    BEGIN
        IF(@FIELDNAME='CLASSID')
        BEGIN
            DECLARE @ROOTID INT
            SELECT @ROOTID=@FIELDVALUE
            --將指定類別的值的子類加入臨時表
            INSERT INTO TBTEMCLASS(ID) SELECT ID FROM TBSDINFOCLASS WHERE ROOTID=@ROOTID

            --使用游標來將指定類別的最小類別提出放入臨時表
            DECLARE CLASSID CURSOR FOR
            SELECT ID FROM TBTEMCLASS
            OPEN CLASSID
            FETCH NEXT FROM CLASSID INTO @ROOTID
            WHILE @@FETCH_STATUS=0
            BEGIN
                --如果判斷有子類則將子類加入臨時表,并刪除該類別,以使游標在臨時表中循環
                IF(EXISTS(SELECT ID FROM TBSDINFOCLASS WHERE ROOTID=@ROOTID))
                BEGIN
                    INSERT INTO TBTEMCLASS(ID) SELECT ID FROM TBSDINFOCLASS WHERE ROOTID=@ROOTID
                    DELETE FROM TBTEMCLASS WHERE ID=@ROOTID
                END
                FETCH NEXT FROM CLASSID INTO @ROOTID
            END
            CLOSE CLASSID
            DEALLOCATE CLASSID

            --將自身加入臨時表
            INSERT INTO TBTEMCLASS(ID) SELECT @FIELDVALUE

            SELECT @WHERE=@WHERE +' AND CLASSID IN(SELECT ID FROM TBTEMCLASS)'
        END
        ELSE
            SELECT @WHERE=@WHERE + ' AND ' + @FIELDNAME + @OPERATION+@FIELDVALUE
    END
    FETCH NEXT FROM ABC INTO @FIELDNAME,@FIELDVALUE,@OPERATION
END
CLOSE ABC
DEALLOCATE ABC

TRUNCATE TABLE TBPARAMETERS

-- --計數語句
DECLARE @COUNTSQL NVARCHAR(500)
SELECT @COUNTSQL=N'SELECT @RECORDCOUNT=COUNT(*) FROM TBSDINFO INNER JOIN TBUSER ON TBSDINFO.USERNAME=TBUSER.USERNAME '
SELECT @COUNTSQL=@COUNTSQL+@WHERE
--
-- --執行統計
EXEC sp_executesql @COUNTSQL,
     N'@RECORDCOUNT INT OUT',
     @RECORDCOUNT OUT
--
-- --計算頁數
SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
--
-- --查詢語句
DECLARE @SQL NVARCHAR(2000)
DECLARE @ORDERBY VARCHAR(100)
SELECT @ORDERBY=' ORDER BY TBSDINFO.IsCommon DESC,TBSDINFO.CommonTime DESC,TBSDINFO.CreateTime DESC'

IF(@PAGEINDEX=1)
BEGIN
    SELECT @SQL='INSERT INTO TBTEMINFO(ID,TITLE,REMARK,CREATETIME,ENDTIME,WEBDOMAIN,CLASSID,CLASSNAME,TYPEID,TYPENAME,PROVINCEID,PROVINCE,CITYID,CITY,COMPANYNAME,ADDRESS,USERTYPE) '
    SELECT @SQL=@SQL+'SELECT TOP '+CONVERT(VARCHAR(4),@PAGESIZE)+' TBSDINFO.ID,TITLE,Remark,TBSDINFO.Createtime,EndTime, WebDomain,TBSDINFO.CLASSID,(SELECT CLASSNAME FROM TBSDINFOCLASS WHERE TBSDINFOCLASS.ID=TBSDINFO.CLASSID) AS CLASSNAME,TYPEID,(SELECT TYPENAME FROM TBSDINFOTYPE WHERE TBSDINFO.TYPEID=TBSDINFOTYPE.ID) AS TYPENAME,ProvinceID,(SELECT PROVINCE FROM TBPROVINCE WHERE TBPROVINCE.ID=PROVINCEID) AS PROVINCE,CityID,(SELECT CITY FROM TBCITY WHERE TBCITY.ID=CITYID) AS CITY,CompanyName,TBSDINFO.Address,UserType FROM TBSDINFO INNER JOIN TBUSER ON TBUSER.USERNAME=TBSDINFO.USERNAME'
    SELECT @SQL=@SQL+@WHERE
    SELECT @SQL=@SQL+@ORDERBY
END
ELSE
BEGIN
    DECLARE @MINRECORD INT
    SELECT @MINRECORD=(@PAGEINDEX-1)*@PAGESIZE
    SELECT @SQL='INSERT INTO TBTEMINFO(ID,TITLE,REMARK,CREATETIME,ENDTIME,WEBDOMAIN,CLASSID,CLASSNAME,TYPEID,TYPENAME,PROVINCEID,PROVINCE,CITYID,CITY,COMPANYNAME,ADDRESS,USERTYPE) '
    SELECT @SQL=@SQL+'SELECT TOP '+CONVERT(VARCHAR(4),@PAGESIZE)+' TBSDINFO.ID, TITLE,Remark,TBSDINFO.Createtime,EndTime, WebDomain,TBSDINFO.CLASSID,(SELECT CLASSNAME FROM TBSDINFOCLASS WHERE TBSDINFOCLASS.ID=TBSDINFO.CLASSID) AS CLASSNAME,TYPEID,(SELECT TYPENAME FROM TBSDINFOTYPE WHERE TBSDINFO.TYPEID=TBSDINFOTYPE.ID) AS TYPENAME,ProvinceID,(SELECT PROVINCE FROM TBPROVINCE WHERE TBPROVINCE.ID=PROVINCEID) AS PROVINCE,CityID,(SELECT CITY FROM TBCITY WHERE TBCITY.ID=CITYID) AS CITY,CompanyName,TBSDINFO.Address,UserType FROM TBSDINFO INNER JOIN TBUSER ON TBUSER.USERNAME=TBSDINFO.USERNAME'
    IF(@WHERE<>'')
        SELECT @SQL=@SQL+@WHERE+' AND '
    ELSE
        SELECT @SQL=@SQL+' WHERE '        
    SELECT @SQL=@SQL+' TBSDINFO.ID NOT IN(SELECT TOP '+CONVERT(VARCHAR(4),@MINRECORD)+' TBSDINFO.ID FROM TBSDINFO INNER JOIN TBUSER ON TBUSER.USERNAME=TBSDINFO.USERNAME '+@WHERE+@ORDERBY+')'

    SELECT @SQL=@SQL+@ORDERBY
END

--PRINT @SQL

--執行查詢
--查詢的結果是將找到的記錄放入臨時表,再通過以下游標查詢出相應的父類與根類記錄
EXEC (@SQL)

DECLARE @CLASSID INT
DECLARE @ID INT

DECLARE TEM CURSOR FOR
SELECT ID,CLASSID FROM TBTEMINFO
OPEN TEM
FETCH NEXT FROM TEM INTO @ID,@CLASSID
WHILE @@FETCH_STATUS=0
BEGIN
    DECLARE @NS VARCHAR(500)
    DECLARE @DS VARCHAR(200)

    SELECT @NS=''
    SELECT @DS=''

    DECLARE @TEMROOTID INT

    DECLARE @TEMTS VARCHAR(50)
    SELECT @CLASSID=ID,@TEMTS=CLASSNAME,@TEMROOTID=ROOTID FROM TBSDINFOCLASS WHERE ID=@CLASSID
    SELECT @NS=@TEMTS+'#'+@NS
    SELECT @DS=CONVERT(VARCHAR(10),@CLASSID)+'#'+@DS

    WHILE(@TEMROOTID>0)
    BEGIN    
        SELECT @TEMROOTID=ROOTID,@CLASSID=ID,@TEMTS=CLASSNAME FROM TBSDINFOCLASS WHERE ID=@TEMROOTID
        SELECT @NS=@TEMTS+'#'+@NS
        SELECT @DS=CONVERT(VARCHAR(10),@CLASSID)+'#'+@DS
    END

    UPDATE TBTEMINFO SET NS=@NS,DS=@DS WHERE ID=@ID

    FETCH NEXT FROM TEM INTO @ID,@CLASSID
END
CLOSE TEM
DEALLOCATE TEM


SELECT * FROM TBTEMINFO

TRUNCATE TABLE TBTEMINFO
TRUNCATE TABLE TBTEMCLASS
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品中文视频在线| 日韩中文字幕视频在线| 91色精品视频在线| 91av在线国产| 亚洲精品国产精品国自产观看浪潮| 中文字幕亚洲国产| 1769国内精品视频在线播放| 性欧美xxxx交| 日韩av在线导航| 97福利一区二区| 国产精品69精品一区二区三区| 国产乱肥老妇国产一区二| 色yeye香蕉凹凸一区二区av| 亚洲成年人影院在线| 久久久久久亚洲精品| 久久伊人精品一区二区三区| 欧美性感美女h网站在线观看免费| 91嫩草在线视频| 欧美乱大交做爰xxxⅹ性3| 日韩成人性视频| 久久久精品免费| 欧美国产日韩免费| 成人欧美在线视频| 色综合视频网站| 欧美成人手机在线| 日韩久久精品成人| 亚洲毛茸茸少妇高潮呻吟| 亚洲国产精品va在线看黑人动漫| 懂色aⅴ精品一区二区三区蜜月| 亚洲国产私拍精品国模在线观看| 91久久国产精品| 国产成人小视频在线观看| 45www国产精品网站| 亚洲天天在线日亚洲洲精| 亚洲精品综合久久中文字幕| 欧美性videos高清精品| 日韩久久精品电影| 国产在线精品播放| 欧美激情视频播放| 欧美激情极品视频| 国产视频999| 亚洲视频在线播放| 亚洲欧美中文日韩v在线观看| 久久久久久九九九| 国产mv久久久| 激情久久av一区av二区av三区| 国产精品欧美日韩一区二区| 国产成人精品免费久久久久| 日韩欧美精品网站| 国产精品99久久久久久久久久久久| 国产成人鲁鲁免费视频a| 色多多国产成人永久免费网站| 最好看的2019年中文视频| 亚洲人成绝费网站色www| 欧美日韩精品二区| 亚洲国产精品久久久久| 97视频在线免费观看| 亚洲最新在线视频| 精品久久久久久电影| 中文字幕欧美精品日韩中文字幕| 综合国产在线观看| 91国产视频在线播放| 韩国精品久久久999| 国产免费一区二区三区香蕉精| 国产91精品久久久久久| 国产精品视频久| 成人深夜直播免费观看| 亚洲欧美一区二区三区久久| 91成人福利在线| 九九热精品视频在线播放| 久久综合电影一区| 亚洲国产精品久久久| 色狠狠久久aa北条麻妃| 欧美高清视频一区二区| 日韩一区视频在线| 色综合久久精品亚洲国产| 欧美日韩高清区| 国产视频精品免费播放| 97香蕉超级碰碰久久免费软件| 性色av一区二区三区免费| 欧美在线观看网站| 国产精品久久二区| 国产在线视频不卡| 亚洲欧洲日韩国产| 超碰97人人做人人爱少妇| 国产欧美在线观看| 亚洲一二三在线| 九九久久久久久久久激情| 国产成人在线精品| 久久久在线视频| 国产精品视频成人| 精品中文字幕久久久久久| 日韩精品高清视频| 欧美日韩激情网| 欧美午夜精品久久久久久久| 欧美日韩成人在线视频| 亚洲第一偷拍网| 亚洲国产精品久久精品怡红院| 亚洲第一页自拍| 久99九色视频在线观看| 欧美在线影院在线视频| 国产精品久久久久久久av大片| 欧美怡春院一区二区三区| 2021国产精品视频| 91高清在线免费观看| 亚洲日韩欧美视频一区| 亚洲欧美日韩一区二区三区在线| 国产精品美女主播在线观看纯欲| 久久国产精品久久久| 亚洲欧美中文日韩在线| 欧美午夜精品久久久久久浪潮| www.日本久久久久com.| 国产精品第七影院| 日本亚洲欧美三级| 亚洲精品美女久久久久| 欧美性xxxx极品hd满灌| 精品国产一区二区三区久久狼黑人| 亚洲电影在线观看| 久久久免费在线观看| 久久成人亚洲精品| 日韩成人黄色av| 亚洲欧洲第一视频| 亚洲欧洲高清在线| 国产免费一区二区三区在线观看| 久久久伊人欧美| 国产精品成人观看视频国产奇米| 黑人精品xxx一区一二区| 深夜福利国产精品| 美女福利视频一区| 欧美性猛交xxxx黑人| 欧美一二三视频| 亚洲自拍小视频| 国产免费亚洲高清| 亚洲国产精品va在看黑人| 一区二区三区回区在观看免费视频| 欧美激情视频在线| 亚洲欧美精品suv| 国产亚洲精品综合一区91| 亚洲天堂av综合网| 欧美精品久久久久久久免费观看| 亚洲人午夜精品| 97av视频在线| 亚洲综合社区网| 国产在线观看精品一区二区三区| 一本色道久久综合狠狠躁篇的优点| 日本高清不卡在线| 久久久影视精品| 久久久久亚洲精品国产| 日韩免费观看av| 国产日韩在线播放| 久久视频在线直播| 91免费的视频在线播放| 欧美日韩在线观看视频小说| 久久的精品视频| 2024亚洲男人天堂| 久久久久日韩精品久久久男男| 日韩电影第一页| 国产精品高清在线观看| 国产精品一区二区在线| 精品久久久久久中文字幕一区奶水| 久久av在线看| 色系列之999| 在线视频精品一| 国产精品一区二区三|