成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解Oracle中三大類型與隱式數據類型轉換

數據庫 其他數據庫
在MySQL跟Oracle中,如果存在隱式的數據類型轉換,可能導致無法命中索引,從而進行全表掃描的危險。

在某些情況下,Oracle Server 會收到數據類型與預期的數據類型不同的數據。發生這種情況時,Oracle Server 可自動將該數據轉換為預期的數據類型。這種數據類型轉換可以由Oracle Server 隱式完成,也可以由用戶顯式完成。

詳解oracle中三大類型與隱式數據類型轉換

在MySQL跟Oracle中,如果存在隱式的數據類型轉換,可能導致無法命中索引,從而進行全表掃描的危險。

一、類型轉換規則

MySQL類型轉換規則:

  • 兩個參數至少有一個是NULL時,比較的結果也是 NULL,例外是使用 <=> 對兩個NULL做比較時會返回1,這兩種情況都不需要做類型轉換
  • 兩個參數都是字符串,會按照字符串來比較,不做類型轉換
  • 兩個參數都是整數,按照整數來比較,不做類型轉換
  • 十六進制的值和非數字做比較時,會被當做二進制串
  • 有一個參數是TIMESTAMP或DATETIME,并且另外一個參數是常量,常量會被轉換為timestamp
  • 所有其他情況下,兩個參數都會被轉換為浮點數再進行比較

Oracle類型轉換規則:

  • 對于insert和update操作,oracle將值轉換為受影響的的列的類型。
  • 對于SELECT操作,oracle會將列的值的類型轉換為目標變量的類型。

二、Oracle中三大類型與隱式數據類型轉換

  • varchar2變長/char定長-->number,例如:'123'->123
  • varchar2/char-->date,例如:'25-4月-15'->'25-4月-15'
  • number---->varchar2/char,例如:123->'123'
  • date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'

三、Oracle/MySQL如何隱式轉換

  • =號二邊的類型是否相同
  • 如果=號二邊的類型不同,嘗試的去做轉換
  • 在轉換時,要確保合法合理,否則轉換會失敗,例如:12月不會有32天,一年中不會有13月

四、Oracle隱式轉換實例

(1) 查詢1980年12月17日入職的員工(方式一:日期隱示式轉換)

  1. select * from emp where hiredate = '17-12月-80'

(2) 使用to_char(日期,'格"常量"式')函數將日期轉成字符串)

  1. select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual; 

詳解oracle中三大類型與隱式數據類型轉換

(3) 使用to_char(日期,'格式')函數將日期轉成字符串)

  1. select to_char(sysdate,'yyyy-mm-dd"今天是"day hh24:mi:ss') from dual; 

  1. select to_char(sysdate,'yyyy-mm-dd"今天是"day HH12:MI:SS AM') from dual; 

詳解oracle中三大類型與隱式數據類型轉換

(4) 使用to_char(數值,'格式')函數將數值轉成字符串

  1. select to_char(1234,'$9,999') from dual;  
  2. select to_char(1234,'L9,999') from dual; 

詳解oracle中三大類型與隱式數據類型轉換

(5) 使用to_date('字符串','格式')函數,查詢1980年12月17日入職的員工(方式二:日期顯式轉換)

  1. select * from emp where hiredate = to_date('1980年12月17日','yyyy"年"mm"月"dd"日"'); 

  1. select * from emp where hiredate = to_date('1980#12#17','yyyy"#"mm"#"dd'); 

  1. select * from emp where hiredate = to_date('1980-12-17','yyyy-mm-dd'); 

(6) 使用to_number('字符串')函數將字符串‘123’轉成數字123

  1. select to_number('123') from dual; 

詳解oracle中三大類型與隱式數據類型轉換

注意:

  1. select '123' + 123 from dual;246 
  2. select '123' || 123 from dual;123123 

詳解oracle中三大類型與隱式數據類型轉換

 

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2017-12-20 14:14:16

數據庫MySQL數據類型

2010-04-13 12:56:16

Oracle字符集

2017-09-13 10:58:51

JavaScript轉換規則

2017-09-05 16:17:35

JavaScript運算轉換

2010-05-12 14:05:54

MySQL安裝

2010-03-30 16:33:55

Oracle數據類型

2019-11-29 07:37:44

Oracle數據庫索引

2010-04-21 15:10:14

Oracle數據類型

2025-02-27 09:13:03

2010-06-17 23:31:35

協議轉換器

2010-04-02 13:15:01

Oracle跟蹤

2023-08-14 08:35:36

2022-06-20 08:26:39

Spring容器類型轉換

2009-11-17 10:01:11

Oracle數據類型

2020-12-29 07:56:23

JavaScript數據類型 primitive

2010-01-05 14:04:53

.NET Framew

2024-03-14 11:54:37

C++數據類型

2023-04-06 07:49:23

Python數據類型

2011-04-13 09:16:55

泛型

2010-08-25 13:36:53

DB2Oracle
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产日韩精品在线 | 日本三级做a全过程在线观看 | 在线观看国产视频 | 亚洲巨乳自拍在线视频 | 成人精品一区二区 | 亚洲国产精品一区二区第一页 | 免费永久av | 成人精品视频免费 | 久久国产精品无码网站 | 中文字幕1区 | 五月激情综合 | 久久国产精品色av免费观看 | 国产黄色av网站 | 亚洲国产精品99久久久久久久久 | 国产视频二区 | 久久成人激情 | 免费一看一级毛片 | 久久久一二三 | 精品国产一区二区三区久久久蜜月 | 91精品久久久久久久久中文字幕 | 国产精品永久免费 | 精品亚洲一区二区三区 | 在线中文视频 | 国产黄色免费网站 | 国产一级淫片a直接免费看 免费a网站 | 老头搡老女人毛片视频在线看 | 国产在线一区二区三区 | 久草99| 精品精品视频 | 亚洲精品九九 | 一区二区不卡视频 | 日本不卡一区二区三区 | 午夜激情小视频 | 日韩精品激情 | 在线综合视频 | 日韩av网址在线观看 | 成人在线播放网址 | 亚洲成人中文字幕 | 人人干人人看 | 天天av天天好逼 | 日韩国产精品一区二区三区 |