oracle01

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 wangshuo identified by wangshuo; //创建用户并为用户设置密码为wangshuo

 

User created

 

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

 

Grant succeeded

 

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

Connected to Oracle Database 10g Express Edition Release 10.2.0.1.0

Connected as wangshuo

 

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;

//把当数字按照$99,999这种方式返回字符串  并且操作数的位数不能够大于5($后边的位数),否则话结果会是########

SQL> select to_char(11111,'$99,999') from dual;

 

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

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

 

//把当前字符串转换成日期

SQL> select to_date('2011-02-08','YYYY-MM-DD') from dual;

//求出两个日期之间相差的天数

SQL> select to_date('2011-07-15','YYYY-MM-DD')-to_date('2011-02-08','YYYY-MM-DD') from dual;

//求出两个日期之间相差的周次

SQL> select (to_date('2011-07-15','YYYY-MM-DD')-to_date('2011-02-08','YYYY-MM-DD'))/7 from dual;

//对周次进行向上取整

SQL> select ceil((to_date('2011-07-15','YYYY-MM-DD')-to_date('2011-02-08','YYYY-MM-DD'))/7) from dual;

 

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

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

 

 

通用函数

 这些函数适用于任何数据类型,同时也适用于空值

NVL (expr1, expr2)

NVL2 (expr1, expr2, expr3)

NULLIF (expr1, expr2)

COALESCE (expr1, expr2, ..., exprn)

 

nvl()

将空值转换成一个已知的值

l        可以使用的数据类型有日期、字符、数字。

l        函数的一般形式:

         NVL(commission_pct,0)

         NVL(hire_date,'01-JAN-97')

         NVL(job_id,'No Job Yet')

//commnull替换成0

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

//在上面的基础上将日期为空替换成给定的日期

SQL>select empno,ename,job,mgr,nvl(hiredate,to_date('2011-1-10','YYYY-MM-DD')),sal,nvl(comm,0),deptno from  emp;

//在上面的基础上将job为空替换成wangshuo

SQL> select empno,ename,nvl(job,'wangshuo'),mgr,nvl(hiredate,to_date('2011-1-10','YYYY-MM-DD')),sal,nvl(comm,0),deptno from  emp;

//计算出员工在该月的工资=(薪资+奖金)

SQL> select empno,ename,job,mgr,hiredate,(nvl(sal,0)+nvl(comm,0)) as "工资",deptno from  emp;

 

NVL2 (expr1, expr2, expr3) : expr1不为NULL,返回expr2;为NULL,返回expr3

   相当于:expr1!=null?exrp2:expr3;

//计算员工的工资

SQL> select empno,ename,job,mgr,hiredate,nvl2(comm,sal+comm,sal) as "工资",deptno from  emp;

 

NULLIF (expr1, expr2) :  相等返回NULL,不等返回expr1

//注意观察理解

SQL> select ename as "expr1",job as "expr2",nullif(length(ename),length(job)) from  emp;

 

l        COALESCE NVL 相比的优点在于 COALESCE 可以同时处理交替的多个值。

l        如果第一个表达式为空,则返回下一个表达式,对其他的参数进行COALESCE

SQL> select empno,ename,job,mgr,hiredate,coalesce(comm,sal,10000) as "salll", deptno from  emp;

 

l        重点理解:单行函数可以嵌套。嵌套函数的执行顺序是由内到外。

 

条件表达式 :IF-THEN-ELSE 逻辑

CASE expr WHEN comparison_expr1 THEN return_expr1

         [WHEN comparison_expr2 THEN return_expr2

          WHEN comparison_exprn THEN return_exprn

          ELSE else_expr]

END

 

 

DECODE(col|expression, search1, result1

                    [, search2, result2,...,]

                    [, default])

 

//为职位是Manager的员工 发放5000元的奖金

SQL> select ename,job,case job when 'MANAGER' then nvl(sal,0)+5000  end  as "工资" from emp;

 

//员工的工资

SQL> select ename ,job,

  2  case job when 'MANAGER' then nvl(sal,0)+5000+nvl(comm,0)

  3  else nvl(sal,0)+nvl(comm,0)

  4  end

  5  from emp;

//改写成 decode的写法

SQL> select ename,job

  2  ,decode(job,'MANAGER', nvl(sal,0)+5000+nvl(comm,0),

  3  'CLERK',nvl(sal,0)+nvl(comm,0)+200,

  4  nvl(sal,0)+nvl(comm,0)) as "工资"

  5  from emp;

 

作业: 当员工为Manger 5000  当员工为SALESMAN 1000 当员工为 clerk500

 

 

 

 

转换函数

 

 

 

 

 

 

 

 

 

 


 

 

//求余数 结果为300

//求余数 结果为300

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 文章:1oracle简化安装图解

       2oracledos操作方式

       3SQL查询介绍

        1SQl介绍

        2、基本查询

        3、条件查询

        4、排序查询

        5、分组查询

        6having子句

 

查询语句:

1表查询某个表中的所有数据.

SQL> select * from emp;

EMPNO ENAME  JOB        MGR HIREDATE       SAL      COMM DEPTNO

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

 7369 SMITH   CLERK   7902 1980-12-17    800.00               20

 7499 ALLEN   SALESMAN  7698 1981-2-20   1600.00    300.00     30

 7521 WARD   SALESMAN  7698 1981-2-22   1250.00    500.00     30

 7566 JONES   MANAGER  7839 1981-4-2   2975.00               20

2、   查询某个表中选择特殊的行

  

 

3、查询某个表中的特殊的列

SQL> select hiredate from emp;

HIREDATE

-----------

1980-12-17

1981-2-20

1981-2-22

1981-4-2

3、  采用别名查询

  SQL> select hiredate as 日期 from emp;

日期

-----------

1980-12-17

1981-2-20

1981-2-22

1981-4-2

备注 as也可以省略

SQL>  select e.hiredate from emp  e; //表的别名

 

HIREDATE

-----------

1980-12-17

1981-2-20

1981-2-22

1981-4-2

4、   

 

 

Oracle的常用函数

1、日期有关的函数

   to_char(转换的列名,格式);//把一个日期类型安照指定的格式转换成字符串.

SQL> select to_char(hiredate,'yyyy-mm-dd hh24-mi-ss') from emp;

TO_CHAR(HIREDATE,'YYYY-MM-DDHH

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

1980-12-17 00-00-00

1981-02-20 00-00-00

1981-02-22 00-00-00

1981-04-02  0-00-00

   to_data(转换的字符,转换的格式)//把一个字符串按照指定的格式转换成指定格式的日期类型。

2、  字符串相关函数

1、字符串连接  ||   concat(‘’,’’)

SQL> select 'a' || 'b' from dual;    //oracle 特有的符号操作

'A'||'B'

--------

ab

SQL> select concat('a','b') from dual;

CONCAT('A','B')

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

ab

SQL> select concat(concat('a','b'),'c') from dual;

CONCAT(CONCAT('A','B'),'C')

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

abc

3、  子串函数 substr(‘’,开始位置,字符长度)  instr(‘’,’出现的字符’)

SQL> select substr('abcdef',1) from dual;

SUBSTR('ABCDEF',1)

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

abcdef

备注:开始位置从1开始,如果有两个参数(substr(‘’,2))那么代表的意思是从位置2开始到字符串的结尾的字符串

 SQL> select substr('abcdef',1,3) from dual;

 SUBSTR('ABCDEF',1,3)

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

abc

 

select instr('abcdef','cd',1) from dual;

 

 

4、  大小写转换 upper(‘’)转换成大写,lower(‘’)转换成小写

SQL> select upper('abc') from dual;

UPPER('ABC')

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

ABC

SQL> select lower('ABC') from dual;

 

LOWER('ABC')

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

abc

5、随机字符串的函数

         dbms_random.string('a',6) //第一个参数有如下几个,第二参数代表产生的字符串的长度。

         u 大写字母

         l小写字母

         a大小写字母

         x大写字母和数字

         p任意字符

   举例如下:

SQL> select dbms_random.string('u',5) from dual;  //随机产生一个长度为5并且字符大写的字符串

DBMS_RANDOM.STRING('U',5)

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

RZLCC

SQL> /    //随机产生一个长度为5并且字符大写的字符串  注意观察下面的结果

DBMS_RANDOM.STRING('U',5)

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

RAVTG

SQL> /   //随机产生一个长度为5并且字符大写的字符串   注意观察下面的结果 每次都是随机产生

DBMS_RANDOM.STRING('U',5)

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

NOAJN

 

备注重点理解u,l,a,x,p的含义。

SQL> select dbms_random.string('l',5) from dual; //随机产生一个长度为5并且字符小写的字符串

DBMS_RANDOM.STRING('L',5)

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

tawgc

SQL> select dbms_random.string('a',5) from dual; //随机产生一个长度为5并且字符大小写混合的字符串

DBMS_RANDOM.STRING('A',5)

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

TEczi

SQL> select dbms_random.string('x',5) from dual; //随机产生一个长度为5并且字符与数字组合的字符串

 

DBMS_RANDOM.STRING('X',5)

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

4TDUU

 

SQL> select dbms_random.string('x',5) from dual;

DBMS_RANDOM.STRING('X',5)

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

RONOZ

SQL> /

DBMS_RANDOM.STRING('X',5)

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

YO803

SQL> select dbms_random.string('p',5) from dual; //随机产生一个长度为5任意的字符串

DBMS_RANDOM.STRING('P',5)

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

5=3)*

 

SQL> select dbms_random.string('p',5) from dual;

 

DBMS_RANDOM.STRING('P',5)

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

zf,@z

        

6、中文排序

         order by nlssort(,'NLS_SORT=SCHINESE_PINYIN_M');//拼音

         order by nlssort(,'NLS_SORT=SCHINESE_STROKE_M');//笔画

         order by nlssort(,'NLS_SORT=SCHINESE_RADICAL_M');//偏旁

举例如下:

SQL> select * from student; //查询所有数据

 

  SID NAME             DEPT    AGE

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

    1 张三               农大      21

    2 李四               农大      22

    3 王五               工大      21

    4 赵六               工大      20

SQL> select * from student order by name;  //注意观察

 

  SID NAME             DEPT    AGE

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

    1 张三               农大      21

    2 李四               农大      22

    3 王五               工大      21

    4 赵六               工大      20

SQL> select * from student order by nlssort(name,'NLS_SORT=SCHINESE_PINYIN_M');//按名笔画排序

  SID NAME             DEPT    AGE

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

    2 李四               农大      22

    3 王五               工大      21

    1 张三               农大      21

    4 赵六               工大      20

SQL> select * from student order by nlssort(name,'NLS_SORT=SCHINESE_STROKE_M');//注意理解

  SID NAME             DEPT    AGE

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

    3 王五               工大      21

    1 张三               农大      21

    2 李四               农大      22

    4 赵六               工大      20

SQL> select * from student order by nlssort(name,'NLS_SORT=SCHINESE_RADICAL_M');//注意理解

  SID NAME             DEPT    AGE

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

    1 张三               农大      21

    2 李四               农大      22

    4 赵六               工大      20

    3 王五               工大      21

 

8null

l       查询NULL值时所用语法  is null  is not null

l       NULL值参与运算总返回NULL

l       NULL值参与排序  null值最大

l       NVL函数  

l       DECODE函数

A、 查询Null

SQL> select * from emp where comm is null;//查询没有奖金的员工的用户

SQL> select * from emp where comm is not null;//查询有奖金的员工的用户

B、 null值参与运算

SQL>  select  ename,(sal+comm) from emp;

ENAME  (SAL+COMM)

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

SMITH  

ALLEN         1900

WARD         1750

JONES  

备注:null值参与运算返回的是空值

C、 null值参与排序

SQL> select ename,comm from emp order by comm;

ENAME       COMM

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

TURNER      0.00

test         100.00

CLARK  

备注:null值参与排序 null值最大

D、 nvl函数 nvl(列名,0)把列名为空或者’’的值转换成0 如果不为空是其本身值

SQL> select ename,nvl(comm,0) from emp;

ENAME  NVL(COMM,0)

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

SMITH             0

ALLEN           300

WARD           500

JONES             0

MARTIN        1400

 

注意:观察下面

SQL> select nvl('',0) from dual;

NVL('',0)

---------

0

SQL> select nvl(null,0) from dual;

NVL(NULL,0)

-----------

          0

E、  DECODE函数

 

 

 

 

 

9、集合运算符

l       UNION 并集 并去掉重复的行

l       UNION ALL 并集 不去除重复的行

l       MINUS  差集

l       INTERSECT 交集(oracle特有的)

 

 

 

 

 

 

 

 

 

 

 

 

10、伪列

l       ROWID

         注意:子查询讲完后,讲快速删除记录

l       ROWNUM

         Order by 连用的问题

l       ORA_ROWSCN

 

 

1rowNum的伪列

SQL> select ename, rownum from emp; //rownum为查询的结果 加上序列号

 

ENAME      ROWNUM

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

SMITH            1

ALLEN            2

WARD            3

..

MILLER          14

test              15

test              16

 

16 rows selected

 

SQL> select ename,rownum from emp where rownum<=5; //查询记录的前五条记录

 

ENAME      ROWNUM

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

SMITH            1

ALLEN            2

WARD            3

JONES            4

MARTIN          5

注意:如果把rownum用于比较条件时,只能用于小于,小于等于。

对于等于  大于  大于等于不使用.

但有个特殊值就是大于等于1 或者等于1的时候可以。这就与rownum的产生原理有关.就是每当从磁盘拿出结果时,加上序列号。通过测试分析

测试:

SQL> select ename,rownum from emp where rownum >5;//当使用大于判断时,没有查询出任何结果.

 

ENAME      ROWNUM

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

分析:当从磁盘读取的数据时,加上序列号为1,1>5不成立,读取数据,加上序号为1(这里很关键?)>5不成立,读取数据…….(明白了吗)?因此说1是特殊值.

 

RowNUMOrder By连接的问题

 

SQL> select ename,sal,rownum from emp  order by sal; //注意观察 rownum的输出结果.

 

ENAME        SAL     ROWNUM

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

test         100.00         15

SMITH      800.00          1

JAMES      950.00         12

ADAMS    1100.00         11

WARD     1250.00          3

MARTIN   1250.00          5

MILLER    1300.00         14

TURNER   1500.00         10

ALLEN     1600.00          2

CLARK     2450.00          7

BLAKE     2850.00          6

JONES     2975.00          4

SCOTT     3000.00          8

FORD      3000.00         13

KING      5000.00          9

test                        16

 

以上说明先执行的rownum 再执行的排序.

 

解决方法:

SQL> select ename,sal,rownum from (select * from emp order by sal);//通过子查询实现

ENAME        SAL     ROWNUM

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

test         100.00          1

SMITH      800.00          2

JAMES      950.00          3

……..

JONES     2975.00         12

SCOTT     3000.00         13

FORD      3000.00         14

KING      5000.00         15

test                        16

 

2rowid伪列:代表数据库表中记录的唯一标识(也可以理解成数据库表中该条记录的物理地址)

SQL> select ename,sal,rowid from emp;

ENAME        SAL ROWID

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

SMITH      800.00 AAADVsAABAAAI1qAAA

ALLEN     1600.00 AAADVsAABAAAI1qAAB

…….

MILLER    1300.00 AAADVsAABAAAI1qAAN

test         100.00 AAADVsAABAAAI1qAAO

test                AAADVsAABAAAI1qAAP

备注说明: 当使用rowid查询时,速度最快.

SQL> select * from emp where rowid='AAADVsAABAAAI1qAAA';

EMPNO ENAME  JOB        MGR HIREDATE       SAL      COMM DEPTNO

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

 7369 SMITH   CLERK   7902 1980-12-17    800.00               20

 

 

 

 

 

 

 

 

 

 

 

事务:

    在执行插入,更新,删除等操作的时候,oracle并不能够自动提交事务,需要手动提交.(采用commit;命令提交).(思考msyql是不是自动提交的呢?)

 例如:当我们执行以下操作的时候

 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

 ……….//省略部分

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

但是没有真正的提交事务

SQL> rollback; //我们执行事务回滚

Rollback complete

SQL> select * from emp;//再查看表中的数据

.在这里你会发现刚刚插入的数据没有了,因为在插入之后事务并没有真正的提交

那么怎么样才能实现呢,看下面的操作

1//执行数据的插入操作

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

2//执行数据插入成功后 通过commit手动提交

SQL> commit;

Commit complete

3//通过commit手动提交后,然后事务回滚

SQL> rollback;

Rollback complete

4//执行表的查询操作..注意观察插入的数据依然存在

SQL> select * from emp;

EMPNO ENAME  JOB        MGR HIREDATE       SAL      COMM DEPTNO

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

 7369 SMITH   CLERK   7902 1980-12-17    800.00               20

 …….

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

所以对于数据库的DML操作需要手动提交事务处理.

 

 

 

 

 

组合函数:

分组函数作用于一组数据,并对一组数据返回一个值。

l       AVG  平均值

l       COUNT 总记录

l       MAX   最大值

l       MIN   最小值

l       STDDEV(标准方差)

l       SUM   求和

举例:

SQL> select max(sal) from emp;//取出薪资的最大值

  MAX(SAL)

----------

      5000

SQL> select count(*) from emp;//取出此表总的总记录

  COUNT(*)

----------

        16

SQL> select count(comm) from emp;//取出此表中奖金不为空的总记录

COUNT(COMM)

-----------

          5

SQL> select min(sal) from emp;//取出薪资最小的值

  MIN(SAL)

----------

       100

SQL> select avg(sal) from emp;//取出薪资不为空的员工的平均薪资  //avg忽略空值

  AVG(SAL)

----------

1941.66666

备注:那怎么计算平均工资呢?

SQL> select sum(sal)/count(*) 平均工资 from emp;

 

      平均工资

----------

 1820.3125

或者

SQL> select avg(nvl(sal,0)) 平均工资 from emp;

 

      平均工资

----------

 1820.3125

 

 

SQL> select sum(sal) from emp;//取出薪资总额

  SUM(SAL)

----------

     29125

 

 

嵌套查询

     所谓嵌套查询指的是在一个select查询内再嵌入一个select查询。外层的select语句叫外部查询,内层的select语句叫子查询。

 

使用子查询注意事项:

         子查询可以嵌套多层

         子查询需要圆括号()括起来

      

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值