oracle 02267,sql - ORA-02267 :(列类型与引用的列类型不兼容)尽管数据类型是相同的 - 堆栈内存溢出...

我正在尝试使用time_id,product_id和customer_id的复合外键创建表SALESDATA。

我收到错误消息:

引用列的数据类型或排序规则与引用列的数据类型或排序规则不兼容。

由于我的外键的数据类型与引用表的主键相同,因此我想知道这种情况下的排序规则以及这可能如何解决我的问题。

这是供参考的代码:

create table ach131.TIME(

time_id NUMBER(*,0),

orderdate TIMESTAMP,

primary key(time_id)

);

create table ach131.PRODUCT(

product_id CHAR(10 BYTE),

p_description CHAR (50 BYTE),

p_salesprice NUMBER(10,2),

p_purchaseprice NUMBER(10,2),

p_category CHAR(10 BYTE),

p_categorydescription VARCHAR2(45 BYTE),

p_division VARCHAR2(10 BYTE),

p_divisiondescription VARCHAR2(45 BYTE),

primary key(product_id)

);

create table ach131.SALESORGANISATION(

customer_id NUMBER(*,0),

s_customerdescription VARCHAR2(255 BYTE),

s_city VARCHAR2(50 BYTE),

s_salesorganisation VARCHAR2(10 BYTE),

s_SOdescription VARCHAR2(45 BYTE),

s_country VARCHAR2(50 BYTE),

primary key(customer_id)

);

create table ach131.SALESDATA(

time_id NUMBER(*,0),

product_id CHAR(10 BYTE),

customer_id NUMBER(*,0),

revenue NUMBER(10,2),

salesquantity NUMBER(10,2),

costgoodssold NUMBER(10,2),

discount NUMBER(10,2),

netsales NUMBER(10,2),

foreign key(time_id) references TIME(time_id),

foreign key(product_id) references PRODUCT(product_id),

foreign key(customer_id) references SALESORGANISATION(customer_id)

);```

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值