从容_ 2017-03-15 13:22 采纳率: 50%
浏览 1067

关于Oracle外键的问题,有的表创建不出来,求解决~

create table userinfo( /*用户表*/
id varchar(32) primary key,
name varchar(50),
password varchar(32)
);
/*仓库表*/
create table store(
id varchar(32) primary key,
name varchar(32),/*仓库名称*/
addr varchar(100),/*仓库所在地*/
manager varchar(32) /*仓库管理人员,不关联userinfo表*/
);

/*货物表*/
create table goods(
id varchar(32) primary key,
name varchar(50),/*货物名称*/
nm varchar(10),/*货物简记内码,如阿斯匹林为ASPL*/
unit varchar(10), /*计量单位,1:个,2:GK,3:只,..*/
amount numeric(10,2),/*库存数量*/
storeid varchar(32),/*所在仓库ID*/
constraint foreign KEY (storeid) references store(id)
);
/*出入库历史记录*/
create table history(
id varchar(32) primary key,
goodsid varchar(32),
datetime varchar(19),/*出入库时间*/
htype char(1),/*类型1:入库,2:出库*/
amount numeric(10,2),/*这次出入库的数量*/
remain numeric(10,2),/*余量*/
huser varchar(50), /*操作员名称,直接保存名称,不引用userinfo表*/
constraint foreign KEY (goodsid) references goods(id)
);

//用户表和仓库表已经创建完了,下面两张表创建出错,引用了外键。但就是创建出错。

//麻烦各位~

  • 写回答

2条回答 默认 最新

  • yelinliner 2017-03-16 13:38
    关注

    创建外键有两种:
    一种是创建表的时候就创建外键
    一种是创建表之后添加外键
    并且外键类型要保持一致
    ①goods表中:storeid varchar(32) references store(id)
    ②alter able goods add foreign key (storeid) references store(id);
    (你把constrain那句删掉,试试上面方法,希望有用吧)

    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog