ibatis插入數據返回ID的方法

<p>很基礎的知識了,貼過來備忘一下</p> <p>主要就是利用seelctkey來獲取這個ID值,可是oracle和mysql的區別仍是很大的</p> <p>oracle的用法</p> <p><code>1</code> <br /><code>&lt;</code><code>insert</code> <code>id</code><code>=</code><code>&quot;insertOperation&quot;</code><code>&gt;</code></p> <p><code>2</code> <br /><code></code><code>&lt;</code><code>selectKey</code> <code>resultClass</code><code>=</code><code>&quot;long&quot;</code> <code>keyProperty</code><code>=</code><code>&quot;Id&quot;</code> <code>&gt;</code></p> <p><code>3</code> <br /><code></code><code>select operation_seq.nextval as id from desc</code></p> <p><code>4</code> <br /><code></code><code>&lt;/</code><code>selectKey</code><code>&gt;</code></p> <p><code>5</code> <br /><code></code><code>insert into test(id,name,desc) values (#id#,#name#,#desc#)</code></p> <p><code>6</code> <br /><code>&lt;/</code><code>insert</code><code>&gt;</code></p> <p>oracle主要經過序列來返回insert的ID號,因此selectkey主要作的操做是從序列中拿到下一個值</p> <p>mysql的用法</p> <p><code>1</code> <br /><code>&lt;</code><code>insert</code> <code>id</code><code>=</code><code>&quot;insertTopic&quot;</code> <code>parameterClass</code><code>=</code><code>&quot;topic&quot;</code><code>&gt;</code></p> <p><code>2</code> <br /><code>insert into test(ID, NAME, DESC) values (#ID#, #NAME#, #DES#)</code></p> <p><code>3</code> <br /><code></code><code>&lt;</code><code>selectKey</code> <code>resultClass</code><code>=</code><code>&quot;string&quot;</code> <code>keyProperty</code><code>=</code><code>&quot;id&quot;</code><code>&gt;</code></p> <p><code>4</code> <br /><code></code><code>select last_insert_id() as ID from test limit 1</code></p> <p><code>5</code> <br /><code></code><code>&lt;/</code><code>selectKey</code><code>&gt;</code></p> <p><code>6</code> <br /><code>&lt;/</code><code>insert</code><code>&gt;</code></p> <p>msyql主要利用了last_insert_id這個函數來獲取最大的id值</p> <p>/**</p> <p>* 2012.09.29</p> <p>*/</p> <p>今天在作selectkey時各類報錯,這裏列幾個遇到的低級錯誤,分先一下</p> <p>ibatis報ora-01475,無效的主機,綁定的變量名:這個很低級,字段中間忘記寫逗號了。</p> <p>主機沒法啓動,沒有成功的生成bean,恐怕是ibatis的變量不是bean的字段</p> <p>ibatis報ora-000904,無效的標示符,覺得name是關鍵字,加上&quot;&quot;也不行,尼瑪最後發現生成表的時候name前面有個空格。。。</p> <p>ibatis報ora-00984,列在此處不容許,一看其中的字符串用的是雙引號,改爲單引號便可。</p> <p>啓動時候報NullPointerException,selectkey增長屬性type=&quot;pre&quot;(針對oracle)</p> <p>ibatis報無效的列索引,通常是查詢變量的名字寫錯,或者多寫少些了,個人問題是我用--註釋,結果不認識了。。。</p> <p>ibatis報無效的列類型,通常是插入了null而非空字符串。</p> <p>/**</p> <p>*2012.10.18</p> <h5></h5> <p>*/</p> <p>今天又遇到一種錯誤類型There is no READABLE property named</p> <p>我得解決方法是把報錯的那個字符在ibatis裏去掉了。</p> <p>解決方案在這裏 <a href="http://bakcom.iteye.com/blog/226036">http://bakcom.iteye.com/blog/226036</a></p> <p>補充一篇文章 <a href="http://hi.baidu.com/daniel_tu/item/6f5ce2da86de8452d73aae00">http://hi.baidu.com/daniel_tu/item/6f5ce2da86de8452d73aae00</a></p> <p>/**</p> <p>* 2012.11.6</p> <p>*/</p> <p><font color="#ff0000">今天遇到了一個執行sql時候ORA-00911: 無效字符的錯誤</font></p> <p><font color="#ff0000">解決方案很簡單。sql的最後有個分號,去掉分號就行了</font></p> <p>總結一下,以前沒用到ibatis的時候,對於mysql還得寫一個事務來封裝,先插入,而後select max()下,太麻煩了。仍是ibiats強大。</p>mysql

相關文章
相關標籤/搜索