首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORA-00933更新前查询

ORA-00933更新前查询
EN

Stack Overflow用户
提问于 2013-06-19 16:08:04
回答 2查看 170关注 0票数 1

日安。我为对象创建了一些存储库,并尝试更新相同的对象。我使用了'ExecuteStoreCommand‘和next方法

代码语言:javascript
复制
public void UpdatePatienAccount(long modelId, long patientId, long accountId)
{
//ExecuteStoreCommand(@"UPDATE PATIENT_ACCOUNT SET PATIENT_ID = :1 AND ACCOUNT_ID = :2 WHERE ID == :3", patientId, accountId, modelId);
ExecuteStoreCommand(String.Format("UPDATE PATIENT_ACCOUNT SET PATIENT_ID = {0} AND ACCOUNT_ID = {1} WHERE ID = {2};", patientId, accountId, modelId));            
}

并且会产生下一个异常:

代码语言:javascript
复制
"ORA-00933: SQL command not properly ended"

P.S.被调用方法的参数不为零( not null和not object in not empty)。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-19 16:13:12

代码语言:javascript
复制
CREATE TABLE PATIENT_ACCOUNT
(
    ID         NUMBER
,   PATIENT_ID NUMBER
,   ACCOUNT_ID NUMBER
);

INSERT INTO PATIENT_ACCOUNT VALUES(1, 11, 22);

UPDATE  PATIENT_ACCOUNT
SET     PATIENT_ID = 1
AND     ACCOUNT_ID = 2
WHERE   ID = 3;
-- ORA-00933: SQL command not properly ended

UPDATE  PATIENT_ACCOUNT
SET     PATIENT_ID = 33
,       ACCOUNT_ID = 44
WHERE   ID = 1;
-- 1 rows updated.
票数 1
EN

Stack Overflow用户

发布于 2013-06-19 16:36:08

另外,语句末尾的分号(;)不正确。即使在"execute immediate“命令中,也不必使用分号。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17186025

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档