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

关于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 这个电路是如何实现路灯控制器的,原理是什么,怎么求解灯亮起后熄灭的时间如图?
  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 file converter 转换格式失败 报错 Error marking filters as finished,如何解决?
  • ¥15 ubuntu系统下挂载磁盘上执行./提示权限不够
  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 关于#r语言#的问题:差异分析前数据准备,报错Error in data[, sampleName1] : subscript out of bounds请问怎么解决呀以下是全部代码:
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)