很基础的知识了,贴过来备忘一下
主要就是利用seelctkey来获取这个ID值,但是oracle和mysql的区别还是很大的
oracle的用法
1
<
insert
id
=
"insertOperation"
>
2
<
selectKey
resultClass
=
"long"
keyProperty
=
"Id"
>
3
select operation_seq.nextval as id from desc
4
</
selectKey
>
5
insert into test(id,name,desc) values (#id#,#name#,#desc#)
6
</
insert
>
oracle主要通过序列来返回insert的ID号,所以selectkey主要做的操作是从序列中拿到下一个值
mysql的用法
1
<
insert
id
=
"insertTopic"
parameterClass
=
"topic"
>
2
insert into test(ID, NAME, DESC) values (#ID#, #NAME#, #DES#)
3
<
selectKey
resultClass
=
"string"
keyProperty
=
"id"
>
4
select last_insert_id() as ID from test limit 1
5
</
selectKey
>
6
</
insert
>
msyql主要利用了last_insert_id这个函数来获取最大的id值
/**
* 2012.09.29
*/
今天在做selectkey时各种报错,这里列几个遇到的低级错误,分先一下
ibatis报ora-01475,无效的主机,绑定的变量名:这个很低级,字段中间忘记写逗号了。
主机无法启动,没有成功的生成bean,恐怕是ibatis的变量不是bean的字段
ibatis报ora-000904,无效的标示符,以为name是关键字,加上""也不行,尼玛最后发现生成表的时候name前面有个空格。。。
ibatis报ora-00984,列在此处不允许,一看其中的字符串用的是双引号,改成单引号即可。
启动时候报NullPointerException,selectkey增加属性type="pre"(针对oracle)
ibatis报无效的列索引,一般是查询变量的名字写错,或者多写少些了,我的问题是我用--注释,结果不认识了。。。
ibatis报无效的列类型,一般是插入了null而非空字符串。
/**
*2012.10.18
*/
今天又遇到一种错误类型There is no READABLE property named
我得解决方法是把报错的那个字符在ibatis里去掉了。
解决方案在这里 http://bakcom.iteye.com/blog/226036
补充一篇文章 http://hi.baidu.com/daniel_tu/item/6f5ce2da86de8452d73aae00
/**
* 2012.11.6
*/
今天遇到了一个执行sql时候ORA-00911: 无效字符的错误
解决方案很简单。sql的最后有个分号,去掉分号就好了
总结一下,之前没用到ibatis的时候,对于mysql还得写一个事务来封装,先插入,然后select max()下,太麻烦了。还是ibiats强大。