首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
MySQL及其它开源数据库
» mysql主键应该怎么设定?就是用自增字段吗?
‹‹ 上一主题
|
下一主题 ››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题: mysql主键应该怎么设定?就是用自增字段吗?
weilaiyxj
怒放的生命
来自 大连
精华贴数 0
个人空间
0
技术积分 519 (3716)
社区积分 3 (20465)
注册日期 2004-10-15
论坛徽章:0
#1
使用道具
发表于 2008-5-25 10:13
mysql主键应该怎么设定?就是用自增字段吗?
mysql主键应该怎么设定?就是用自增字段吗?
还是说应该有跟业务有关的字段作为主键。
__________________
我的blog
曾经多少次跌倒在路上曾经多少次折断过翅膀 如今我已不再感到彷徨我想超越这平凡的生活 我想要怒放的生命就象飞翔在辽阔的天空就象穿行在无边的旷野拥有挣脱一切的力量
只看该作者
jinguanding
Eugene
来自 上海
精华贴数 1
个人空间
70
技术积分 2397 (654)
社区积分 78 (3919)
注册日期 2007-3-29
论坛徽章:5
#2
使用道具
发表于 2008-5-25 13:30
QUOTE:
原帖由
weilaiyxj
于 2008-5-25 10:13 发表
mysql主键应该怎么设定?就是用自增字段吗?
还是说应该有跟业务有关的字段作为主键。
至于是那个字段作为自增字段,这个肯定根据你需求而定....
One Table have only one Auto_Increment that column is must to be Primary key.
至于你问: mysql主键应该怎么设定?就是用自增字段吗?
主键如何设置加上 Primary key或者结束定义的地方加上 Create Table tablename(................,Primary key(columnname))
主键是否要设置为 Auto_Increment的问题。。我觉得是不是问点有点太差了,也只有数字类型的字段可以设置为Auto_Increment,其他类型不行。。
没人说主键一定要是自增的,但是自增加的字段必须是主键且是数字类型
这下应该能看明白吧
__________________
.....做人做事尽心尽力,做学问谦虚求根问底.......
......***寻MySQL方面的兼职***......
.....专业的综合布线、安防公司........................
......www.showgold.cn..............................
......上海亮金信息技术有限公司.......................
只看该作者
weilaiyxj
怒放的生命
来自 大连
精华贴数 0
个人空间
0
技术积分 519 (3716)
社区积分 3 (20465)
注册日期 2004-10-15
论坛徽章:0
#3
使用道具
发表于 2008-5-26 10:34
可能是我问的不是太确切。
我说的怎么设定 应该是怎么选择的问题。 是不是专门有个自增字段当主键。 (而这个主键可以跟业务没有关系。)
__________________
我的blog
曾经多少次跌倒在路上曾经多少次折断过翅膀 如今我已不再感到彷徨我想超越这平凡的生活 我想要怒放的生命就象飞翔在辽阔的天空就象穿行在无边的旷野拥有挣脱一切的力量
只看该作者
jinguanding
Eugene
来自 上海
精华贴数 1
个人空间
70
技术积分 2397 (654)
社区积分 78 (3919)
注册日期 2007-3-29
论坛徽章:5
#4
使用道具
发表于 2008-5-26 11:38
我觉得已经说的非常清楚了,如何设置......
以及设置为自增字段的,必须具备的条件
你问的问题,确实有点让人难以理解
__________________
.....做人做事尽心尽力,做学问谦虚求根问底.......
......***寻MySQL方面的兼职***......
.....专业的综合布线、安防公司........................
......www.showgold.cn..............................
......上海亮金信息技术有限公司.......................
只看该作者
sky000
一般会员
精华贴数 0
个人空间
0
技术积分 207 (9131)
社区积分 1 (34896)
注册日期 2004-3-3
论坛徽章:1
#5
使用道具
发表于 2008-5-26 19:24
楼主,对于一个表主键的选择,从架构设计角度来说,尽量设计一个与业务无关的字段来作为主键会对系统更好
当然,这势必会增加表数据量的大小,可能有些人会认为这个副作用不值得而选择一个有业务意义的字段(或者多个字段)来作为主键
但是对于大多数时候,这个字段所增加的物理存储空间实际上是很小的,并没有很多人想象的那么可怕。而带来逻辑上的简单是很可观的。
另外,是否选择自增类型作为主键,这个可以说是各有好处,如果用自增,应用可以不care这个主键的值得设定,但是有在高并发下成为瓶颈的风险,当然如果并发并不是非常非常高的话,一般不会成为瓶颈。如果自己控制这个主键值的话,应哟娜更需要付出一点点代价来生成这个值,并发问题可以通过扩展应用集群来解决。
__________________
朝阳的天空
|
阿里巴巴DBA Team Blog
|
朝阳的Photo
只看该作者
yueliangdao0608
斑竹
上帝他爸
来自 中国-红灯区-深圳
精华贴数 0
个人空间
0
技术积分 3991 (359)
社区积分 1471 (736)
注册日期 2005-2-25
论坛徽章:19
#6
使用道具
发表于 2008-5-27 15:42
QUOTE:
原帖由
sky000
于 2008-5-26 19:24 发表
楼主,对于一个表主键的选择,从架构设计角度来说,尽量设计一个与业务无关的字段来作为主键会对系统更好
当然,这势必会增加表数据量的大小,可能有些人会认为这个副作用不值得而选择一个有业务意义的字段(或者多个字段)来作为主键
但是对于大多数时候,这个字段所增加的物理存储空间实际上是很小的,并没有很多人想象的那么可怕。而带来逻辑上的简单是很可观的。
另外,是否选择自增类型作为主键,这个可以说是各有好处,如果用自增,应用可以不care这个主键的值得设定,但是有在高并发下成为瓶颈的风险,当然如果并发并不是非常非常高的话,一般不会成为瓶颈。如果自己控制这个主键值的话,应哟娜更需要付出一点点代价来生成这个值,并发问题可以通过扩展应用集群来解决。
Yeah.auto_increment will be a bottleneck in the near future.
especially with the high concurrency.
__________________
-------------------------------------------------------
以前搞维护-搞软件-搞网站-现在搞DBA ---
点击这里访问我的技术博客
最近在练习英语中。。。
Losing my face!
只看该作者
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 体育世界
> 体育博彩专版
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计