本文共 27399 字,大约阅读时间需要 91 分钟。
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 直接登录 2、sqlplus --提示输入用户名 --提示输入密码 B、也可以不退出直接在sql>操作中采用 conn scott/tiger conn/用户名/密码切换用户 注意:登录的时候没有分号结束。 4、oracle 中的表是按照用户进行分类的。 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文件中查找PORT与SERVICE_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; 注意:对用用户的创建,权限的分配,只有管理员才能够操作,普通用户不能实现. 登录简单总结 SQL Plus 登录的几种不同方式 • sqlplus 根据提示输入用户名、密码 • sqlplus 用户名/密码 (本机登录) • sqlplus 用户名/密码@网络服务名 (远程登录) • sqlplus / as sysdba (以sysdba身份登录,用户实际为sys) 总结: 创建用户 切换到system管理员中 以system管理员进行登录 1、Create user 用户名 identified by 密码;(不能是全数字) 2、grant create session,create table,resource to 用户名;//给用户分配权限 3、start 目录(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常见的命令 conn 切换连接用户 desc 显示表结构 host 执行操作系统命令 start 执行文件系统SQL语句 exit 退出 col 格式化输出 / 执行最近一条SQL或新定义过程 startup 启动数据库实例 (DBA) 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。 Nchar与char的解析是一样的不过,ncarh存储的是Unicode字符数据。 2、 可变长度的字符类型 varchar与char类似,但是它是用于存储可变的字符串,而char用于存储固定的字符串。 Nvarchar与varchar解析是一样的,不过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 SQL是structured Query Language(结构化查询语言)的缩写。可以使用sql语句建立或删除数据库的对象,插入,修改和更新数据库中的数据,并且可以对数据库执行各种日常管理的操作。它是所有关系数据库管理系统的标准语言.换句话说使用sql可以对所有的关系数据库进行操作。 SQL按照功能分类: 1、 数据库定义语句 DDL(Data Definition Language):用于创建、修改、删除数据库对象。 2、 数据库操作语句 DML(Data 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;//||连接符 把empno与ename作为一个字段显示 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: 使用 LIKE 运算选择类似的值 选择条件可以包含字符或数字: • % 代表零个或多个字符(任意个字符)。 • _ 代表一个字符。 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; 注意: 字符和日期要包含在单引号中。 字符大小写敏感,日期格式敏感。 默认的日期格式是 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; //查询部门号位10,20的员工信息 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 子句: 使用 ORDER BY 子句排序 • ASC(ascend): 升序 • DESC(descend): 降序 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子句、between、like、in、null、not 、or、and等来过滤数据,也可以使用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);返回date1到date2之间间隔多少个月 new_time(date,this’,’other’);将时间date从this时区转换成other时区 next_day(day,’day’);返回指定日期或最后一的第一个星期几的日期,这里day为星期几 sysdate();获取系统的当前日期 current_timestamp();获取当前的时间和日期值 round:日期的四舍五入 trunc 日期的截取 日期的数学运算: 在日期上加上或减去一个数字结果仍为日期。 两个日期相减返回日期之间相差的天数。 可以用数字除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类型 rowidtochar(x);把rowid类型转换成字符类型数据 通用函数 这些函数适用于任何数据类型,同时也适用于空值: NVL (expr1, expr2) NVL2 (expr1, expr2, expr3) NULLIF (expr1, expr2) COALESCE (expr1, expr2, ..., exprn) nvl() 将空值转换成一个已知的值: 可以使用的数据类型有日期、字符、数字。 函数的一般形式: • NVL(commission_pct,0) • NVL(hire_date,'01-JAN-97') • NVL(job_id,'No Job Yet') //将comm为null替换成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为空替换成sunlijuan SQL> select empno,ename,nvl(job,'sunlijuan'),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; COALESCE 与 NVL 相比的优点在于 COALESCE 可以同时处理交替的多个值。 如果第一个表达式为空,则返回下一个表达式,对其他的参数进行COALESCE 。 SQL> select empno,ename,job,mgr,hiredate,coalesce(comm,sal,10000) as "salll", deptno from emp; 重点理解:单行函数可以嵌套。嵌套函数的执行顺序是由内到外。 条件表达式 :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 当员工为 clerk加500 转换函数 //求余数 结果为300 //求余数 结果为300 文章:1、oracle简化安装图解 2、oracle的dos操作方式 3、SQL查询介绍 1、SQl介绍 2、基本查询 3、条件查询 4、排序查询 5、分组查询 6、having子句 查询语句: 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 8、null值 查询NULL值时所用语法 is null is not null NULL值参与运算总返回NULL NULL值参与排序 null值最大 NVL函数 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、集合运算符 UNION 并集 并去掉重复的行 UNION ALL 并集 不去除重复的行 MINUS 差集 INTERSECT 交集(oracle特有的) 10、伪列 ROWID • 注意:子查询讲完后,讲快速删除记录 ROWNUM • 与Order by 连用的问题 ORA_ROWSCN 1、rowNum的伪列 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是特殊值. RowNUM与Order 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 2、rowid伪列:代表数据库表中记录的唯一标识(也可以理解成数据库表中该条记录的物理地址)。 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操作需要手动提交事务处理. 组合函数: 分组函数作用于一组数据,并对一组数据返回一个值。 AVG 平均值 COUNT 总记录 MAX 最大值 MIN 最小值 STDDEV(标准方差) 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语句叫子查询。 使用子查询注意事项: 子查询可以嵌套多层 子查询需要圆括号()括起来转载地址:http://hjlmi.baihongyu.com/