oracle入门01

    技术2022-05-20  33

    1、  安装成功后进入DOS界面操作

    在进行以下操作时,需启动oracle服务。

    A、进入sql界面:开始--运行--cmd:输入sqlplus 回车

    提示输入正确的用户名和密码

    B、开始—>所有程序-àoracle-à运行sql命令—>直接采用conn 用户名/密码 进入

     

    用户名 默认的是 sys,system.

    密码是你安装的密码

    输入正确的用户名及密码即可进入界面。

     

    2、密码修改

    当忘记密码时,可以采用

    sqlplus sys/aaa as sysdba;--以数据库管理员的身份登录. 如果在本机登录

    密码可以随意输入。

     

    修改密码:

    //修改system用户的密码是system

    alter user system identified by system;

    alter user identified by 都是关键字。

     

     

    3、切换用户操作

      A、先退出 再登陆

        exit;退出。

      1、登录命令 sqlplus system/system 直接登录

      2sqlplus

         --提示输入用户名

         --提示输入密码

     B、也可以不退出直接在sql>操作中采用 conn scott/tiger  conn/用户名/密码切换用户

    注意:登录的时候没有分号结束。

     

     

     

    4oracle 中的表是按照用户进行分类的。

       sys 超级用户(权限最高)

       system 数据库管理员(执行大部分管理操作)

      

       自定用户 测试用户

    5、简单入门命令

    select * from tabs;---查询当前用户下有哪些表(多查询出系统表)

    select table_name from user_tables; ---查询当前用户下的所有表的名称。

     

    desc 表名  ---查看表有哪些列(表的结构)

     

     

    客户端工具安装;

     

     

    -6、远程数据库的连接

        --前提:1、在客户端程序必须安装oracle客户端程序

                2、服务器端的防火墙必须关闭 因为oracle采用的是TCP/IP协议的。

                3、需要添加全局配置,修改配置文件

    C:/oraclexe/app/oracle/product/10.2.0/server/NETWORK/ADMIN/tnsnames.ora

    network/admin/找到tnsnames.ora配置文件内容如下:

    XE =

      (DESCRIPTION =

        (ADDRESS = (PROTOCOL = TCP)(HOST = PC-201009100931)(PORT = 1521))

        (CONNECT_DATA =

          (SERVER = DEDICATED)

          (SERVICE_NAME = XE)

        )

      )

    EXTPROC_CONNECTION_DATA =

      (DESCRIPTION =

        (ADDRESS_LIST =

          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC_FOR_XE))

        )

        (CONNECT_DATA =

          (SID = PLSExtProc)

          (PRESENTATION = RO)

        )

      )

     

    ORACLR_CONNECTION_DATA =

      (DESCRIPTION =

        (ADDRESS_LIST =

          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC_FOR_XE))

        )

        (CONNECT_DATA =

          (SID = CLRExtProc)

          (PRESENTATION = RO)

        )

      )

    XE是默认的全局名称PROTOCOL = TCP 协议

    HOST = PC-201009100931 本机的名称

    PORT = 1521 oralce的端口号

    如果需要采用远程连接需要配置一个全局的连接属性

    teacher =

      (DESCRIPTION =

        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))

        (CONNECT_DATA =

          (SERVER = DEDICATED)

          (SERVICE_NAME = csdn.cn)

        )

      )

    teacher是随意起的全局名称 注意:名称不能重复

    HOST = 192.168.1.100 是远程局连接的IP地址

    PORT = 1521是远程连接的端口号.必须一致。

    SERVICE_NAME = csdn.cn 是远程连接服务的名称.必须一致。

    备注:可以到服务端的tnsnames.ora文件中查找PORTSERVICE_NAME

    注意:以上配置teacher之前不能有空格否则会有异常信息。

     

        4、当远程客户连接服务器时,服务器端的OracleXETNSListener的监听必须启动

           打开方式---管理工具--服务中---查找OracleXETNSListener并启动程序。

     

      

    --sqlplus远程连接命令

         sqlplus 服务器端的用户名/密码@全局数据库名称

         sqlplus 服务器端的用户名/密码@teacher;即可。

     

    7、创建用户命令

     A、连接到用户SQL> conn system/root

    B、创建用户: SQL> create user scott identified by tiger;

    C、切换用户:SQL> conn scott/tiger    //用户切换失败

    Not logged on

      备注:出现用户没有session权限的提示.

    所以应当分配session权限

    8、分配权限

    grant 权限名 to 用户名;

    SQL> conn system/root;//第一步切换到管理员

    SQL> grant create session to scott; //为用户受权

    Grant succeeded//受权成功

    备注当受权成功后,scott就可以登录,但是登录后,当用户创建表时,也会出现权限不足.然在oracle中是通过用户的角色来给用户分配权限的.详细参考9角色

     

    9、角色(一个角色包含多个权限)

    connect

       create session

       create table

       ……

     resource

        对表空间使用权限

        ……

       grant connect,resource to scott;

    注意:对用用户的创建,权限的分配,只有管理员才能够操作,普通用户不能实现.

     

     

    登录简单总结

    l       SQL Plus 登录的几种不同方式

    •         sqlplus 根据提示输入用户名、密码

    •         sqlplus 用户名/密码            (本机登录)

    •         sqlplus 用户名/密码@网络服务名   (远程登录)

    •         sqlplus / as sysdba                 (sysdba身份登录,用户实际为sys)

     

     

    总结:

    创建用户

        切换到system管理员中 以system管理员进行登录

       

        1Create user 用户名 identified by 密码;(不能是全数字)

        2grant create session,create table,resource to 用户名;//给用户分配权限

        3start  目录(D:/emp.sql);//注意该文件不能放在桌面 为什么呢(目录中不能包含空格否则会出现如下错误:

    SQL> start C:/a a a/emp.sql;

    Error reading file

    )

    完成操作案例:

     SQL> conn system/red; //切换到system用户

    Connected to Oracle Database 10g Express Edition Release 10.2.0.1.0

    Connected as system

     

    SQL> create user sunlijuan identified by sunlijuan; //创建用户并为用户设置密码为sunlijuan

     

    User created

     

    SQL>  grant connect,resource to sunlijuan; //给用户授权 connect,resource

     

    Grant succeeded

     

    SQL> conn sunlijuan/sunlijuan; //切换到新创建的用户中来

    Connected to Oracle Database 10g Express Edition Release 10.2.0.1.0

    Connected as sunlijuan

     

    SQL> start c:/emp.sql;  //导入外部sql文件的方式

     

    SQL> select * from tabs; //查询该用户下面的所有表

    SQL> select table_name from user_tables; //查询该用户下的所有的表的名称

     

    TABLE_NAME

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

    PRODUCT

    ORDERS

    ORDERITEM

    TMP

    PAGES

    STUDENT

    COURSE

    SC

    TEST

    DEPT

    EMP

    SALGRADE

    USERS

     

    13 rows selected

     

    SQL> desc product //查看商品表的结构

    Name    Type       Nullable Default Comments

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

    PRODUCTID NUMBER(6)                          

    PRODUCTNAME VARCHAR2(30)                          

    PRICE     NUMBER(10,2)                          

     

     

     

    SQL Plus常见的命令

    l       conn            切换连接用户

    l       desc             显示表结构

    l       host             执行操作系统命令

    l       start            执行文件系统SQL语句

    l       exit                        退出

    l       col                         格式化输出

    l       /                    执行最近一条SQL或新定义过程

    l       startup                 启动数据库实例 (DBA)

    l       shutdown            关闭数据库实例 (DBA)

    对于conn,desc,host,exit已经结束

     

    首先创建scott用户

    为用户分配角色

     

    采用start命令 导入并执行数据库库脚本文件

    SQL> start c:/emp.sql

     

    / :执行最近一条SQL 例如:

    SQL> select * from dual;

    DUMMY

    -----

    X

    SQL> /  当使用/会执行上面一条语句相同的命令操作

    DUMMY

    -----

    X

     

    SQL>

    startup shutdown必须是sys system用户才能够执行

    其它用户不能使用.并且此命令只能在sqlplus中执行.不能在客户端工具中使用。

     

    //SQL命令

      Dual系统表介绍

     

    数据类型:

       数据是信息数字表现形式,信息的加工处理是以大量的结构化数据为载体进行的,数据库管理系统的核心是数据库,数据库的主要对象是表,表是结构化数据存储的地方.

       Oracle系统也提供了大量的数据类型主要包括两大类:

    1、  用户自定义的数据类型

    2、  内置的数据类型

    A、字符型

    字符数据类型可以用于声明包含了多个字母数字数据的字段。

    1、  固定长度的字符类型

     char:用于存储固定长度的字符,一旦声明长度固定(不论你存储的实际大小,但是大小绝对不能大于声明的长度)长度不足时,采用空格补充。1B的默认大小,最大尺寸为2000B

     

    Ncharchar的解析是一样的不过,ncarh存储的是Unicode字符数据。

     

    2、  可变长度的字符类型

    varcharchar类似,但是它是用于存储可变的字符串,char用于存储固定的字符串。

    Nvarcharvarchar解析是一样的,不过nvarchar用于存储的数据位双字节的数据。

    日期型

      date 短日期格式(1990-10-10)

      Timestamp长日期格式(1990-10-10 10:10:10)

    数字型

    Number(2),代表:声明一个2位数字的整数。

    Number(3,2)代表:声明为3数字位,并且小数后有2位。

     

    文本型-àlob数据类型

    Blob:可以存储图像,音频文件及视频等文件。

    Clob:字符格式的大型对象,oracle数据àunicode格式的编码

    Bfile:用于存储二进制格式的文件。

    --------------------------------------------------------------------------------------------------------------rowid 伪劣类型:用于在oracle内部保存表中的每条记录的物理地址。

     

     

    创建表

     

    插入语句:

    1、  向表中插入一条新的(全字段)记录

    SQL> insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(1111,'test','test','7369',to_date('1992-12-12','yyyy-mm-dd'),100,100,20);

    1 row inserted

    或者写成

    SQL> insert into emp values(2222,'test','test','7369',to_date('1992-12-12','yyyy-mm-dd'),100,100,20);

    1 row inserted

    都过查询即可看到结果

    SQL> select * from emp;

     

    EMPNO ENAME  JOB        MGR HIREDATE       SAL      COMM DEPTNO

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

     7369 SMITH   CLERK   7902 1980-12-17    800.00               20

     ……….//省略部分

    1111 test      test      7369 1992-12-12    100.00    100.00     20

     2222 test      test      7369 1992-12-12    100.00    100.00     20

    2、  向表中插入一条新的(部分字段)记录

    SQL>  insert into emp(empno,ename,hiredate,deptno) values(3333,'test',to_date('1992-12-12','yyyy-mm-dd'),30);

    1 row inserted

    注意:在插入操作的时候如果有关联,一定要插入相应关联的字段的值.

     

    备注:插入之后都需要手动的提交 commit;

    SQL> commit;

    Commit complete

     

     

     

     

     

     

             SQLstructured Query Language(结构化查询语言)的缩写。可以使用sql语句建立或删除数据库的对象,插入,修改和更新数据库中的数据,并且可以对数据库执行各种日常管理的操作。它是所有关系数据库管理系统的标准语言.换句话说使用sql可以对所有的关系数据库进行操作。

       SQL按照功能分类:

    1、  数据库定义语句

    DDLData Definition Language:用于创建、修改、删除数据库对象。

    2、  数据库操作语句

    DMLData Manipulation Language)用于:查询,添加修改或删除存在数据库对象中的数据。

    3、  数据库控制语句DCL

    DCL(Data Control Language)用于控制访问数据库中特定对象的用户、grant revoke

    Oracle系统中经过对Sql语言扩展被称为PL/SQL语言。

     

    基本的sql语句

    SELECT         *|{[DISTINCT] column|expression [alias],...}

    FROM table;

     

    SQL> select * from emp;//查询所有的字段信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp;//查询所有

    SQL> select empno from emp;//查询部分字段

    SQL> select empno "员工编号" from emp;//采用别名查询

    SQL> select empno as "员工编号" from emp;//采用别名查询 等效于上面的效果

    SQL> select distinct(hiredate) from emp;//查询所有员工的入职日期并且去掉重复的日期

    SQL> select sal+comm from emp;//注意:包含空值的数学表达式求出的结果为空值

    SQL> select empno||ename from emp;//||连接符 把empnoename作为一个字段显示

    SQL> select empno||ename  as "员工编号和员工姓名" from emp;//效果同上

    SQL> select '员工的编号是'||empno from emp;//字符的链接

    SQL> select '姓名为'||ename||'员工,所在的部门是:'||deptno as "新列" from emp;//字段的链接包号字符连接

    SQL> select distinct(deptno) from emp;//查询去掉重复行的员工部门编号

     

    条件查询

    SELECT     *|{[DISTINCT] column|expression [alias],...}

    FROM       table

    [WHERE  condition(s)];

    Condition(s)要使用到比较运算符常用的比较运算符如下:

    操作符

    含义

    =

    等于

    大于

    >=

    大于等于

    小于

    <=

    小于等于

    <> 

    不等于 等效于!=

    其它操作

    And 逻辑运算  逻辑与

    Or  逻辑运算  逻辑或

    Not 逻辑运算  逻辑否

    Between 起始值 and 结束值:使用 BETWEEN 运算来显示在一个区间内的值 包含(起始结束值)

    In: 使用 IN运算显示列表中的值。 In(,,,)相当于一个集合,只要出现集合中匹配的就显示

    Like

    l       使用 LIKE 运算选择类似的值

    l       选择条件可以包含字符或数字:

    •         % 代表零个或多个字符(任意个字符)

    •         _ 代表一个字符。

     

    Escape

       回避特殊符号的:使用转义符。例如:将[%]转为[/%][_]转为[/_],然后再加上[ESCAPE ‘/’] 即可

    Null:

    使用 IS (NOT) NULL 判断空值。

     

    //查询部门号为10的员工信息  部门为整数类型

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=10;

    //查询职位号为MANAGER的员工信息  岗位的类型为字符类型

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER';

    //查询部门号为10并且员工的职位为MANAGER的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER' and deptno=10;

    注意:

    l        字符和日期要包含在单引号中。

    l        字符大小写敏感,日期格式敏感。

    l        默认的日期格式是 DD-MON-RR

     

    //查询部门号大于10的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno>10;

    //查询薪水大于等于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=3000;

    //查询薪水不等于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal<>3000;

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal !=3000;

    //查询薪水大于2000并且小于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>2000 and sal<3000;

    //查询薪水大于等于2000并且小于等于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal between 1600 and 3000;

    //等效于

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=1600 and sal<=3000;

    //查询部门号位1020的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno in(10,20);

    //注意:相当于如下操作:

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno =10 or deptno=20;

    //查询员工名称以S开头的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like 'S%';

    //查询员工名称以S结尾的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%S';

    //查询员工名称第三个字符为N的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '__N%';

    //查询员工名称中含有N的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%N%';

    //查询员工名称中倒数第二个字符为%的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%_'escape'/';

    //查询员工名称总含有%的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%%'escape'/';

    //查询奖金为null的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is null;

    //查询奖金非null的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is not null;

    优先级表格:

    优先级

     

    1

    算术运算

    2

    连接符

    3

    比较符

    4

    Is not null like not in

    5

    Not between

    6

    not

    7

    and

    8

    Or

    备注:可以采用括号改变优先级

     

     

       关系数据库-à层次关系---》网状的关系-à关系数据库-à对象关系。

     

     Order by 子句:

    l                                         使用 ORDER BY 子句排序

    •                                                                  ASCascend: 升序

    •                                                                  DESCdescend: 降序

    l                                         ORDER BY 子句在SELECT语句的结尾。

    //查询员工信息按照部门的编号进行升序排列   默认的是 asc

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno;

    //查询员工信息按照部门的编号进行降序排列   使用desc

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno desc;

    //查询部门为20的员工信息并按照员工的编号进行升序排列

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp  where deptno=20 order by empno asc;

    备注:可以与条件语句结合使用但order by子句放在最后

    //查询员工信息并按照员工的部门编号升序并且编号进行降序排列

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp  order by deptno asc,empno desc;

    备注:理解思路:首先查询员工信息按照部门的编号进行升序,然后每个部门中的员工按照员工的编号进行降序排列

     

    总结:

    整体语法如下:

    SELECT     *|{[DISTINCT] column|expression [alias],...}

    FROM       table

    [WHERE     condition(s)]

    [ORDER BY  {column, expr, alias} [ASC|DESC]];

    通过学习可以完成 使用where子句、betweenlikeinnullnot orand等来过滤数据,也可以使用order by子句进行对查询结果排序数据。

     

     

     

    Sql--plus函数:

    字符串函数是oracle使用最广泛的一种函数.

    LOWER:小写

    UPPER:大写

    INITCAP:首字母大写

    CONCAT:连接

    SUBSTR:截取  (参数,开始,数目)

    LENGTH:返回字符串的长度

    INSTR:(参数,字母) 返回字母出现的位置

    LPAD:(参数,长度,在前补齐参数字母)

    | RPAD:(参数,长度,在后补齐参数字母)

    TRIM

    REPLACE:(参数,参数[,参数]:第一个参数操作数,第二是要查找的字符,第三个是替换的字符,如果没有第三个就删除查找的字符。

    //查询名称为scott的员工信息 (不区分大小写)

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp  where lower(ename)='scott';

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp  where upper(ename)='SCOTT';

    //查询员工信息 把员工名称与工作连接在一起

    SQL> select empno,concat(ename,job),mgr,hiredate,sal,comm,deptno from emp;

    //查询员工信息 把员工名称与工作连接在一起

       SQL> select empno,concat(ename||'is work:',job),mgr,hiredate,sal,comm,deptno from emp;

    //查询员工名称中含有O字符的位置

    SQL> select empno,instr(ename,'O'),job,mgr,hiredate,sal,comm,deptno from emp;

    //查询员工名称中含有O字符的位置并且求出了员工名称字符长度

    SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp;

    //在查询上面结果中过滤出员工工作从第三字母开始为ERK员工信息

    SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp where substr(job,3)='ERK';

    备注:当含有两个参数的时候,从开始位置直接到参数结束的结束为止

    //在效果同上的同时指明了截取个数为3

     SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp where substr(job,3,3)='ERK';

    //查询员工信息  薪资是10位位数不够在左部分补*填充

    SQL> select empno,ename,job,mgr,hiredate,LPAD(sal,10,'*'),comm,deptno from emp;

    //查询员工信息  薪资是10位位数不够在右部分补*填充

    SQL> select empno,ename,job,mgr,hiredate,RPAD(sal,10,'*'),comm,deptno from emp;

    //查询员工信息  把员工名称中含有S字符去除掉

    SQL> select empno,TRIM('S' from ename),job,mgr,hiredate,10,comm,deptno from emp;

    等效于:

    SQL> select empno,TRIM( both 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;

    //查询员工信息  把员工名称中前面有S字符去除掉

    SQL> select empno,TRIM( Leading 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;

    //等效于

    SQL> select empno,LTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp;

    //查询员工信息  把员工名称中后面有S字符去除掉

    SQL> select empno,TRIM( trailing 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;

    等效于:

    SQL> select empno,RTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp;

     

     

    数字函数:

    ROUND: 四舍五入

                ROUND(45.926, 2)          45.93

    TRUNC:   截断

                TRUNC(45.926, 2)          45.92

    MOD: 求余

                MOD(1600, 300)            100

    ABS:绝对值

    CEIL:返回大于或等于value的最小整数

    FLOOR:返回小于或等于value的最大整数

    SQRT :返回value的平方根 负数无意义。

    //四舍五入 结果为46

    SQL> select round(45.56) from dual;

    //绝对值 结果为45.56

    SQL> select abs(-45.56) from dual;

    //大于等于最小整数 结果为-45

    SQL> select ceil(-45.56) from dual;

    //小于等于最大整数 结果为-46

    SQL> select floor(-45.56) from dual;

    //求余数 结果为300

    SQL> select mod(1800,500) from dual

    //截取的数的操作数是正数的情况下:只操作小数位  结果为1800.11

    SQL> select trunc(1800.11111,2) from dual;

    //截取的数的操作数是负数的情况下:操作的是小数点之前的位,把操作位小数点之前的位数全部改写成0. 结果就是1000

    SQL> select trunc(1899.11111,-3) from dual;

     

     

     

     

    日期时间函数

    Oracle 中的日期型数据实际含有两个值: 日期和时间。默认的日期格式是 DD-MON-RR.日期时间函数用来返回当前系统的日期和时间、以及对日期和时间类型的数据进行处理运算。

     

    add_months(date,count);在指定的日期上增加count个月

    last_day(date);返回日期date所在月的最后一天

    months_between(date1,dates);返回date1date2之间间隔多少个月

    new_time(date,this,other);将时间datethis时区转换成other时区

    next_day(day,day);返回指定日期或最后一的第一个星期几的日期,这里day为星期几

    sysdate();获取系统的当前日期

    current_timestamp();获取当前的时间和日期值

    round:日期的四舍五入

    trunc 日期的截取

     

    日期的数学运算:

    l        在日期上加上或减去一个数字结果仍为日期。

    l        两个日期相减返回日期之间相差的天数。

    l        可以用数字除24来向日期中加上或减去小时。

     

    //获取系统的当前时间 显示的格式采用默认格式 显示结果:07-4 -11 11.15.38.390000 上午 +08:00

    SQL> select current_timestamp from dual;

    //获取系统的当前日期值  显示结果:2011-4-7 11

    SQL> select sysdate from dual;

    //为当前日期加上3个月 显示的结果:2011-7-7 11:18:36

    select add_months(sysdate,3) from dual;

    //返回当前月的最后一天 显示的结果:2011-4-30 11:19:4

    select last_day(sysdate) from dual;

    //返回两个日期之间的间隔月是几: 结果为:4

    SQL> select months_between(add_months(sysdate,4),sysdate) from dual;

    //GMT时区转换成AST时区的日期结果

     SQL> select new_time(sysdate,'GMT','AST') from dual;

    //返回下一个星期一的日期值   必须写成星期

     SQL> select next_day(sysdate,'星期一') from dual;

     

     

     

     

    转换函数:

      隐式转换:在运算过程中由系统自动完成的

      显式转换:在运算过程中需要调用相应的转换函数实现。

    隐式转换

    显式转换

    to_char(date,format):按照指定的格式format把数字或日期类型的数据转换成字符串

     

    格式:

             必须包含在单引号中而且大小写敏感。

              可以包含任意的有效的日期格式。

             日期之间用逗号隔开。

       日期格式如下:

    //把当前日期转换成YYYY/MM/DD的格式

    SQL> select to_char(current_timestamp,'YYYY/MM/DD') from dual;

    //把当前日期转换成YYYY/MM/DD HH24/MI/SS AM的格式

    SQL> select to_char(current_timestamp,'YYYY/MM/DD HH24/MI/SS AM') from dual;

    //DD of MONTH

    SQL> select to_char(current_timestamp,'YYYY DD "of" MONTH  HH/MI/SS AM') from dual;

    to_number(char);把包含了数字格式的字符串转换成数字数据

    to_date(string,format);按照指定格式的format把字符串转换成日期数据,如果省略了foramt格式,那么就采用默认的日期格式(DD-MON-YY);

     

    chartorowid(char);把字符串转换成rowid类型

    rowidtocharx;rowid类型转换成字符类型数据


    最新回复(0)