版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、第9章 常用函數(shù)Oracle數(shù)據(jù)庫提供了大量的系統(tǒng)函數(shù)。他們可以對(duì)數(shù)據(jù)庫的值、對(duì)象和設(shè)置進(jìn)展操作并前往相關(guān)信息。此外,Oracle數(shù)據(jù)庫還提供了一些處置列值的聚合函數(shù),對(duì)表中的數(shù)據(jù)進(jìn)展統(tǒng)計(jì)分析。經(jīng)過這些函數(shù),可以進(jìn)一步提供快速、簡單的方法以完成特定的任務(wù)。在本章中,我們將重點(diǎn)學(xué)習(xí)聚合函數(shù)、數(shù)學(xué)函數(shù)、字符串函數(shù)、數(shù)據(jù)類型轉(zhuǎn)換函數(shù)、日期函數(shù)等。.9.1 聚合函數(shù)在訪問數(shù)據(jù)庫時(shí),經(jīng)常需求對(duì)表中的某列數(shù)據(jù)進(jìn)展統(tǒng)計(jì)分析,如求最大值、最小值、平均值等。一切針對(duì)這些表中一列或者多列數(shù)據(jù)的分析就叫做聚合分析。Oracle提供了一些聚合函數(shù),如表所示。函數(shù)功能avg()求平均值,計(jì)算并返回表達(dá)式的平均值coun
2、t()統(tǒng)計(jì)數(shù)目,返回一個(gè)集合中的項(xiàng)數(shù)max()求最大值,返回表達(dá)式中的最大項(xiàng)min()求最小值,返回表達(dá)式中的最小項(xiàng)sum()求和,計(jì)算并返回表達(dá)式各項(xiàng)的和stddev()求標(biāo)準(zhǔn)偏差stddev_pop()求總體標(biāo)準(zhǔn)偏差.9.1 聚合函數(shù)在select語句中運(yùn)用聚合函數(shù)如下圖。.9.1.1 計(jì)數(shù)函數(shù)count()count()函數(shù)用來計(jì)算表中行的總數(shù),計(jì)算內(nèi)容由select語句執(zhí)行。運(yùn)用count()函數(shù)時(shí),必需指定一個(gè)列的稱號(hào)或者運(yùn)用星號(hào)?!纠?-1】運(yùn)用count()函數(shù)獲取customersnew數(shù)據(jù)表中記錄數(shù)和customersnew表中status列的記錄數(shù)?!纠?-2】運(yùn)用co
3、unt()函數(shù)獲取customersnew數(shù)據(jù)表中status列為gold的記錄數(shù)。.9.1.2 求和函數(shù)sum()sum()函數(shù)用于對(duì)數(shù)據(jù)求和,它分組計(jì)算指定列的和。假設(shè)不運(yùn)用分組,那么該函數(shù)默許把整個(gè)表作為一組。sum()只能作用于數(shù)值類型的數(shù)據(jù)。其語法構(gòu)造如以下圖所示?!纠?-3】查詢orders數(shù)據(jù)表中order_total總和。【例如9-4】orders數(shù)據(jù)表中,存儲(chǔ)的是顧客的訂單編號(hào),每個(gè)顧客存在多個(gè)訂單的情況。查詢orders數(shù)據(jù)表中各個(gè)顧客的order_total總和。.9.1.3 均值函數(shù)avg()avg()函數(shù)用于計(jì)算結(jié)果集中一切數(shù)據(jù)的算術(shù)平均值,也可以求某組數(shù)據(jù)的平均值
4、。該函數(shù)作用于數(shù)值類型數(shù)據(jù),前往數(shù)據(jù)類型值,其語法構(gòu)造如下圖。【例如9-5】查詢orders數(shù)據(jù)表中order_total字段的一切數(shù)據(jù)的算數(shù)平均值?!纠?-6】查詢orders數(shù)據(jù)表中order_total大于訂單平均值的一切訂單信息。.9.1.4 最大值max()和最小值min()利用max()函數(shù)和min()函數(shù),可以獲得結(jié)果集中記錄數(shù)據(jù)的最大值和最小值。與前面引見的不同,這里的數(shù)據(jù)可以是數(shù)值、字符串或日期數(shù)據(jù)類型。其中,字符串是根據(jù)ASCII碼的順序來獲取最大值和最小值的,根本的語法構(gòu)造如下圖。.9.1.4 最大值max()和最小值min()【例如9-7】假設(shè)想知道orders數(shù)據(jù)表
5、中最大order_total?!纠?-8】orders數(shù)據(jù)表中最小order_total。【例如9-9】假設(shè)想求得orders數(shù)據(jù)表中最大order_total,還可以換一種方式,經(jīng)過order by語句按照order_total進(jìn)展排序,然后運(yùn)用rownum關(guān)鍵字,只選取結(jié)果集中的第1條記錄。.9.2 數(shù)學(xué)函數(shù)數(shù)學(xué)函數(shù)操作數(shù)字?jǐn)?shù)值,執(zhí)行數(shù)學(xué)和算術(shù)運(yùn)算。本小節(jié)主要講解數(shù)值型的定義、數(shù)值型函數(shù)。.9.2.1 Oracle中的數(shù)值型Oracle中數(shù)值型是用來存放數(shù)的,包括整數(shù)和實(shí)數(shù)。在Oracle中一致運(yùn)用number表示數(shù)值型。number (p,s)是一種格式化的數(shù)字,其中p是精度,s是刻度
6、范圍。精度是數(shù)值中一切有效數(shù)字的個(gè)數(shù),而刻度范圍是小數(shù)點(diǎn)右邊數(shù)字位的個(gè)數(shù)。精度和刻度范圍都是可選的,但假設(shè)指定了刻度范圍,那么也必需指定精度。.9.2.1 Oracle中的數(shù)值型Oracle提供了豐富的內(nèi)置函數(shù)對(duì)數(shù)據(jù)進(jìn)展處置,一切函數(shù)都有數(shù)值型參數(shù)并前往數(shù)值型值。需求留意的是一切三角函數(shù)的操作數(shù)和值都是弧度而不是角度,如下表所示。.9.2.1 Oracle中的數(shù)值型函數(shù)名稱描述abs(n)用于返回n的絕對(duì)值acos(n)反余弦函數(shù),用于返回-11之間的數(shù),n表示弧度asin(n)反正弦函數(shù),用于返回-11之間的數(shù),n表示弧度atan(n )反正切函數(shù).用于返回n的反正切值,n表示弧度ceil(
7、n)用于返回大于或等于n的最小整數(shù)cos(n )用于返回n的余弦值,n為弧度cosh(n)用于返回n的雙曲余弦值,n為數(shù)字exp(n)用于返回e的n次冪,e=2.71828183floor(n )用于返回小于等于n的最大整數(shù)ln(n)用于返回n的自然對(duì)數(shù),n必須大于0log(n1,n2)用于返回以n1為底n2的對(duì)數(shù)mod(n1,n2)用于返回n1除以n2的余數(shù)power(n1,n2 )用于返回n1的n2次方round(n1,n2)用于返回舍入小數(shù)點(diǎn)右邊n2位的n1的值,n2的默認(rèn)值為0,這會(huì)返回小數(shù)點(diǎn)最接近的整數(shù),如果n2為負(fù)數(shù)就舍入到小數(shù)點(diǎn)左邊相應(yīng)的位上,n2必須是整數(shù)sign(n)若n為負(fù)
8、數(shù),則返回-1。若n為正數(shù),則返回1,若n=0,則返回0sin(n )用于返回n的正弦值,n為弧度sinh( n)用于返回n的雙曲正弦值,n為弧度sqrt(n )度于返回n的平方根tan(n )用于返回n的正切值,n為弧度tanh( n)用于返回n的雙曲正切值,n為弧度trunc(n1,n2)用于返回截尾到n2位小數(shù)的n1的值,n2默認(rèn)設(shè)置為0,當(dāng)n2為馱認(rèn)設(shè)置時(shí)會(huì)將n1截尾為整數(shù),如果n2為負(fù)值,就截尾在小數(shù)點(diǎn)左邊相應(yīng)的位上.9.2.2 絕對(duì)值、取余、判別數(shù)值正負(fù)本小節(jié)主要講解數(shù)值類型函數(shù)中的取絕對(duì)值函數(shù)、取余函數(shù)、判別正負(fù)函數(shù)。1.前往數(shù)字的絕對(duì)值abs()函數(shù)絕對(duì)值表示在數(shù)軸上,一個(gè)數(shù)的
9、點(diǎn)到原點(diǎn)的間隔。非負(fù)數(shù)的絕對(duì)值是它本身,非正數(shù)的絕對(duì)值是它的相反數(shù)。Oracle提供abs()函數(shù)來計(jì)算數(shù)字的絕對(duì)值。該函數(shù)包含一個(gè)參數(shù),通常參數(shù)類型為數(shù)字類型,或可以隱式轉(zhuǎn)換成數(shù)字類型。【例如9-10】利用abs()前往數(shù)值的絕對(duì)值,要求測試正數(shù)、負(fù)數(shù),以及自動(dòng)轉(zhuǎn)換成數(shù)字的字符串在絕對(duì)值函數(shù)中的運(yùn)用。.9.2.2 絕對(duì)值、取余、判別數(shù)值正負(fù)2.取余操作mod()函數(shù)取余函數(shù)也叫取模,該函數(shù)表示一個(gè)除數(shù)除一個(gè)值并給出余數(shù)。該函數(shù)要求兩個(gè)參數(shù)被除數(shù)和除數(shù),參數(shù)類型是數(shù)值型,或者可以隱式轉(zhuǎn)換為數(shù)值型的其他類型,其語法方式如下圖?!纠?-11】演示mod()函數(shù)的運(yùn)用方法。.9.2.2 絕對(duì)值、取
10、余、判別數(shù)值正負(fù)3.前往數(shù)字的正負(fù)性sign()函數(shù)sign()函數(shù)的功能是前往參數(shù)的符號(hào)正或負(fù)。當(dāng)參數(shù)大于0時(shí),sign()函數(shù)前往1;當(dāng)參數(shù)小于0時(shí),sign()函數(shù)前往-1;當(dāng)參數(shù)等于0時(shí),sign()函數(shù)將前往0?!纠?-12】演示sign()函數(shù)的運(yùn)用。.9.2.3 近似值函數(shù)、截取、取整函數(shù)在Oracle中,近似值函數(shù)運(yùn)用round(),ceil()函數(shù)、floor()函數(shù)用于取整。1.前往數(shù)字的“四舍五入值round()函數(shù)四舍五入表示在取小數(shù)近似數(shù)的時(shí)候,假設(shè)尾數(shù)的最高位數(shù)字是4或者比4小,就把尾數(shù)去掉。假設(shè)尾數(shù)的最高位數(shù)是5或者比5大,就把尾數(shù)舍去并且在它的前一位進(jìn)“1,該
11、函數(shù)的運(yùn)用語法如下圖?!纠?-13】當(dāng)小數(shù)位數(shù)為正數(shù)時(shí),表示準(zhǔn)確到小數(shù)點(diǎn)之后的位數(shù)。.9.2.3 近似值函數(shù)、截取、取整函數(shù)2.截取數(shù)字trunc(n1,n2)函數(shù)trunc(n1,n2)函數(shù)用于將數(shù)值n1根據(jù)n2進(jìn)展截取。其任務(wù)機(jī)制非常類似于round()函數(shù),但是trunc()函數(shù)并不進(jìn)展四舍五入操作,而是直接舍去。該函數(shù)的調(diào)用語法如下圖?!纠?-14】利用trunc()函數(shù)截取部分?jǐn)?shù)字。當(dāng)小數(shù)位數(shù)大于0時(shí),表示截取至原數(shù)值的小數(shù)點(diǎn)之后的位數(shù)。.9.2.3 近似值函數(shù)、截取、取整函數(shù)2.向上取整ceil()函數(shù)向上取整表示將前往大于等于數(shù)值型參數(shù)的最小整數(shù)。Oracle中ceil()是
12、向上取整函數(shù),該參數(shù)要求是數(shù)值類型或者可以隱式轉(zhuǎn)換為數(shù)值的類型,可以是非整數(shù)?!纠?-15】演示ceil()函數(shù)的運(yùn)用,將數(shù)據(jù)表orders中的order_total向上取整。.9.2.3 近似值函數(shù)、截取、取整函數(shù)3.向下取整floor()函數(shù)向下取整表示前往小于等于數(shù)值型參數(shù)的最大整數(shù)。與ceil()函數(shù)相反,floor()函數(shù)用于前往小于等于參數(shù)值的最大整數(shù)。【例如9-16】演示floor()函數(shù)的運(yùn)用。.9.2.4 平方根、乘方運(yùn)算函數(shù)在Oracle數(shù)據(jù)庫中,sqrt()函數(shù)用于前往數(shù)字的平方根;power()函數(shù)用于計(jì)算一個(gè)值與給定正指數(shù)的乘方。1.前往數(shù)字的平方根sqrt()函數(shù)
13、從平方根的意義我們知道,該函數(shù)的參數(shù)不能小于0?!纠?-17】利用sqrt()函數(shù)前往參數(shù)的平方根。.9.2.4 平方根、乘方運(yùn)算函數(shù)2.乘方運(yùn)算power()函數(shù)該函數(shù)有兩個(gè)參數(shù),第一個(gè)參數(shù)為乘方運(yùn)算的底數(shù),第二個(gè)參數(shù)為乘方運(yùn)算的指數(shù)?!纠?-18】利用power()函數(shù)進(jìn)展乘方運(yùn)算。.9.2.5 格式化數(shù)值to_char()函數(shù)to_char()函數(shù)是將數(shù)值型數(shù)據(jù)轉(zhuǎn)換為字符串。第一個(gè)參數(shù)是待格式化的值,第二個(gè)是一個(gè)定義輸出格式的模板。可以將數(shù)值進(jìn)展格式化,并前往格式化后的字符串。其調(diào)用格式如下圖。.9.2.5 格式化數(shù)值to_char()函數(shù)1. 格式字符“0“0代表一個(gè)數(shù)字位。當(dāng)原數(shù)
14、值沒有數(shù)字位與之匹配時(shí),強(qiáng)迫添加0?!纠?-19】Oracle中格式字符“0的運(yùn)用,將數(shù)據(jù)表order_items中unit_price用格式字符“0顯示。.9.2.5 格式化數(shù)值to_char()函數(shù)2.格式字符“99,代表一個(gè)數(shù)字位。當(dāng)原數(shù)值中的整數(shù)部分沒有數(shù)字位與之匹配時(shí),不填充任何字符?!纠?-20】Oracle中格式字符“9的運(yùn)用,將數(shù)據(jù)表order_items中unit_price用格式字符“9顯示。.9.2.5 格式化數(shù)值to_char()函數(shù)3.格式字符“,逗號(hào),,分組符號(hào)。常見的運(yùn)用為千位分隔符。【例如9-21】Oracle中格式字符“,的運(yùn)用,將數(shù)據(jù)表order_ite
15、ms中unit_price用格式字符“,顯示。.9.2.5 格式化數(shù)值to_char()函數(shù)4.格式字符“FMFormat Mask而對(duì)于格式字符“9來說,小數(shù)部分沒有對(duì)應(yīng)位時(shí),依然運(yùn)用“0進(jìn)展填充。這違背了運(yùn)用習(xí)慣。利用格式字符“FM可以處理這一問題?!纠?-22】Oracle中格式字符“FM的運(yùn)用,將數(shù)據(jù)表order_items中unit_price用格式字符“FM顯示。.9.2.5 格式化數(shù)值to_char()函數(shù)6. 格式字符“L美圓符號(hào)表示貨幣,但是貨幣標(biāo)識(shí)往往具有本地化的顏色。例如,在我國,通常運(yùn)用“¥而非“$來表示貨幣。在to_char()函數(shù)中,運(yùn)用“L來指定本地化的貨幣標(biāo)識(shí)
16、。【例如9-23】Oracle中格式字符“L的運(yùn)用,將數(shù)據(jù)表order_items中unit_price用格式字符“L顯示。.9.2.5 格式化數(shù)值to_char()函數(shù)7. 格式字符“C通常,貨幣標(biāo)識(shí)只能表示能否為貨幣,而貨幣種類無法進(jìn)展區(qū)分。在to_char()函數(shù)中,還提供了另外,一個(gè)格式字符“C。該字符將前往與數(shù)據(jù)庫系統(tǒng)環(huán)境相關(guān)的貨幣種類符號(hào)。【例如9-24】Oracle中格式字符“C的運(yùn)用,將數(shù)據(jù)表order_items中unit_price用格式字符“C顯示。.9.2.5 格式化數(shù)值to_char()函數(shù)9.字符串與數(shù)值的比較在字符串與數(shù)值的比較運(yùn)算中,字符型首先被轉(zhuǎn)換為數(shù)值型,然
17、后進(jìn)展比較?!纠?-25】給出字符串與數(shù)值的比較運(yùn)算。.9.3 字符串函數(shù)字符型是用來存放字符和字符串的。字符串函數(shù)對(duì)字符類型的數(shù)據(jù)進(jìn)展相關(guān)的處置,它們可以接納字符或字符串類型的參數(shù),前往字符串或數(shù)字類型的處置結(jié)果。用戶可以在select語句的select和where子句以及表達(dá)式中運(yùn)用字符串函數(shù)。本節(jié)詳細(xì)講解字符類型定義及字符串函數(shù)的運(yùn)用。.9.3.1 字符型簡介字符類型,即字母、數(shù)據(jù)、標(biāo)點(diǎn)符號(hào)、數(shù)字和空格的混合方式,在Oracle中的字符型有varchar2(n)、nvarchar2(n)、char(n)、nchar2(n)、long等類型。char(n),用于指定變量或列的數(shù)據(jù)類型為固
18、定長度的字符串。其中,n代表字符串的長度。varchar(n),用于存儲(chǔ)可變長度的字符串。varchar2(n),同樣是可變長度的字符串類型,普通在Oracle中,盡量運(yùn)用varchar2(n)Oracle中的字符類型函數(shù)可以去掉字符串空格,截取子串,搜索字符串,銜接字符串,下面將詳細(xì)講解。.9.3.2 刪除空格在很多時(shí)候?qū)QL語句進(jìn)展處置時(shí),需求將字符串中的空格去除。函數(shù)ltrim()去除字符串前面的一切空格;函數(shù)rtrim()去除一個(gè)字符串尾部的一切空格;函數(shù)trim()去除一個(gè)字符串兩側(cè)的一切空格。.9.3.2 刪除空格1.ltrim()函數(shù)ltrim ()函數(shù)把字符串頭部的空格去掉,
19、其語法如下圖?!纠?-26】運(yùn)用函數(shù)ltrim()去除customersnew表中cust_first_name字段前面的空格,詳細(xì)實(shí)現(xiàn)如下圖。.9.3.3 求字符串長度函數(shù)利用length()函數(shù)可以得到指定字符串的長度,前往數(shù)值型。假設(shè)字符串為null,那么將前往null值。【例如9-27】利用length()函數(shù)前往字符長度,查詢customersnew表中cust_first_name的長度,以及去掉兩側(cè)空格之后的長度。.9.3.4 字符轉(zhuǎn)換函數(shù)在Oracle中,提供了一系列函數(shù)以完成字符與ASCII碼轉(zhuǎn)換、字符與數(shù)值之間的轉(zhuǎn)換、大小寫字母轉(zhuǎn)換等轉(zhuǎn)換任務(wù)。1ASCII()函數(shù)ASCI
20、I()函數(shù)前往字符表達(dá)式最第一個(gè)字符的ASCII碼值,ASCII函數(shù)語法如下圖?!纠?-30】運(yùn)用ASCII()函數(shù)求customersnew表中cust_first_name字段的ASCII碼值。.9.3.4 字符轉(zhuǎn)換函數(shù)2chr(n)函數(shù)該函數(shù)是用于求n對(duì)應(yīng)的ASCII字符,其中n是一個(gè)數(shù)字?!纠?-31】chr(n)函數(shù)例如。.9.3.4 字符轉(zhuǎn)換函數(shù)3lower()函數(shù)lower()函數(shù)把字符串全部轉(zhuǎn)換為小寫,其語法如下圖。【例如9-32】運(yùn)用lower()函數(shù)將customersnew表中cust_first_name字段轉(zhuǎn)換為小寫。.9.3.4 字符轉(zhuǎn)換函數(shù)4upper()函數(shù)
21、upper()函數(shù)把字符串全部轉(zhuǎn)換為大寫,其語法如下圖?!纠?-33】運(yùn)用upper()函數(shù)將customersnew表中nls_language字段轉(zhuǎn)換為大寫。.9.3.4 字符轉(zhuǎn)換函數(shù)5單詞首字符大寫initcap()函數(shù)initcap()函數(shù)用于將字符串中的每個(gè)單詞首字符大寫、其它字符小寫的方式。單詞由空格、控制字符、標(biāo)點(diǎn)符號(hào)限制?!纠?-34】運(yùn)用initcap()函數(shù)將customersnew表中nls_language字段首字母大寫。.9.3.5 銜接字符串銜接字符串可以運(yùn)用concat()函數(shù),也可以運(yùn)用操作符“|。1.concat()函數(shù)concat()函數(shù)把提供的兩個(gè)參數(shù)
22、銜接起來,前往銜接后的字符串?!纠?-35】運(yùn)用concat()函數(shù)將customersnew表中顧客的姓名cust_first_name和姓cust_last_name銜接起來。.9.3.5 銜接字符串2.|運(yùn)算符【例如9-36】運(yùn)用|運(yùn)算符將customersnew表中顧客的姓名cust_first_name和姓cust_last_name銜接起來。.9.3.6 檢索字符串、取子串函數(shù)在很多實(shí)踐運(yùn)用中,我們需求獲得字符串的某一部分內(nèi)容來完成查詢。在SQL中,經(jīng)過取子串函數(shù)完成這一目的。1.獲得字符串出現(xiàn)的位置instr()函數(shù)該函數(shù)可以查看在指定字符串中能否存在另一個(gè)字符串,語法構(gòu)造如下
23、圖?!纠?-37】利用instr()函數(shù)獲得categories數(shù)據(jù)表的category_name字段中software出現(xiàn)的位置,如下圖。.9.3.5 銜接字符串2.截取字符串substr()函數(shù)運(yùn)用substr()函數(shù)可以對(duì)提供的參數(shù)進(jìn)展截取,前往截取后的字符串,語法構(gòu)造如下圖?!纠?-38】利用instr()函數(shù)截取categories數(shù)據(jù)表的category_name字段中前三位。.9.3.5 銜接字符串3.交換字符串replace()replace()函數(shù)可以用指定的字符串替代需求交換的字符串,語法構(gòu)造如下圖?!纠?-39】利用replace()函數(shù)截取categories數(shù)據(jù)
24、表的category_name字段中software交換為“軟件。.9.3.5 銜接字符串4.向左補(bǔ)全字符串lpad()函數(shù)lpad()函數(shù)和rpad()函數(shù)用于對(duì)字符串進(jìn)展填充,詳細(xì)可以在字符串的左邊或右邊銜接空格或其他字符。lpad()函數(shù)用于向左補(bǔ)全字符串,語法如下圖?!纠?-40】categories數(shù)據(jù)表中category_id原來是2位,如今希望被格式化為4位數(shù)字,缺乏部分運(yùn)用“0進(jìn)展填充。如category_id為11,應(yīng)被格式化為“0011,那么此時(shí)可以利用lpad()函數(shù)。.9.3.5 銜接字符串5.向右補(bǔ)全字符串rpad()函數(shù)該函數(shù)與lpad()函數(shù)的運(yùn)用方法類似。該函
25、數(shù)的功能是在字符串c1的右邊用字符串c2填充,直到整個(gè)字符串長度為n。【例如9-41】當(dāng)原始字符串長度大于預(yù)期長度時(shí),rplad()函數(shù)也是自左端截取字符串。.9.4 日期函數(shù)所謂日期處置函數(shù)就是用來操作與日期、時(shí)間相關(guān)的函數(shù)。利用日期函數(shù)可以得到當(dāng)前的系統(tǒng)時(shí)間,以及計(jì)算日期之間的秒、分鐘、小時(shí)、天、月、年等。.9.4.1 獲取日期和時(shí)間的函數(shù)Oracle中的日期類型用date表示,它可以用來放置日期和時(shí)間。date類型實(shí)踐包含了以下信息:Century:世紀(jì)信息;Year:年份信息;Month:月份信息;Day:天數(shù)信息;Hour:小時(shí)信息;Minute:分鐘信息;Second:秒數(shù)信息。O
26、racle中也存在timestamp數(shù)據(jù)類型,它包括了一切date數(shù)據(jù)類型的年月日時(shí)分秒的信息,而且包括了小數(shù)秒的信息。.9.4.1 獲取日期和時(shí)間的函數(shù)1 獲取系統(tǒng)日期函數(shù)sysdate該函數(shù)沒有參數(shù),前往當(dāng)前數(shù)據(jù)庫系統(tǒng)日期,是很常用的函數(shù)?!纠?-42】運(yùn)用sysdate函數(shù)前往當(dāng)前系統(tǒng)日期。.9.4.1 獲取日期和時(shí)間的函數(shù)2 獲取系統(tǒng)時(shí)間函數(shù)systimestampsystimestamp函數(shù)與sysdate函數(shù)類似,也沒有參數(shù)。該函數(shù)前往的是系統(tǒng)時(shí)間,時(shí)間準(zhǔn)確到微秒?!纠?-43】運(yùn)用systimestamp函數(shù)前往當(dāng)前系統(tǒng)時(shí)間。.9.4.1 獲取日期和時(shí)間的函數(shù)3 前往會(huì)話所在
27、時(shí)區(qū)當(dāng)前日期函數(shù)current_date()current_date()函數(shù)得到會(huì)話時(shí)區(qū)下的當(dāng)前日期?!纠?-44】結(jié)合當(dāng)前時(shí)區(qū)來查看current_date函數(shù)的運(yùn)用。.9.4.1 獲取日期和時(shí)間的函數(shù)4前往日期的某個(gè)域extract()函數(shù)該函數(shù)可以從指定的時(shí)間當(dāng)中提取到指定的日期部分,如日期中的年、月、日、時(shí)、分、秒等,其運(yùn)用語法如下圖?!纠?-45】結(jié)合數(shù)據(jù)表orders,從order_date中分解出月份?!纠?-46】結(jié)合數(shù)據(jù)表orders,從order_date中分解出小時(shí)信息。.9.4.1 獲取日期和時(shí)間的函數(shù)extact()函數(shù)的各種域的列表如表所示。域代碼說明year
28、獲得年份month獲得月份day獲得天數(shù)hour獲得小時(shí)數(shù)minute獲得分鐘數(shù)second獲得秒數(shù)timezone_hour獲得當(dāng)前時(shí)區(qū)的小時(shí)數(shù).9.4.1 獲取日期和時(shí)間的函數(shù)5截取日期trunc()函數(shù)trunc()函數(shù)可以截取日期,運(yùn)用方法與截取數(shù)字非常類似,其運(yùn)用語法如下圖?!纠?-47】結(jié)合數(shù)據(jù)表orders,將order_date分別截取到天和月。.9.4.1 獲取日期和時(shí)間的函數(shù)trunc()函數(shù)的作用為將日期截取到某一種格式,截取格式分類如表所示。分類可用格式代碼世紀(jì)CC、SSC年SYYY, YYYY, YEAR, SYEAR, YYY, YY, or YISO年(一年53
29、周,第54周的星期一為新年的開始)IYYY, IYY, IY, or I季度Q月份MONTH, MON, MM, or RM本周內(nèi)與當(dāng)年第一天具有相同周內(nèi)天數(shù)的日期WW本周內(nèi)與ISO年第一天具有相同周內(nèi)天數(shù)的日期IW本周內(nèi)與當(dāng)月第一天具有相同周內(nèi)天數(shù)的日期W天DDD, DD, or J本周內(nèi)的第一天DAY, DY, or D小時(shí)HH, HH12, HH24分鐘MI.9.4.2 日期和時(shí)間差的函數(shù)在實(shí)踐中,我們往往想知道在特定的兩個(gè)日期或者時(shí)間內(nèi)有多少天數(shù)、小時(shí)等,或者從某個(gè)時(shí)間開場,經(jīng)過某個(gè)時(shí)間段,系統(tǒng)需求對(duì)某個(gè)數(shù)據(jù)進(jìn)展操作。這時(shí)需求運(yùn)用一些日期和時(shí)間差的函數(shù)。.9.4.2 日期和時(shí)間差的函數(shù)
30、1.前往特定日期所在月的最后一天last_day()函數(shù)last_day()函數(shù)用于前往給定日期所在月份的最后一天,它有一個(gè)參數(shù)?!纠?-48】結(jié)合數(shù)據(jù)表orders,查詢order_date對(duì)應(yīng)的月份的最后一天。.9.4.2 日期和時(shí)間差的函數(shù)2.月份添加add_months()函數(shù)add_months()函數(shù)可以實(shí)現(xiàn)對(duì)日期和月份的計(jì)算,它可以在給定的日期上添加月份數(shù),然后重新計(jì)算日期。【例如9-49】將數(shù)據(jù)表orders中order_date日期推后一個(gè)月。.9.4.2 日期和時(shí)間差的函數(shù)3.兩個(gè)日期之間的月份months_between()函數(shù)months_between()函數(shù)有兩個(gè)參數(shù),可以獲取兩個(gè)參數(shù)之間的月份數(shù),其語法構(gòu)造如下圖?!纠?-50】獲取系統(tǒng)當(dāng)前日期與數(shù)據(jù)表orders中order_date日期的月份差。.9.4.2 日期和時(shí)間差的函數(shù)4. 特定日期之后的一周之內(nèi)的日期next_day()函數(shù)該函數(shù)前往指定日期
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- Fmoc-Phe-bis-Boc-4-guanidino-OH-生命科學(xué)試劑-MCE-3788
- Cannabidiphorol-CBDP-生命科學(xué)試劑-MCE-5981
- 2025年度區(qū)塊鏈技術(shù)股份投資協(xié)議
- 二零二五年度股權(quán)質(zhì)押合同樣本:適用于體育產(chǎn)業(yè)股權(quán)質(zhì)押
- 2025年度民宿窗簾墻布溫馨家居布置合同
- 二零二五年度股東致行動(dòng)協(xié)議書:文化產(chǎn)業(yè)股權(quán)合作與數(shù)字版權(quán)保護(hù)協(xié)議
- 二零二五年度建筑垃圾處理與簡易房屋拆除合同
- 二零二五年度產(chǎn)學(xué)研合作聘用及錄用合同
- 施工現(xiàn)場施工防化學(xué)毒品泄漏制度
- 施工日志填寫樣本建筑物屋面防水工程
- 2025年個(gè)人土地承包合同樣本(2篇)
- (完整版)高考英語詞匯3500詞(精校版)
- 2024年聯(lián)勤保障部隊(duì)第九四〇醫(yī)院社會(huì)招聘筆試真題
- 網(wǎng)絡(luò)貨運(yùn)行業(yè)研究報(bào)告
- 【人教版化學(xué)】選擇性必修1 知識(shí)點(diǎn)默寫小紙條(答案背誦版)
- 人教版七年級(jí)英語上冊(cè)單元重難點(diǎn)易錯(cuò)題Unit 2 單元話題完形填空練習(xí)(含答案)
- 00015-英語二自學(xué)教程-unit1
- 新版建設(shè)工程工程量清單計(jì)價(jià)標(biāo)準(zhǔn)解讀
- 2024-2025年突發(fā)緊急事故(急救護(hù)理學(xué))基礎(chǔ)知識(shí)考試題庫與答案
- 左心耳封堵術(shù)護(hù)理
- 2024年部編版八年級(jí)語文上冊(cè)電子課本(高清版)
評(píng)論
0/150
提交評(píng)論