mysql 排序id_mysql怎么按特定id排序

mysql如何按特定id排序

mysql如何按特定id排序

141758522.png

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for `p`

-- ----------------------------

DROP TABLE IF EXISTS `p`;

CREATE TABLE `p` (

`id` int(11) NOT NULL auto_increment,

`name` varchar(255) default NULL,

`categories_id` int(11) default NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of p

-- ----------------------------

INSERT INTO `p` VALUES ('1', 'jimmy', '2');

INSERT INTO `p` VALUES ('2', 'tina', '2');

INSERT INTO `p` VALUES ('3', 'dd', '2');

INSERT INTO `p` VALUES ('4', 'hello', '2');

INSERT INTO `p` VALUES ('5', 'world', '2');

INSERT INTO `p` VALUES ('6', 'slucky', '2');

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for `p_sort`

-- ----------------------------

DROP TABLE IF EXISTS `p_sort`;

CREATE TABLE `p_sort` (

`categories_id` int(10) NOT NULL default '0',

`best_sort_person_id` varchar(100) default NULL,

PRIMARY KEY (`categories_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of p_sort

-- ----------------------------

INSERT INTO `p_sort` VALUES ('2', '2,5,1');

------解决方案--------------------

select * from p, p_sort

order by find_in_set(p.id, p_sort.best_sort_person_id)>0 desc, find_in_set(p.id, p_sort.best_sort_person_id) asc, id

find_in_set(p.id, p_sort.best_sort_person_id)>0 desc 用于将id=2,5,1的排在前面

find_in_set(p.id, p_sort.best_sort_person_id) asc 用于将id=2,5,1的按出现次序排列

相关文章

相关视频

网友评论

文明上网理性发言,请遵守 新闻评论服务协议我要评论

47d507a036d4dd65488c445c0974b649.png

立即提交

专题推荐064df72cb40df78e80e61b7041ee044f.png独孤九贱-php全栈开发教程

全栈 100W+

主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门

7dafe36c040e31d783922649aefe0be1.png玉女心经-web前端开发教程

入门 50W+

主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门

04246fdfe8958426b043c89ded0857f1.png天龙八部-实战开发教程

实战 80W+

主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值