免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 10357 | 回复: 6
打印 上一主题 下一主题

请教如何添加或删除主键 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-06-14 16:23 |只看该作者 |倒序浏览
一张表内已经有了一个主键a ,我想使另外一个字段b和a共同构成主键和语句 primary key (a,b)的效果一样。

请问我该如何操作?谢谢了~!!

论坛徽章:
0
2 [报告]
发表于 2006-06-15 11:43 |只看该作者
既然有了一个a作主键,那么(b,a)作主键又有什么意义呢??

论坛徽章:
0
3 [报告]
发表于 2006-06-16 10:51 |只看该作者
原帖由 lmtok 于 2006-6-15 11:43 发表
既然有了一个a作主键,那么(b,a)作主键又有什么意义呢??


因为客户端写入数据库时要用a.b确定唯一性,里面的数据记录的是银行的帐号

论坛徽章:
0
4 [报告]
发表于 2006-06-16 10:58 |只看该作者
a 唯一
a b 组合一定唯一

建议重修数据库基本原理

论坛徽章:
0
5 [报告]
发表于 2006-06-19 02:06 |只看该作者
不是吧。。。没人知道啊。。。

无奈之下我用了个笨办法,先把数据库dbexport出来,然后修改建表脚本,把a设置主键的那条语句去掉,然后dbimport,最后将a,b设置为主键。

这也是无奈之举,对informix不熟悉,请老大们告知不修改脚本怎么在线改,谢谢了!

论坛徽章:
0
6 [报告]
发表于 2006-06-21 21:02 |只看该作者
select constrname from sysconstraints where constrtype='P' and tabid= ( select tabid from systables where tabname = '表名' ) ;
alter table tabname drop constraint constrname;
ALTER TABLE table_name
   ADD CONSTRAINT PRIMARY KEY (col_name1,col_name2,.....)
   CONSTRAINT constraint_name

论坛徽章:
0
7 [报告]
发表于 2006-06-21 22:37 |只看该作者
原帖由 vikily 于 2006-6-21 21:02 发表
select constrname from sysconstraints where constrtype='P' and tabid= ( select tabid from systables where tabname = '表名' ) ;
alter table tabname drop constraint constrname;
ALTER TABLE table_n ...


  谢谢~!!!受教了!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP