操作动态SQL办理排序题目
发布时间:2018-08-15 13:13:53 所属栏目:电商 来源:站长网
导读:我们常碰着一个存储进程要做都种排序的环境。凡是order by 的前提只有一个牢靠的,这是远远不足的。必要用一个变量来替代它,而Oracle有不能辨认Order by后头的字符串。该怎么办呢?先看看我的一个糟糕方案: IF myorderby='OBJECTID DESC' then --按名称
我们常碰着一个存储进程要做都种排序的环境。凡是order by 的前提只有一个牢靠的,这是远远不足的。必要用一个变量来替代它,而Oracle有不能辨认Order by后头的字符串。该怎么办呢?先看看我的一个糟糕方案: IF myorderby='OBJECTID DESC' then --按名称排序 OPEN outcur FOR SELECT * FROM( SELECT rownum rowno,t.* FROM ( SELECT OBJECTID , HITS,POSTTIME FROM CARTOON ORDER BY OBJECTID DESC) t WHERE rownum<endRow) WHERE rowno>=startRow; elsif myorderby='HITS DESC' then --按点击率排序 OPEN outcur FOR SELECT * FROM( SELECT rownum rowno,t.* FROM ( SELECT OBJECTID , HITS,POSTTIME FROM CARTOON ORDER BY HITS DESC') t WHERE rownum<endRow) WHERE rowno>=startRow; else --定时刻排序 OPEN outcur FOR SELECT * FROM( SELECT rownum rowno,t.* FROM ( SELECT OBJECTID , HITS,POSTTIME FROM CARTOON ORDER BY HITS DESC') t WHERE rownum<endRow) WHERE rowno>=startRow; END IF; 这固然是凡是行使的两种排序方法得以功过,但显得繁杂并且不足通用。 这时我的同事的好步伐: --------------------------------------------------------------------------- IF (myorderby is not null) then mysql:='SELECT * FROM( SELECT rownum rowno,t.* FROM ( SELECT OBJECTID , HITS,POSTTIME FROM CARTOON ORDER BY '|| myorderby || ') t WHERE rownum<' || endRow || ') WHERE rowno>=' || startRow; else mysql:='SELECT * FROM( SELECT rownum rowno,t.* FROM ( SELECT OBJECTID , HITS,POSTTIME FROM CARTOON ORDER BY posttime DESC) t WHERE rownum<' || endRow || ') WHERE rowno>=' || startRow; END IF; OPEN outcur FOR mysql; 怎么样,感受差异凡响吧。但愿你能有更好的步伐。 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |