ホームページ >バックエンド開発 >PHPチュートリアル >mysql特定のIDで並べ替える方法

mysql特定のIDで並べ替える方法

WBOY
WBOYオリジナル
2016-06-23 14:05:44944ブラウズ

mysql で特定の ID で並べ替える方法


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が1位です
find_in_set(p.id, p_sort.best_sort_person_id) ascはid=2,5,1のものを出現順にソートするために使用されます

xuzuning先生、crazy Kiss

SELECT p.*  FROM p INNER JOIN p_sort s ON p.categories_id=s.categories_id    ORDER BY IF(FIND_IN_SET(id,s.best_sort_person_id)>0,FIND_IN_SET(id,s.best_sort_person_id),id) ASC ;

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。