更新:如何修复过程语句中的SQL错误:NEW ERROR

时间:2014-11-22 00:02:38

标签: oracle date plsql sqlplus auto-populate

我创建了sql数据库,我有许多不同的表连接不同的实体关系。

我目前正在使用程序处理1:N关系和im人口数据到表。

我取得了一些进展,但我仍然在微小的错误上磕磕绊绊,我修复它们时遇到了问题。

我刚进入一个我无法解决的问题。我现在一直看着感冒了一个小时,我猜它可能就在那里,但我无法看到它。

总之...

这是代码

表格

CREATE TABLE CENIK (
ID_CENIK INTEGER NOT NULL,
CENA NUMBER(10) NOT NULL,
DATUM_OD DATE NOT NULL,
DATUM_DO DATE NOT NULL,
TK_ID_ARTIKEL NUMBER(10) NOT NULL
);

ALTER TABLE CENIK
ADD (CONSTRAINT PK_CENIK PRIMARY KEY (ID_CENIK));

ALTER TABLE CENIK
ADD (CONSTRAINT TK_CENIK_ID_ARTIKEL FOREIGN KEY
(TK_ID_ARTIKEL) REFERENCES ARTIKEL(ID_ARTIKEL));

程序代码

--polnjenje tabele cenik
PROCEDURE polni_cenik(stevilo_cenikov NUMBER) IS
cena_artikla NUMBER(10);
datum_od DATE;
datum_do DATE;
c_tk_id_artikel NUMBER(10);
c_stevilo_artiklov int;
BEGIN
    SELECT MAX(ID_ARTIKEL) INTO c_stevilo_artiklov FROM ARTIKEL;
    FOR st14 IN 1..stevilo_cenikov LOOP
        cena_artikla := dbms_random.value(1,9999);
        datum_od := SYSDATE();
        datum_do := SYSDATE();
        datum_od := datum_od - dbms_random.value(0,1000);
        datum_do := datum_do + dbms_random.value(0,1000);
        c_tk_id_artikel := round(dbms_random.value(1,c_stevilo_artiklov));
        INSERT INTO CENIK(ID_CENIK, DATUM_OD, DATUM_DO, TK_ID_ARTIKEL)
        VALUES (st14, datum_od, datum_do, c_tk_id_artikel);
        dbms_output.put_line (st14);
    END LOOP;
COMMIT;
END;

这是错误

enter image description here

1 个答案:

答案 0 :(得分:2)

ime_kraja := ||' '|| TO_CHAR(st);应为ime_kraja := TO_CHAR(st);,否则您会在第一个||之前忘记一些内容。