dtnpf35197 2014-03-23 14:40
浏览 44
已采纳

选择一个具有特定ID的项目,然后按字母顺序添加到其他所有项目

I have mySQL DB where I have this: link
I need to return result where first item will be item with id==1 and then add to that everything else in alphabetical order. This is what I want:
[Názov predmetu], [Algoritmizácia úloh], [Fyzika 1]...

Now Im using this:

<?php
    $result = mysql_query("SELECT nazov FROM tbPredmety ORDER BY nazov ASC");
    echo "<select name='subject_name'>";

    while ($row = mysql_fetch_assoc($result))
    {
        echo "<option value = '" . $row[nazov] . "'>" . $row[nazov] . "</option>";
    }

    echo "</select>";
?>
  • 写回答

1条回答 默认 最新

  • dongqian9567 2014-03-23 14:43
    关注

    You can add a CASE clause inside your ORDER BY clause:

    SELECT nazov 
    
    FROM tbPredmety 
    
    ORDER BY 
       -- item(s) with item_id 1 will appear first 
       CASE WHEN item_id = 1 THEN 0 ELSE 1 END, 
       nazov ASC
    

    I used THEN 0 ELSE 1 but for your purpose you could use any pair of values in which the former value is considered less than the latter value when sorting.

    EDIT: For mysql you may need to use CASE ... END CASE. If the above does not work try changing END to END CASE.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画