oracle&mysql对比
数据类型对比
1.字符型
mysql的字符型根据长度和是否定长分为了很多类型,常见的有char,varchar,以及各种不定长的text和blob(tiny,medium,long)。
oracle常用的字符型就是nvarchar2和varchar2,其实还有数据类型是varchar和nvarchar,但是实在旧版本的oracle里面使用,而且无法解析中文,因此我们常用的是nvarchar2和varchar,对于比较大的字符串,会在后面提到长字符串的处理。
2.数字型
mysql内根据根据整数和浮点数分为了int和double,根据数据范围类似字符型也分为了tiny,medium,long之类的。
oracle里主要使用number(p,s)和float(126位二进制)。
3.日期类型
mysql内的数据类型包括date,datetime,timestamp三种类型,且插入方式可以是字符串或者时间。
oracle内的时间类型分为date和timestamp,插入时必须把时间格式的字符串转换成时间类型文件。
同样的,从oracle里取出时间的时候,如果不进行处理,会根据不同的IDE将它解析成不同的格式,因此取出时间的时候需要将它转换成字符串(to_char函数)。
4.长字符串处理
长字符串常用的字段类型是clob和blob,区别在于clob直接存储文字,blob是按照二进制存储。
无论是clob还是blob的存储范围都是0-4G。
因此在存储的时候,纯文本信息(如文章或者较长的文字)直接使用clob存储。而音乐、图片、文件等信息先转换成二进制,再存储进blob。
自增主键问题
CREATE SEQUENCE emp_sequence INCREMENT BY 1 -- 每次加几个
START WITH 1 -- 从1开始计数
NOMAXVALUE -- 不设置最大值
NOCYCLE -- 一直累加,不循环
NOCACHE -- 不建缓冲区
以上代码完成了一个序列(sequence)的建立过程,名称为emp_sequence,范围是从1开始到无限大(无限大的程度是由你机器决定的),nocycle是决定不循环,如果你设置了最大值那么你可以用cycle,使seq到最大之后循环。
对于nocache,如果你给出了cache值那么系统将自动读取你的cache值大小个seq,这样在反复操作时会加快运行速度,但如果遭遇意外情况如当机了或oracle死了,则下次取出的seq值将和上次的不连贯(如果连不连贯无所谓建议用cache)。
其次建立触发器,在向表内部插入数据前触发。(以表'example'为例)
CREATE TRIGGER trigger_name
BEFORE
INSERT ON example FOR EACH ROW WHEN (new.id is null)
begin
select emp_sequence.nextval into :new.id from dual;
end;
也可以不通过触发器,直接在sql语句内部实现。(不建议)
INSERT INTO example(id,Name,phone,address)
Values(emp_sequence.nextval,'wxb','54483','wh');
分页问题
1.mysql中的分页
较为简单的做法(随着数据量的增大,效率会变低)
select * from tablename order by id desc
limit (page-1)*pageSize, pageSize;
较为高效的做法
select * from tablename
where id>=
(
select id from tablename order by id limit (page-1)*pageSize, 1
)
limit pageSize;
2.oracle中的分页
在oracle中分页处理比较麻烦
每个结果集只有一个ROWNUM字段标明它的位置, 并且只能用类似ROWNUM<100, 而不能用ROWNUM>80。
select * from
(
select t.*,rownum as rn from
(select * from tablename) as t where rownum<=page*pageSize
)
where rn>(page-1)*pageSize;
组函数用法规则
组函数(如count,max,min)之类的函数在mysql里面可以随意使用,但是如果在oracle里面使用,其他的字段必须处理过,或者经过group by子句经过分类。
例如:
select name,max(age) from user;
这行sql在mysql里面是可以正常执行的,但是在oracle里面不能执行。
select name,max(age) from user group by name;
而经过加入group by 将列name进行分组之后就可以正常执行了。
空字符的处理
mysql非空字段的内容可以有空的内容,而oracle里面非空字段不容许有空的内容,因此导入数据的时候需要对空字符判断。
Mybatis JdbcType与Oracle、MySql数据类型对应列表
Mybatis
JdbcType
Oracle
MySql
JdbcType
ARRAY
JdbcType
BIGINT
BIGINT
JdbcType
BINARY
JdbcType
BIT
BIT
JdbcType
BLOB
BLOB
BLOB
JdbcType
BOOLEAN
JdbcType
CHAR
CHAR
CHAR
JdbcType
CLOB
CLOB
CLOB
JdbcType
CURSOR
JdbcType
DATE
DATE
DATE
JdbcType
DECIMAL
DECIMAL
DECIMAL
JdbcType
DOUBLE
NUMBER
DOUBLE
JdbcType
FLOAT
FLOAT
FLOAT
JdbcType
INTEGER
INTEGER
INTEGER
JdbcType
LONGVARBINARY
JdbcType
LONGVARCHAR
LONG
VARCHAR
JdbcType
NCHAR
NCHAR
JdbcType
NCLOB
NCLOB
JdbcType
NULL
JdbcType
NUMERIC
NUMERIC/NUMBER
NUMERIC/
JdbcType
NVARCHAR
JdbcType
OTHER
JdbcType
REAL
REAL
REAL
JdbcType
SMALLINT
SMALLINT
SMALLINT
JdbcType
STRUCT
JdbcType
TIME
TIME
JdbcType
TIMESTAMP
TIMESTAMP
TIMESTAMP
JdbcType
TINYINT
TINYINT
JdbcType
UNDEFINED
JdbcType
VARBINARY
JdbcType
VARCHAR
VARCHAR
VARCHAR
mapper中的对比
1. 模糊查询
oracle:
select * from t_user where user_name like CONCAT('%',#{search_name},'%')
select * from t_user where user_name like '%'||#{search_name}||'%'
mysql:
select * from t_user where user_name like CONCAT('%',#{search_name},'%')
2. 批量更新
oracle:
updatetest
test=${item.test}+1
whereid = ${item.id}