ORACLE數據庫轉MySQL數據庫遇到的坑 總結

最近在做Oracle轉mysql的工程,遇到的坑是真的多,尤其是存儲過程,以前都沒接觸過類似的知識,最近也差不多轉完了就總結一下。希望能幫到一些人(包括以後的自己)~

1> 基本語法

  變量聲明:

    oracle:   v_cnt varchar2(100) := ' ' ;

    mysql:   DECLARE v_cnt VARCHAR(100) DEFAULT  ' ';

  存儲過程聲明:

    oracle:  procedure regNewRecord(i_custno in varchar2(100))

    msyql: create procedure regNewRecord(IN i_custno VARCAHR(100))

  賦值:

    oracle:  v_cnt  = 'test';

    mysql:  set  v_cnt = 'test';

  函數:

    oracle:  nvl

    msyql: ifnull

  字符串的拼接:

    oracle:  str1 || str2

    mysql: concat(stra,str2)

  

  數據類型的轉換:

    oracle:  varchar2  -->  msyql:  varchar

 

2> 分頁

  oracle中使用rownum: 需要注意的是oracle的下標從1開始,mysql的下標從0開始

  select t.* from (SELECT rownum rn , a.seqid  from test a order by a.seqid ) t

  where rn >= 5 and rn <= 10   #表示取結果集中的第5到第10條記錄

  mysql中使用limit關鍵字

  select  seqid from test limit 4,6;   #表示從下標4開始,查詢后6條記錄

3> %rowtype    %rowtype是oracle中獨有的關鍵字

  oracle:     v_test test@%rowtype; 

       v_test.name = 'zhangsan';

   解析:test為一張已存在的表的表名,表示聲明一個包含test表中所有字段的變量,並且這個變量的類型會自動和表數據類型保持一致。後期使用的時候只需要 用 v_test.字段名就可以了。 假如test表中有name字段,那麼可以使用 v_test.name 去使用。

  msyql :  在mysql中實現%rowtype的辦法是根據當前表創建一張臨時表,並且定義臨時表中需要使用到的字段對應的變量。

  DECLARE t_name varchar(100);  -- 定義臨時表中的臨時變量

  drop table if exists test_temp;

  CREATE TEMPORARY TABLE IF NOT EXISTS test_temp (
    SELECT t.*  FROM test limit 1
  );  

  -- 這裡創建表之後會自動將一條數據存儲新的臨時表中。

  select name into t_name from test_temp;  -- 將臨時表中的數據放入臨時變量中,有多個的時候使用逗號分開, 例如: select name, seqid into t_name,t_seqid from test_temp;

  之後就可以直接使用 t_name 變量去代替 v_test.name了。

  如果後期還有別的存儲過程需要用到臨時表,則需要將變量數據重新update到臨時表中。

  eg:  update test_temp set name= t_name;

  

   如果oracle在存儲過程里調用的存儲過程的入參中使用 了 tablename%rowtype, msyql對應的解決辦法可以只講對應的表的臨時表的主鍵作為入參傳入,然後同樣定義臨時表中的變量去接收臨時表中的值。

   oracle:   procedure autoFillSysCol(v_test in test%rowtype)

   msyql實現示範:  (假定seqid是test 表中的唯一標識)

            procedure autoFillSysCol(in v_seqid varchar(100)) 

      DECLARE t_name varchar(100);

      DECLARE t_seqid varchar(100);

      select seqid,name into t_seqid,t_name from test_temp where seqid= v_seqid; #注意,這裡是承接上面的例子,test_temp臨時表已經創建后被調用的。

  到這裡就可以直接使用t_seqid,t_name變量了。。。 如果有更改t_seqid、t_name的操作,需要update test_temp表中的數據

4> return關鍵字

  oracle:結束存儲過程可以直接使用return關鍵字

  mysql: 需要先定義一個標籤,然後使用LEAVE關鍵字

  使用示範:      

    oracle:

    begin
      if t_name is null then
      return;
      end if;
      -- 其他操作
    end

    msyql:

endproc_tag:
begin
if t_name is null then
LEAVE endproc_tag;
end if;
end

  

      

5> 時間類型的轉換

  oracle: to_char(sysdate,'yyyyMMddHH24mmss')

  msyql: date_format(now(),'%Y%m%d%H%i%s')

6> 日期的計算

  ORACLE日期相加或者相減: getdate('2018-08-08')+365)  getdate('2018-08-08')-365) 

  msyql日期相加或者相減:adddate('2018-08-08',365)    adddate('2018-08-08',-365)  #後面的值為正數的時候表示相加,為負數的時候表示相減

7> 垮庫使用表:在當前存儲過程中使用到其他數據庫中的表

  oracle: 可以直接使用 表名@數據庫名  ,不需要做什麼配置,直接 dblink就可以了

  mysql: 需要修改配置文件,更改數據庫引擎: InnoDB --> federated ,然後建立需要引用表的對應臨時表 再去使用

  

8> 存儲過程中調用存儲過程

  oracle:  直接在存儲過程中寫存儲過程名,例如:  newRegCust()

  msyql: 需要添加個call關鍵字,例如: call newRegCust()

9> number(p,s)

  oracle: 表示最多可以有p位數,小數位占s為,整數位為 p-s. 例如: number(20,6) ,表示最多有20位,小數位為4位,整數位為16位。

  msyql:numeric(p,s) 和oracle同理

10> 入參和出參的定義

  oracle:需要定義入參和出參 ,格式: ( i_opt in varchar2,o_status out varchar2)

  mysql: 出參可以不用定義,也會有結果集返回。 格式: (in i_opt varchar(255))   #這裡要注意,要指定varchar的長度,不然會出錯~

  

數據庫ORACLE轉MYSQL存儲過程遇到的坑~(總結)的更多相关文章

  1. Csharp:操作存儲過程輸出參數,和返回值

    /// <summary> ///塗聚文 存儲過程輸出參數,和返回值 /// 20131030 /// Geovin Du /// </summary> /// <par ...

  2. SQL存儲過程的調試方法

    1.在vs2010调试存储过程步骤如下:(要點:連接登陸賬號的權限必須是管理員,才能單步調試,否則只能直接執行存儲過程:[因此,此方式適合數據庫和vs裝在同一台電腦上]) 1.1首先,打开vs,点击 ...

  3. 簡單SQL存儲過程實例

    簡單SQL存儲過程實例 摘自:http://blog.csdn.net/libra6956/article/details/5589173 实例1:只返回单一记录集的存储过程. 银行存款表(bankM ...

  4. sql server存儲過程語法

    -- 变量的声明,sql里面声明变量时必须在变量前加@符号    DECLARE @I INT -- 变量的赋值,变量赋值时变量前必须加set    SET @I = 30 -- 声明多个变量    ...

  5. MS SQLSERVER 存儲過程與緩存

    提升SQL Server最具性能的一个方面就是存储过程,SQL Server具备执行计划的缓存功能,以便计划重用.SQL Server2000增强了ad-hoc执行计划的缓存功能,就处理存储过程上性能 ...

  6. SQL使用存儲過程訪問不同服務器

    用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB', 'sql服 ...

  7. Nhibernate/Hibernate 使用多参数存儲過程 出現could not execute query,Could not locate named parameter等錯誤解決

    <?xml version="1.0" encoding="utf-8" ?> <hibernate-mapping xmlns=" ...

  8. 在Android中afinal框架下實現sqlite數據庫版本升級的辦法

    public abstract void onUpgrade(SQLiteDatabase db,int oldVersion,int new Version) 這個方法在實現時需要重寫.   pub ...

  9. Scrapy——將數據保存到MySQL數據庫

    Scrapy--將數據保存到MySQL數據庫 1. 在MySQL中創建數據庫表job_inf: 1 Create table job_inf( 2 id int(11) not null auto_i ...

随机推荐

  1. git分支错误提交导致代码丢失--窗口提示HEAD detached错误

    今天开发时git 检出分支到本地时操作错误,导致在一个临时分支上开发,且把代码提交了,结果代码未提交到任何分支,提交时还报了个错: HEAD detached at 4d927fa4 后来把代码重新检 ...

  2. 第 3 章 镜像 - 015 - 调试 Dockerfile

    如何 debug Dockerfile 通过 Dockerfile 构建镜像的过程 从 base 镜像运行一个容器 执行命令对容器做修改 执行类似 docker commit 的操作,生成一个新的镜像 ...

  3. thinkphp中出现unserialize(): Error at offset 533 of 1857 bytes如何解决

    thinkphp中出现unserialize(): Error at offset 533 of 1857 bytes如何解决 一.总结 一句话总结:清缓存就好了,所以框架有问题可以考虑清缓存 清缓存 ...

  4. layui 日期插件onchange事件失效的方法

    laydate.render({ elem:'#text1',//制定元素 type:'date', //range:true,//开启左右面板 min:'2017-09-1',// max:'201 ...

  5. tomcat ----> 启动,关闭和配置等等

    1.启动 在tomcat安装目录的bin文件中双击startup.bat. 2.关闭 在tomcat安装目录的bin文件中双击shutdown.bat. 3.配置tomcat-user.xml文件 ( ...

  6. python paramiko自动登录网络设备抓取配置信息

    ssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())ssh.connect(hostn ...

  7. canvas学习之树叶动画

    项目地址:http://pan.baidu.com/s/1geJgqen 今天用canvas做了一个树叶发芽到凋落的动画,当然还有很多不完善的地方,不过也让我体会到了,做动画技术占2分,算法占8分.这 ...

  8. Okhttp 插入缓存拦截器 解析

    我们在做网络请求的时候,如果网络请求过于频繁而且请求的数据变动不大,或者基本没有变动,这个时候如果没有缓存功能,我们想一下 会浪费掉多少资源,一次请求刷新一次,去请求一次,不但会消耗用户的流量,而且还 ...

  9. VS Code行内样式提示插件

    打开vscode,在软件界面左下角找到“齿轮”标志并点击,在弹出的菜单中选择“设置”,把下面的代码添加到设置里. { "workbench.colorTheme": "C ...

  10. CF903G Yet Another Maxflow Problem

    考虑最大流=最小割 不妨把a到a的边称为a类边,b到b的称为b类边,a到b的称为c类边. 显然,答案一定是由最多1条a和最多一条b以及一些c组成的. 只有a是会变的,也就是说每个a对应了唯一的最优的b ...