oracle&mysql对比

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。


自增主键问题

oracle没有自增主键的设置,如果需要设置自增主键,需要自己来通过自加序列和触发器来配合设置自增主键。(http://blog.csdn.net/chaishen10000/article/details/12219103

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 id="searchUserBySearchName" parameterType="java.lang.String"      resultType="com.urm.entity.User">  
  select * from t_user where user_name like CONCAT('%',#{search_name},'%')  
</select>  

<select id="searchUserBySearchName" parameterType="java.lang.String" resultType="com.urm.entity.User">  
  select * from t_user where user_name like '%'||#{search_name}||'%'   
</select>  

mysql:
<select id="searchUserBySearchName" parameterType="java.lang.String" resultType="com.urm.entity.User">  
  select * from t_user where user_name like CONCAT('%',#{search_name},'%')  
</select>  
2. 批量更新
oracle:
<updateidupdateid="batchUpdate" parameterType="java.util.List">  

     <foreach collection="list" item="item" index="index" open="begin" close="end;" separator=";">  
              updatetest  
              <set>  
                test=${item.test}+1  
              </set>  
              whereid = ${item.id}  
     </foreach>  
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • 一. Java基础部分.................................................
    wy_sure阅读 3,785评论 0 11
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,567评论 18 399
  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 4,028评论 0 19
  • 以前的看电影,据分析还是小青年挤眉弄眼,谈情说爱,暧昧表白的时候,那时候,大城市及港台文化冲击也不小,也教坏了一批...
    瑀轩阅读 319评论 0 0
  • 我有一杯水足以慰风尘。 曾、放在心尖尖上的那人如今在身侧么? 若、回头重走当时路会做出哪样的选择? 我曾渴望永恒、...
    三水目阅读 187评论 0 0