Oracle学习笔记4--单行函数

Jun 07, 2016 pm 02:54 PM
oracle 関数 勉強 ノート

使用函数可以完成一系列的操作。数据库之间的不同,在于对函数的支持上是不一样。 本次笔记学习函数。函数分为单行函数和多行函数,此处重点学习单行函数。 单行函数分类: 字符函数 数值函数 日期函数 转换函数 通用函数 字符函数:又分为大小写控制函数

  使用函数可以完成一系列的操作。数据库之间的不同,在于对函数的支持上是不一样。

  本次笔记学习函数。函数分为单行函数和多行函数,此处重点学习单行函数。

  单行函数分类:

  字符函数

  数值函数

  日期函数

  转换函数

  通用函数

  字符函数:又分为大小写控制函数和字符控制函数

  1)大小写空值函数:

  LOWER()

  UPPER()

  INITCAP()

?

1

2

3

4

5

SQL> select lower('SQL COURSE') , upper('sql course') , initcap('SQL course') from dual ;

  

LOWER('SQLCOURSE') UPPER('SQLCOURSE') INITCAP('SQLCOURSE')

------------------ ------------------ --------------------

sql course         SQL COURSE         Sql Course

  通过上面的查询结果,看出:

  Lower() 函数的作用是:将字符转换为小写。

  Upper()函数的作用是:将字符转换为大写。

  Initcap()函数的作用是:将字符的首字母转换为大写。

  例:查询名字是king的雇员信息 ,由于不确定数据库中名字的大小写形式,我们引入lower函数和 upper()函数,来保证查询的有效性。

?

1

2

3

4

5

6

7

8

9

10

11

SQL> select * from emp  where lower(ename) = 'king' ;

  

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

 7839 KING       PRESIDENT       1981/11/17    5000.00               10

 

SQL> select * from emp  where ename = upper('king' );

  

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

 7839 KING       PRESIDENT       1981/11/17    5000.00               10

  例:将查询结果字符的首字母转换为大写形式,使用initcap 函数。

?

1

SQL> select initcap(ename) from emp where ename = 'KING';

?

1

2

3

INITCAP(ENAME)

--------------

King

  字符控制函数:

  concat()

  substr()

  length()

  replace()

  例:字符串除了使用‘||’连接之外,还可以使用concat() 函数进行连接 。

?

1

2

3

4

5

6

7

8

9

10

11

SQL> select concat('Hello ' , 'world'  ) from  dual ;

  

CONCAT('HELLO','WORLD')

-----------------------

Hello world

 

SQL> select substr('hello' , 1 , 2) ,length('world') , replace('sql' , 'q' , 'X') from dual ;

  

SUBSTR('HELLO',1,2) LENGTH('WORLD') REPLACE('SQL','Q','X')

------------------- --------------- ----------------------

    he                   5      sXl

  上例中我们可以看到 substr()的作用是截取字符串,在字符串的后面跟两个参数,第一个参数表示的是要截取的

  起始位置,第二个参数表示的是截取的个数,length()函数返回的是字符串的长度。replace() 字符串后面跟两

  个参数,第一个参数表示要替换的字母,第二个参数表示将第一个字母换为第二个字母。

  另外Oracle还支持倒着截取字符串的方式:

?

1

2

3

4

5

6

7

SQL> select ename ,substr(ename ,-3 ) from emp  where deptno = 10 ;

  

ENAME      SUBSTR(ENAME,-3)

---------- ----------------

CLARK      ARK

KING       ING

MILLER     LER

  数值函数:

  round():四舍五入函数

  trunc():截断小数位函数

  mod() :取余函数

  例:

?

1

2

3

4

5

SQL> select round(234.12 , 2) , round(234.324) , round(234.25 , -2) from dual;

  

ROUND(234.12,2) ROUND(234.324) ROUND(234.25,-2)

--------------- -------------- ----------------

    234.12            234              200

  后面的参数 2 表示保留小数点后两位,如果不写,默认为零,-2 表示对小数点前面的数进行四舍五入ROUND(234.25,-2) , 4 舍去,3 舍去得到200。

  例:

?

1

2

3

4

5

SQL> select trunc(234.12 , 2) , trunc(234.324) , trunc(248.25 , -2) from dual;

  

TRUNC(234.12,2) TRUNC(234.324) TRUNC(248.25,-2)

--------------- -------------- ----------------

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Oracleで2つの日付の間の日数を計算する関数 Oracleで2つの日付の間の日数を計算する関数 May 08, 2024 pm 07:45 PM

Oracleで2つの日付の間の日数を計算する関数

Oracle データベースのログはどのくらいの期間保存されますか? Oracle データベースのログはどのくらいの期間保存されますか? May 10, 2024 am 03:27 AM

Oracle データベースのログはどのくらいの期間保存されますか?

Oracle データベースの起動手順の順序は次のとおりです。 Oracle データベースの起動手順の順序は次のとおりです。 May 10, 2024 am 01:48 AM

Oracle データベースの起動手順の順序は次のとおりです。

オラクルで間隔を使用する方法 オラクルで間隔を使用する方法 May 08, 2024 pm 07:54 PM

オラクルで間隔を使用する方法

Oracle にはどれくらいのメモリが必要ですか? Oracle にはどれくらいのメモリが必要ですか? May 10, 2024 am 04:12 AM

Oracle にはどれくらいのメモリが必要ですか?

Oracle で特定の文字の出現数を確認する方法 Oracle で特定の文字の出現数を確認する方法 May 09, 2024 pm 09:33 PM

Oracle で特定の文字の出現数を確認する方法

Oracle データベース サーバーのハードウェア構成要件 Oracle データベース サーバーのハードウェア構成要件 May 10, 2024 am 04:00 AM

Oracle データベース サーバーのハードウェア構成要件

Oracleで文字列を置換する方法 Oracleで文字列を置換する方法 May 08, 2024 pm 07:24 PM

Oracleで文字列を置換する方法

See all articles