Oracle報錯系列---ORA-00911: invalid character


今天下午,項目測試,發現點擊保存的時候,總是報錯ORA-00911: invalid character。

后來在www.jwss.com上查了一下,發現有人也遇到我的錯誤,http://blog.csdn.net/bruesz/article/details/2310671.

其實是我們在寫sql語句的時候,習慣於在語句的末尾添加一個分號“;”。如

insert into  QMSUP_PURCHASE_INTNT qp(qp.id,qp.purMobile,qp.purQQ,qp.purMail,qp.purLinkman,qp.message) values (SEQ_COMMON.nextVal,#{purMobile},#{purQQ},#{purMail},#{purLinkman},#{message});

但是Oracle執行的時候回報錯。所以將分號刪除以后就可以了。

 

有的時候寫插入語句,報錯:無效的列類型,原因是,插入語句應該寫的更加的規范一些,例如在上面的這個插入語句,在表中,某些字段為varchar2()類型,那么在寫插入語句的時候,應該寫成這樣:

insert into QMSUP_PURCHASE_INTNT qp
(qp.id,
qp.purMobile,
qp.purQQ,
qp.purMail,
qp.purLinkman,
qp.message,
qp.supplierId,
qp.state,
qp.goodsId,
qp.goodsName,
qp.goodsPrice,
qp.createTime,
qp.updateTime,
qp.supShopName,
qp.goodsNum
)
values
(SEQ_COMMON.nextVal,
#{purMobile,jdbcType=VARCHAR},
#{purQQ,jdbcType=VARCHAR},
#{purMail,jdbcType=VARCHAR},
#{purLinkman,jdbcType=VARCHAR},
#{message,jdbcType=VARCHAR},
#{supplierId,jdbcType=VARCHAR},
0,
#{goodsId},
#{goodsName,jdbcType=VARCHAR},
#{goodsPrice,jdbcType=VARCHAR},
sysdate,
sysdate,
#{supShopName,jdbcType=VARCHAR},
#{goodsNum,jdbcType=VARCHAR})

在相應的字段后加上jdbcType=varchar,這樣不會報錯,無效的列類型。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM