id catid order
1 1 1
2 1 5
3 2 3
4 1 2
5 2 15
7 1 11
8 1 9
...
152 1 155
153 1 143
我需要的是根据一个ID,算出这个ID是当前CATID下的第几条记录
比如 给的 ID 是 7 对应的Catid是1 。 SQL语句就是:
SELECT * FROM `news_list` WHERE `TId` =1ORDER BY `order` ASC LIMIT x , 30
因为根据order排序,而且数据比较多。
需要解决的问题是:
比如给个ID=7 , 根据ID所属的Catid,计算出获取的结果中此ID的位置。(7是第4条记录)
立即学习“PHP免费学习笔记(深入)”;
希望大神们帮忙。
51shop 由 PHP 语言开发, 使用快速的 MySQL 数据库保存数据 ,为中小型网站实现网上电子商务提供一个完美的解决方案.一、用户模块1. 用户注册:用户信息包括:用户ID、用户名、用户密码、性别、邮箱、省份、城市、 联系电话等信息,用户注册后不能立即使用,需由管理员激活账号,才可使用(此功能管理员可设置)2. 登录功能3. 资料修改:用户可修改除账号以后的所有资料4. 忘记密码:要求用
ps:数据量大,不能先读出满足条件的所有记录,再判断。
我的回答如下:
set @i :=0;SELECT @i :=@i+1 as num,news_list.* FROM `news_list` WHERE `catid` =1ORDER BY `order` ASC LIMIT 0 , 30










