我有一个使用CREATE和INSERT INTO语句填充的数据库。我现在正在尝试编写一个CASE状态网,它将显示support_due_date已经过今天的“客户”。以下是以下代码
创建声明'Ord'(订单)
CREATE TABLE Ord(OrderID varchar2(9) PRIMARY KEY,
CustomerID varchar(9) REFERENCES Customer(CustomerID),
Expected_Delivery_Date date DEFAULT sysdate NOT NULL,
Actual_Delivery_Date date DEFAULT sysdate NOT NULL,
Payment_Due_Date date DEFAULT sysdate NOT NULL,
Order_Date date DEFAULT sysdate NOT NULL, Price Varchar(10),
Order_Placed varchar2(1) CONSTRAINT OrderPlaced
CHECK(Order_Placed IN('Y','N')) NOT NULL, Order_Confirmed varchar2(1)
CONSTRAINT Order_Confirmed CHECK(Order_Confirmed IN('Y','N'))
NOT NULL, Order_Completed varchar2(1) CONSTRAINT Order_Completed
CHECK(Order_Completed IN('Y','N')) NOT NULL)
插入声明
INSERT INTO Ord VALUES(401565981, 501623129,
'10-Dec-10', '11-Dec-10', '07-Dec-10', '03-Dec-10','£14.99', 'Y', 'Y', 'Y')
案例陈述
SELECT OrderID, CustomerID, Payment_Due_Date CASE WHEN
Payment_Due_Date = '08-Dec-10' THEN 'Send Final Demand Letter'
ELSE 'Do not send letter'
END FROM Ord;
当我尝试运行上述case语句时,我收到以下错误
ORA-00923:找不到FROM关键字 预期的地方 00923. 00000 - “未找到FROM关键字” *原因:
*动作:行错误:26列:50
有什么方法可以解决这个问题吗?
答案 0 :(得分:4)
我认为您需要在Payment_Due_Date和CASE之间使用逗号。