<p>很基础的知识了,贴过来备忘一下</p> <p>主要就是利用seelctkey来获取这个ID值,可是oracle和mysql的区别仍是很大的</p> <p>oracle的用法</p> <p><code>1</code> <br /><code><</code><code>insert</code> <code>id</code><code>=</code><code>"insertOperation"</code><code>></code></p> <p><code>2</code> <br /><code></code><code><</code><code>selectKey</code> <code>resultClass</code><code>=</code><code>"long"</code> <code>keyProperty</code><code>=</code><code>"Id"</code> <code>></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></</code><code>selectKey</code><code>></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></</code><code>insert</code><code>></code></p> <p>oracle主要经过序列来返回insert的ID号,因此selectkey主要作的操做是从序列中拿到下一个值</p> <p>mysql的用法</p> <p><code>1</code> <br /><code><</code><code>insert</code> <code>id</code><code>=</code><code>"insertTopic"</code> <code>parameterClass</code><code>=</code><code>"topic"</code><code>></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><</code><code>selectKey</code> <code>resultClass</code><code>=</code><code>"string"</code> <code>keyProperty</code><code>=</code><code>"id"</code><code>></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></</code><code>selectKey</code><code>></code></p> <p><code>6</code> <br /><code></</code><code>insert</code><code>></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是关键字,加上""也不行,尼玛最后发现生成表的时候name前面有个空格。。。</p> <p>ibatis报ora-00984,列在此处不容许,一看其中的字符串用的是双引号,改为单引号便可。</p> <p>启动时候报NullPointerException,selectkey增长属性type="pre"(针对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