MySQL社区

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 3108|回复: 2
打印 上一主题 下一主题

[SQL类] 表排序问题。

[复制链接]
1#
发表于 2012-5-10 10:08:42 | 显示全部楼层
给你存储过程,按照你的需求,你稍微加工下,基本就OK了
DELIMITER $$

USE `test`$$

DROP PROCEDURE IF EXISTS `test_1`$$

CREATE DEFINER=`admin`@`%` PROCEDURE `test_1`()
BEGIN
        DECLARE v_id        INT;
        DECLARE v_Max        INT;
        DECLARE v_Min        INT;
        DECLARE v_flag         INT;
        DECLARE v_count INT;
        SELECT COUNT(id) INTO v_count FROM test123;
        SELECT MAX(COUNT),MIN(COUNT) INTO v_Max,v_Min FROM test123;
        SET v_flag=1;
       
        WHILE v_Max >= v_Min DO
                SELECT id INTO v_id FROM test123 WHERE COUNT=v_Max;
                IF FOUND_ROWS() >=1 THEN
                        UPDATE test123 SET rank=v_flag WHERE id=v_id;
                        SET v_flag=v_flag+1;
                END IF;
                SET v_Max = v_Max - 1;
                SELECT v_id;
        END WHILE;
END$$

DELIMITER ;

点评

强!  发表于 2012-5-10 11:43

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|申请友链|小黑屋|Archiver|手机版|MySQL社区 ( 京ICP备07012489号   
联系人:周生; 联系电话:13911732319

GMT+8, 2024-5-20 17:40 , Processed in 0.066450 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表