开发者社区> 问答> 正文

mysql如何按特定id排序

mysql如何按特定id排序 我想讲数据按某些特定id排前面,怎么做到?

Sql代码 收藏代码

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');

image.png

展开
收起
长安归故里. 2020-01-13 17:21:30 986 0
1 条回答
写回答
取消 提交回答
  • select e.* from (select a.*  from p a,p_sort b where a.categories_id = b.categories_id and find_in_set(a.id,b.best_sort_person_id)  order by find_in_set(a.id,b.best_sort_person_id))  e union  
    select a.*  from p a,p_sort b where a.categories_id = b.categories_id and not find_in_set(a.id,b.best_sort_person_id)   
    
    2020-01-13 17:21:42
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像