123
返回列表 发新帖
楼主: devilkin0312

[FAQ] 关于auto_increment列的问题

[复制链接]
论坛徽章:
27
数据库板块每日发贴之星
日期:2005-12-22 01:01:31ITPUB十周年纪念徽章
日期:2011-11-01 16:21:152012新春纪念徽章
日期:2012-02-13 15:12:092012新春纪念徽章
日期:2012-02-13 15:12:092012新春纪念徽章
日期:2012-02-13 15:12:092012新春纪念徽章
日期:2012-02-13 15:12:092012新春纪念徽章
日期:2012-02-13 15:12:09版主2段
日期:2012-05-15 15:24:11马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14
21#
发表于 2011-11-21 22:55 | 只看该作者
首先,规则不能乱; 一定是优先保证业务逻辑性; 再来优化性能;
其次,索引产生碎片,只要你是在删除数据的,肯定会有这个问题; 你去折腾去数据填回去,还不如定期REBUILD一下好了;
要是表太大就分区;  

使用道具 举报

回复
论坛徽章:
14
2011新春纪念徽章
日期:2011-04-02 17:01:062013年新春福章
日期:2013-02-25 14:51:24复活蛋
日期:2012-12-06 19:27:46ITPUB 11周年纪念徽章
日期:2012-10-09 18:16:00ITPUB 11周年纪念徽章
日期:2012-09-28 17:34:42紫蛋头
日期:2012-03-13 16:37:18灰彻蛋
日期:2012-02-06 14:20:122012新春纪念徽章
日期:2012-01-04 11:57:56灰彻蛋
日期:2011-12-26 14:20:13茶鸡蛋
日期:2011-12-20 15:00:13
22#
 楼主| 发表于 2011-11-22 09:52 | 只看该作者
Steven_1981 发表于 2011-11-21 22:55
首先,规则不能乱; 一定是优先保证业务逻辑性; 再来优化性能;
其次,索引产生碎片,只要你是在删除数据 ...

兄弟说的rebuild 指的是?

使用道具 举报

回复
论坛徽章:
11
鲜花蛋
日期:2011-09-03 18:52:38鲜花蛋
日期:2011-11-09 10:10:12茶鸡蛋
日期:2011-11-19 22:46:41茶鸡蛋
日期:2011-12-14 15:16:572012新春纪念徽章
日期:2012-01-04 11:57:56奥运会纪念徽章:赛艇
日期:2012-09-26 21:40:11ITPUB 11周年纪念徽章
日期:2012-10-09 18:16:002013年新春福章
日期:2013-02-25 14:51:24
23#
发表于 2011-11-22 18:08 | 只看该作者
rebuild 是不是drop and then recreate ?

使用道具 举报

回复
论坛徽章:
14
2011新春纪念徽章
日期:2011-04-02 17:01:062013年新春福章
日期:2013-02-25 14:51:24复活蛋
日期:2012-12-06 19:27:46ITPUB 11周年纪念徽章
日期:2012-10-09 18:16:00ITPUB 11周年纪念徽章
日期:2012-09-28 17:34:42紫蛋头
日期:2012-03-13 16:37:18灰彻蛋
日期:2012-02-06 14:20:122012新春纪念徽章
日期:2012-01-04 11:57:56灰彻蛋
日期:2011-12-26 14:20:13茶鸡蛋
日期:2011-12-20 15:00:13
24#
 楼主| 发表于 2011-11-24 11:55 | 只看该作者
测试了一个折中的办法,前提是自增长列并非业务数据,仅为innodb 表主键。
ALTER TABLE table DROP COLUMN id
ALTER TABLE table    ADD COLUMN `id` INT UNSIGNED NOT NULL AUTO_INCREMENT FIRST,    ADD PRIMARY KEY(`id`);
这样可以重新排序。对于数据增加很快的业务表还可以将id从1重新计数
当然代价和数据量的大小有关。



使用道具 举报

回复
论坛徽章:
14
2011新春纪念徽章
日期:2011-04-02 17:01:062013年新春福章
日期:2013-02-25 14:51:24复活蛋
日期:2012-12-06 19:27:46ITPUB 11周年纪念徽章
日期:2012-10-09 18:16:00ITPUB 11周年纪念徽章
日期:2012-09-28 17:34:42紫蛋头
日期:2012-03-13 16:37:18灰彻蛋
日期:2012-02-06 14:20:122012新春纪念徽章
日期:2012-01-04 11:57:56灰彻蛋
日期:2011-12-26 14:20:13茶鸡蛋
日期:2011-12-20 15:00:13
25#
 楼主| 发表于 2011-11-24 11:58 | 只看该作者
Steven_1981 发表于 2011-11-21 22:55
首先,规则不能乱; 一定是优先保证业务逻辑性; 再来优化性能;
其次,索引产生碎片,只要你是在删除数据 ...

1.可以停业务的话:重建新表,然后将数据导入新表,可以实现,有一个问题就是数据回放得时间问题
2.不停业务,如何在重建过程保证业务正常呢?

使用道具 举报

回复

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

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表