Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
java.sql.SQLException:ORA-00933_Sql_Oracle_Groovy - Fatal编程技术网

java.sql.SQLException:ORA-00933

java.sql.SQLException:ORA-00933,sql,oracle,groovy,Sql,Oracle,Groovy,我有这个SQL代码。当我从SQL开发人员那里运行它时,它运行得很好。 我需要从groovy脚本执行 sql.executeInsert("INSERT INTO s_status (C_DATE, sl_id, st_id, PARENT_st_id, STATUS, DETAILS, ACTIVE_IND) SELECT cd.cc_date, sl_id, st_id+1 st_id, st_id parent_st_id, 'CONFIRMED' status, 'SQL' details

我有这个SQL代码。当我从SQL开发人员那里运行它时,它运行得很好。 我需要从groovy脚本执行

sql.executeInsert("INSERT INTO s_status (C_DATE, sl_id, st_id, PARENT_st_id, STATUS, DETAILS, ACTIVE_IND) SELECT cd.cc_date, sl_id, st_id+1 st_id, st_id parent_st_id, 'CONFIRMED' status, 'SQL' details, 'Y' active_ind FROM s_status ss JOIN v_c_dates cd ON 1=1 WHERE (sl_id, st_id) IN (SELECT sl.sl_id, MAX(st_id) st_id FROM s_status ss JOIN stats sl ON ss.sl_id = sl.sl_id JOIN site si ON si.site_id = sl.site_id JOIN orders d ON d.ord_id = si.ord_id GROUP BY sl.sl_id ) and ss.active_ind = 'N' and ss.status = 'SENT'")
当我从groovy运行这个程序时,我在groovy控制台中看到了这个错误。帮我找出错误

java.sql.SQLException: ORA-00933: SQL command not properly ended

select
语句中不需要别名。相应地修改了你的陈述。您还需要查看代码中需要使用表别名的注释。

我遇到过几个案例,其中ORA-00933是由区分大小写引起的。确保表和列名引用与架构匹配

INSERT INTO s_status (C_DATE, sl_id, st_id, PARENT_st_id, STATUS, DETAILS, ACTIVE_IND) 
SELECT cd.cc_date, sl_id, st_id+1, st_id, 'CONFIRMED', 
'SQL', 'Y'
FROM s_status ss JOIN v_c_dates cd ON 1=1 
WHERE (sl_id, st_id) IN 
(SELECT sl.sl_id, MAX(st_id) --use table alias before st_id
 FROM s_status ss JOIN stats sl ON ss.sl_id = sl.sl_id
 JOIN site si ON si.site_id = sl.site_id 
 JOIN orders d ON d.ord_id = si.ord_id 
 GROUP BY sl.sl_id) 
and ss.active_ind = 'N' and ss.status = 'SENT'