加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 电商 > 正文

操作动态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;

怎么样,感受差异凡响吧。但愿你能有更好的步伐。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读