今天下午,項目測試,發現點擊保存的時候,總是報錯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,這樣不會報錯,無效的列類型。