sql - ORA-01843: 插入日期时月份无效
问题描述
我正在使用 Apex Oracle 运行将数据/表与现有架构合并的脚本文件。这是完整的脚本文件。每个插入命令都会产生错误,说明not a valid month
。在 Alter 命令说明时产生一个错误Column Type incompatible with referenced column type
脚本文件:
--A1_rr_upd.txt file
--dropping the table if already exists
DROP TABLE RRSTAFF;
--creating new table for RRSTAFF
CREATE TABLE RRSTAFF (
staff_num CHAR(4) PRIMARY KEY,
name VARCHAR(20),
gender CHAR(1),
date_join DATE,
date_resign DATE,
contact_num NUMBER(11),
address VARCHAR(255)
);
--Adding new hired staff
INSERT INTO RRSTAFF VALUES ('s001','Adrian','M','2021/07/02',null,'60122000000','6 Jalan BU6, Petaling Jaya,Selangor');
INSERT INTO RRSTAFF VALUES ('s002','Jewel','F','2021/07/12',null,'60123000000','2 Jalan PJS2, Sunway,Selangor');
INSERT INTO RRSTAFF VALUES ('s003','Sean','M','2021/07/12',null,'60166000000','100 Sunway South K,Selangor');
--Adding new customer details
INSERT INTO rrcustomer VALUES ('1011','Dr','Brendan');
INSERT INTO rrcustomer VALUES ('1012','Dr','Haya');
--Adding new records into models
INSERT INTO model VALUES ('LGC83','LG C1 83 in OLED 4K TV', '500');
INSERT INTO model VALUES ('LGG77','LG Gallery 77 in OLED 4K TV', '400');
INSERT INTO model VALUES ('SNY43','Sony 43 in X75 4K Ultra HD Android TV', '200');
INSERT INTO model VALUES ('SHA50','Sharp 50 in Full HD Basic TV ', '80');
--Adding new records into appliance
INSERT INTO appliance VALUES ('2010','LGC83','E',null);
INSERT INTO appliance VALUES ('2011','LGC83','E',null);
--Altering the HIRE table to link it with RRSTAFF using staff_id as Foriegn Key
ALTER TABLE
hire ADD(
staff_id VARCHAR(4),
FOREIGN KEY (staff_id) REFERENCES rrstaff(staff_num)
);
--Adding new hire records
INSERT INTO hire VALUES ('2010','2021/08/02','1011','2021/08/08','s001');
INSERT INTO hire VALUES ('2010','2021/08/22','1012','2021/08/28','s001');
INSERT INTO hire VALUES ('2011','2021/08/12','1013',null,'s001');
解决方案
在 Oracle 中,您使用ISO 标准 YYYY-MM-DD 格式date
的关键字和字符串来表示常量。date
例如:
INSERT INTO RRSTAFF
VALUES ('s001', 'Adrian', 'M', DATE '2021-07-02', null, '60122000000', '6 Jalan BU6, Petaling Jaya,Selangor');
这是一个 db<>fiddle。
推荐阅读
- angular - 使用持久数据的正确方法
- listview - 从 ListView 禁用开始和结束动画
- prestashop - Prestashop 1.6:创建重定向到支付网关的支付方式
- php - 无论如何搜索活动的 SQLite 数据库作为全文搜索
- python - 有没有办法“解决”装饰器的保留状态?
- jsp - 如何从 Servlet 页面重定向到不同的两个 Jsp 页面
- yocto - 为图像构建所有包
- sql - 从 SQL ORACLE 中删除日期的小时、分钟和秒
- azure - Logic App Execute Query 并基于 SP 结果集和分配
- java - 扫描目录以查找新文件并将文件复制到新位置并删除源文件