mysql 排序问题
mysql 查询出一个数据列表 这个数据列表是分页的 比如说5个记录一页
$page = $_REQUEST['page'];select * from user limit ($page-1)*5,5;
然后查询的数组比如说为$user_list 然后循环这个user_list
foreach($user_list as $k=>$v){ // 然后根据某函数比如说 aa 计算出一个新的字段cc $user_list[$k]['cc'] = aa($v['id']);}
然后想按照cc这个字段排序user表 遇到的问题是 列表是分页的 第一页排序是正常 从小
到大排序 但是点击第二页又会出现从小到大排序 而不是已整体为依据 排序整个数据
cc 是经常变的字段,不能存到数据库 必须经由计算得出 请教一下大家有什么好的解决方法
回复讨论(解决方案)
可以在查询的时候把你的计算公式aa嵌套进语句中算出CC(如果aa不太复杂的话) 然后直接按CC排序即可
可以在查询的时候把你的计算公式aa嵌套进语句中算出CC(如果aa不太复杂的话) 然后直接按CC排序即可
但是比如说我写的这个sql distance的值就计算不出来$sql = "select id,avg_point,name,xpoint,ypoint,index_img,dp_count,deal_cate_id,ratio,note ,".intval(GetDistance($ypoint,$xpoint,'ypoint','xpoint')*1000)." as distance from ".DB_PREFIX."supplier_location where ".$where;
//把你的aa函数写成mysql的函数,然后用sqlselect *,aa(id)cc from table order by cc desc;
//把你的aa函数写成mysql的函数,然后用sqlselect *,aa(id)cc from table order by cc desc;
那应该怎么实现像这样的msyql自定义函数 aa(变量1,变量2,表字段1,表字段2)
那应该怎么实现像这样的msyql自定义函数 aa(变量1,变量2,表字段1,表字段2)
//你的aa函数就要4个变量select *,aa(变量1,变量2,字段1,字段2)cc from table order by cc desc;
http://www.baidu.com/s?wd=mysql%20%E8%87%AA%E5%AE%9A%E4%B9%89%E5%87%BD%E6%95%B0&rsv_spt=1&issp=1&f=8&rsv_bp=0&ie=utf-8&tn=baiduhome_pg&rsv_enter=1&rsv_sug3=3&rsv_sug4=97&rsv_sug1=3&rsv_sug2=0&inputT=2568
使用create temporary table temp
创建一个临时表,然后把cc计算好后作为字段保存在temp中,然后再对临时表排序,分页。
使用create temporary table temp
创建一个临时表,然后把cc计算好后作为字段保存在temp中,然后再对临时表排序,分页。
你只对读取到的部分数据进行了计算,当然排序的效果就不是预期的了
如果你是需要按距离排序,那么可以这样做:
假定表中有 X、Y 字段分别保存有商家的经纬度
$x、$y 表示用户的经纬度
则有 select * from user ORDER BY abs($x-X), abs($y-Y) limit ($page-1)*5,5;
一定要全部??排序後再分?。否?就不能??了。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...
