收藏 分享(赏)

玩转oracle实战教程(韩顺平)学习word笔记.docx

上传人:拉拉链 文档编号:13563001 上传时间:2022-09-13 格式:DOCX 页数:85 大小:595.45KB
下载 相关 举报
玩转oracle实战教程(韩顺平)学习word笔记.docx_第1页
第1页 / 共85页
玩转oracle实战教程(韩顺平)学习word笔记.docx_第2页
第2页 / 共85页
玩转oracle实战教程(韩顺平)学习word笔记.docx_第3页
第3页 / 共85页
亲,该文档总共85页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、韩顺平玩转oracle视频教程笔记一:Oracle认证,与其它数据库比较,安装oracle的卸载1.停止所有与ORACLE相关的服务。2. 使用OUI(Oracle Universal Installer)卸载Oracle软件。“开始”-“程序”-“Oracle-OraDb110g_home1|Oracle installation product|Universal installer.3.删除注册表内容。运行regedit命令,删除下面内容:HKEY_LOCAL_MACHINE|SOFTWARE|ORACLE注册表键,删除此键。HKEY_LOCAL_MACHINE|SYSTEM|Curre

2、ntControlSet|Services,删除Services键下所有以oracle为首的键。HKEY_LOCAL_MACHINE|SYSTEM|CurrentControlSet|Services|Eventlog|Application, 删除此键下所有以oracle为首的键。HKEY_CLASSES_ROOT,删除此键下所有以Ora,Oracle,Orcl,EnumOra 为前缀的键。HKEY_CURRENT_USER|Software| Microsoft|Windows|CurrentVersion|Explorer|MenuOrder|Start Menu|Programs, 删

3、除此键下所有以oracle为首的键。HKEY_LOCAL_MACHINE|SOFTWARE|ODBC|ODBCINST.INI注册表键,删除了Microsoft ODBC FOR ORACLE注册表键以外的所有有Oracle字样的键值。HKEY_LOCAL_MACHINE|SYSTEM|CurrentControlSet|Services,删除以Oracle或OraWeb为前缀的键。4. 删除环境变量。 删除环境变量CLASSPATH,PATH中含有Oracle字样的值。5.最后在文件系统内删除ORACLE相关的文件及目录:删除系统盘符:Progrm FilesOracle目录;删除ORACL

4、E_BASE目录。我无法删除D:oracle目录,重新启动机器之后才删除Oracle安装会自动的生成sys用户和system用户: (1) sys用户是超级用户,具有最高权限,具有sysdba角色,有create database的权限,该用户默认的密码是change_on_install (2) system用户是管理操作员,权限也很大。具有sysoper角色,没有create database的权限,默认的密码是manager (3) 一般讲,对数据库维护,使用system用户登录就可以拉 也就是说sys和system这两个用户最大的区别是在于有没有create database的权限。E

5、nterprise manager console(企业管理器) (10G新应用到浏览器中) oracle 10g是通过web管理的 一般默认端口是5500, 也有1158的。 访问url(请一定保证oracle服务启动了): http:/ip:1158 (也可能是5500)/em http:/机器名:端口/em二: Oracle的基本使用-基本命令sql*plus的常用命令 连接命令 1. connect 用法:conn 用户名/密码网络服务名as sysdba/sysoper当用特权用户身份连接时,必须带上as sysdba或是as sysoper 2.disconnect 说明: 该命令

6、用来断开与当前数据库的连接 3.psssword 说明: 该命令用于修改用户的密码,如果要想修改其它用户的密码,需要用sys/system登录。 4.show user 说明: 显示当前用户名 5.exit 说明: 该命令会断开与数据库的连接,同时会退出sql*plus 6. SHOW PARAMETER NAME;说明:显示当前数据库实例名(只能用sys和system查);文件操作命令 1.start和 说明: 运行sql脚本 案例: sql d:a.sql或是sqlstart d:a.sql 2.edit 说明: 该命令可以编辑指定的sql脚本 案例: sqledit d:a.sql,这样

7、会把d:a.sql这个文件打开 3.spool 说明: 该命令可以将sql*plus屏幕上的内容输出到指定文件中去。 案例: sqlspool d:b.sql 并输入 sqlspool off 交互式命令 1.& 说明:可以替代变量,而该变量在执行时,需要用户输入。 select * from emp where job=&job; 2.edit 说明:该命令可以编辑指定的sql脚本 案例:SQLedit d:a.sql 3.spool 说明:该命令可以将sql*plus屏幕上的内容输出到指定文件中去。 spool d:b.sql 并输入 spool off 显示和设置环境变量 概述:可以用来

8、控制输出的各种格式,set show如果希望永久的保存相关的设置,可以去修改glogin.sql脚本 1.linesize 说明:设置显示行的宽度,默认是80个字符 show linesize set linesize 90 2.pagesize说明:设置每页显示的行数目,默认是14 用法和linesize一样 至于其它环境参数的使用也是大同小异 三:oracle用户管理oracle用户的管理 创建用户 概述:在oracle中要创建一个新的用户使用create user语句,一般是具有dba(数据库管理员)的权限才能使用。 create user 用户名 identified by 密码; (

9、oracle有个毛病,密码必须以字母开头,如果以字母开头,它不会创建用户) 例子: sql create user shunping identified by m123default tablespace userstemporary tablespace tempquota 3m on users;identified by 表明该用户shunping 将用数据库方式验证 default tablespace users /用户的表空间在users上temporary tablespace temp /用户shunping的临时表健在temp 空间quota 3m on users /表明

10、用户shunping 建立的数据对象(表,索引,视图,pl/sql块.)最大只能是3m刚刚创建的用户是没有任何权限的,因此,需要dba给该用户授权.sqlgrant connect to shunping 如果你希望该用户建表没有空间的限制sqlgrand resource to shunping如果你希望该用户成为dbasqlgrant dba to shunping给用户修改密码 概述:如果给自己修改密码可以直接使用 password 用户名 如果给别人修改密码则需要具有dba的权限,或是拥有alter user的系统权限 SQL alter user 用户名 identified by

11、新密码 删除用户 概述:一般以dba的身份去删除某个用户,如果用其它用户去删除用户则需要具有drop user的权限。 比如 drop user 用户名 【cascade】 在删除用户时,注意: 如果要删除的用户,已经创建了表,那么就需要在删除的时候带一个参数cascade; 用户管理的综合案例 概述:创建的新用户是没有任何权限的,甚至连登陆的数据库的权限都没有,需要为其指定相应的权限。给一个用户赋权限使用命令grant,回收权限使用命令revoke。 为了给讲清楚用户的管理,这里我给大家举一个案例。 SQL conn xiaoming/m12; ERROR: ORA-01045: user

12、XIAOMING lacks CREATE SESSION privilege; logon denied 警告: 您不再连接到 ORACLE。 SQL show user; USER 为 SQL conn system/p; 已连接。 SQL grant connect to xiaoming; 授权成功。 查看CONNECT角色具有的权限;select role, privilege, admin_option from role_sys_privs where upper(role)=CONNECT;SQL conn xiaoming/m12; /后面的为密码分开来输入。已连接。 SQL

13、 注意:grant connect to xiaoming;在这里,准确的讲,connect不是权限,而是角色(角色是权限的集合)。 看图: 现在说下对象权限,现在要做这么件事情: * 希望xiaoming用户可以去查询emp表 * 希望xiaoming用户可以去查询scott的emp表 grant select on emp to xiaoming * 希望xiaoming用户可以去修改scott的emp表 grant update on emp to xiaoming * 希望xiaoming用户可以去修改/删除,查询,添加scott的emp表 grant all on emp to xi

14、aoming * scott希望收回xiaoming对emp表的查询权限 revoke select on emp from xiaoming /对权限的维护。 * 希望xiaoming用户可以去查询scott的emp表/还希望xiaoming可以把这个权限继续给别人。 -如果是对象权限,就加入 with grant option grant select on emp to xiaoming with grant option 我的操作过程: SQL conn scott/tiger; 已连接。 SQL grant select on scott.emp to xiaoming with g

15、rant option; 授权成功。 SQL conn system/p; 已连接。 SQL create user xiaohong identified by m123; 用户已创建。 SQL grant connect to xiaohong; 授权成功。 SQL conn xiaoming/m12; 已连接。 SQL grant select on scott.emp to xiaohong; 授权成功。 -如果是系统权限。 system给xiaoming权限时: grant connect to xiaoming with admin option 问题:如果scott把xiaomi

16、ng对emp表的查询权限回收,那么xiaohong会怎样? 答案:被回收。 下面是我的操作过程: SQL conn scott/tiger; 已连接。 SQL revoke select on emp from xiaoming; 撤销成功。 SQL conn xiaohong/m123; 已连接。 SQL select * from scott.emp; select * from scott.emp 第 1 行出现错误: ORA-00942: 表或视图不存在 结果显示:小红受到诛连了。使用profile管理用户口令 概述:profile是口令限制,资源限制的命令集合,当建立数据库的,ora

17、cle会自动建立名称为default的profile。当建立用户没有指定profile选项,那么oracle就会将default分配给用户。 1.账户锁定 概述:指定该账户(用户)登陆时最多可以输入密码的次数,也可以指定用户锁定的时间(天)一般用dba的身份去执行该命令。 例子:指定scott这个用户最多只能尝试3次登陆,锁定时间为2天,让我们看看怎么实现。 创建profile文件 SQL create profile lock_account limit failed_login_attempts 3 password_lock_time 2; SQL alter user scott pr

18、ofile lock_account; 2.给账户(用户)解锁 SQL alter user tea account unlock; 3.终止口令 为了让用户定期修改密码可以使用终止口令的指令来完成,同样这个命令也需要dba的身份来操作。 例子:给前面创建的用户tea创建一个profile文件,要求该用户每隔10天要修改自己的登陆密码,宽限期为2天。看看怎么做。 SQL create profile myprofile limit password_life_time 10 password_grace_time 2; SQL alter user tea profile myprofile;

19、 口令历史 概述:如果希望用户在修改密码时,不能使用以前使用过的密码,可使用口令历史,这样oracle就会将口令修改的信息存放到数据字典中,这样当用户修改密码时,oracle就会对新旧密码进行比较,当发现新旧密码一样时,就提示用户重新输入密码。 例子: 1)建立profile SQLcreate profile password_history limit password_life_time 10 password_grace_time 2 password_reuse_time 10 password_reuse_time /指定口令可重用时间即10天后就可以重用 2)分配给某个用户 删除

20、profile 概述:当不需要某个profile文件时,可以删除该文件。 SQL drop profile password_history 【casade】 注意:文件删除后,用这个文件去约束的那些用户通通也都被释放了。若创建的PROFILE已经授权给了某个用户,使用CASCADE级联收回相应的限制,收回限制信息后将以系统默认的PROFILE对该用户进行限制。加了casade,就会把级联的相关东西也给删除掉四:oracle表的管理(数据类型,表创建删除,数据CRUD操作)oracle的表的管理 表名和列的命名规则 必须以字母开头 长度不能超过30个字符 不能使用oracle的保留字 只能使用

21、如下字符 A-Z,a-z,0-9,$,#等 oracle支持的数据类型 字符类 char 定长 最大2000个字符。 例子:char(10) 小韩前四个字符放小韩,后添6个空格补全 如小韩 varchar2(20) 变长 最大4000个字符。 例子:varchar2(10) 小韩 oracle分配四个字符。这样可以节省空间。 clob(character large object) 字符型大对象 最大4G char 查询的速度极快浪费空间,查询比较多的数据用。 varchar 节省空间 数字型number范围 -10的38次方 到 10的38次方 可以表示整数,也可以表示小数 number(5

22、,2) 表示一位小数有5位有效数,2位小数 范围:-999.99到999.99 number(5) 表示一个5位整数 范围99999到-99999 日期类型 date 包含年月日和时分秒 oracle默认格式 1-1月-1999 timestamp 这是oracle9i对date数据类型的扩展。可以精确到毫秒。 图片blob 二进制数据 可以存放图片/声音 4G 一般来讲,在真实项目中是不会把图片和声音真的往数据库里存放,一般存放图片、视频的路径,如果安全需要比较高的话,则放入数据库。 怎样创建表 建表-学生表 create table student ( -表名 xh number(4),

23、-学号 xm varchar2(20), -姓名 sex char(2), -性别 birthday , date -出生日期 sal number(7,2) -奖学金 ); -班级表 CREATE TABLE class( classId NUMBER(2), cName VARCHAR2(40); 修改表 添加一个字段SQLALTER TABLE student add (classId NUMBER(2); 修改一个字段的长度 SQLALTER TABLE student MODIFY (xm VARCHAR2(30); 修改字段的类型/或是名字(不能有数据) 不建议做 SQLALTER

24、 TABLE student modify (xm CHAR(30); 删除一个字段 不建议做(删了之后,顺序就变了。加就没问题,应为是加在后面)SQLALTER TABLE student DROP COLUMN sal; 修改表的名字 很少有这种需求 SQLRENAME student TO stu; 删除表 SQLDROP TABLE student; 添加数据 所有字段都插入数据 INSERT INTO student VALUES (A001, 张三, 男, 01-5月-05, 10); oracle中默认的日期格式dd-mon-yy dd日子(天) mon 月份 yy 2位的年 0

25、9-6月-99 1999年6月9日 修改日期的默认格式(临时修改,数据库重启后仍为默认;如要修改需要修改注册表) ALTER SESSION SET NLS_DATE_FORMAT =yyyy-mm-dd; 修改后,可以用我们熟悉的格式添加日期类型: INSERT INTO student VALUES (A002, MIKE, 男, 1905-05-06, 10); 插入部分字段 INSERT INTO student(xh, xm, sex) VALUES (A003, JOHN, 女); 插入空值 INSERT INTO student(xh, xm, sex, birthday) VA

26、LUES (A004, MARTIN, 男, null); 问题来了,如果你要查询student表里birthday为null的记录,怎么写sql呢? 错误写法:select * from student where birthday = null; 正确写法:select * from student where birthday is null; 如果要查询birthday不为null,则应该这样写: select * from student where birthday is not null; 修改数据 修改一个字段UPDATE student SET sex = 女 WHERE x

27、h = A001; 修改多个字段UPDATE student SET sex = 男, birthday = 1984-04-01 WHERE xh = A001; 修改含有null值的数据 不要用 = null 而是用 is null; SELECT * FROM student WHERE birthday IS null; 删除数据DELETE FROM student; 删除所有记录,表结构还在,写日志,可以恢复的,速度慢。 Delete 的数据可以恢复。 savepoint a; -创建保存点 DELETE FROM student; rollback to a; -恢复到保存点 一

28、个有经验的DBA,在确保完成无误的情况下要定期创建还原点。 DROP TABLE student; -删除表的结构和数据; delete from student WHERE xh = A001; -删除一条记录; truncate TABLE student; -删除表中的所有记录,表结构还在,不写日志,无法找回删除的记录,速度快。五:oracle表查询(1)oracle表基本查询 介绍在我们讲解的过程中我们利用scott用户存在的几张表(emp,dept)为大家演示如何使用select语句,select语句在软件编程中非常有用,希望大家好好的掌握。 emp 雇员表 clerk 普员工 sa

29、lesman 销售 manager 经理 analyst 分析师 president 总裁 mgr 上级的编号 hiredate 入职时间 sal 月工资 comm 奖金 deptno 部门 dept部门表 deptno 部门编号 accounting 财务部 research 研发部 operations 业务部 loc 部门所在地点 salgrade 工资级别 grade 级别 losal 最低工资 hisal 最高工资 简单的查询语句 查看表结构DESC emp; 查询所有列SELECT * FROM dept; 切忌动不动就用select * SET TIMING ON; 打开显示操作

30、时间的开关,在下面显示查询时间。 CREATE TABLE users(userId VARCHAR2(10), uName VARCHAR2 (20), uPassw VARCHAR2(30); INSERT INTO users VALUES(a0001, 啊啊啊啊, aaaaaaaaaaaaaaaaaaaaaaa); -从自己复制,加大数据量 大概几万行就可以了 可以用来测试sql语句执行效率 INSERT INTO users (userId,UNAME,UPASSW) SELECT * FROM users; SELECT COUNT (*) FROM users;统计行数 查询指定

31、列SELECT ename, sal, job, deptno FROM emp; 如何取消重复行DISTINCT SELECT DISTINCT deptno, job FROM emp; 查询SMITH所在部门,工作,薪水 SELECT deptno,job,sal FROM emp WHERE ename = SMITH; 注意:oracle对内容的大小写是区分的,所以ename=SMITH和ename=smith是不同的 使用算术表达式nvl null 问题:如何显示每个雇员的年工资? SELECT sal*13+nvl(comm, 0)*13 年薪 , ename, comm FRO

32、M emp; 使用列的别名SELECT ename 姓名, sal*12 AS 年收入 FROM emp; 如何处理null值使用nvl函数来处理 如何连接字符串(|)SELECT ename | is a | job FROM emp; 使用where子句问题:如何显示工资高于3000的 员工? SELECT * FROM emp WHERE sal 3000; 问题:如何查找1982.1.1后入职的员工? SELECT ename,hiredate FROM emp WHERE hiredate 1-1月-1982; 问题:如何显示工资在2000到3000的员工? SELECT ename

33、,sal FROM emp WHERE sal =2000 AND sal 500 or job = MANAGER) and ename LIKE J%; 使用order by 字句 默认asc 问题:如何按照工资的从低到高的顺序显示雇员的信息? SELECT * FROM emp ORDER by sal; 问题:按照部门号升序而雇员的工资降序排列 SELECT * FROM emp ORDER by deptno, sal DESC; 使用列的别名排序问题:按年薪排序 select ename, (sal+nvl(comm,0)*12 年薪 from emp order by 年薪 as

34、c; 别名需要使用“”号圈中,英文不需要“”号 分页查询 等学了子查询再说吧。 Clear 清屏命令 oracle表复杂查询 说明在实际应用中经常需要执行复杂的数据统计,经常需要显示多张表的数据,现在我们给大家介绍较为复杂的select语句 数据分组 max,min, avg, sum, count 问题:如何显示所有员工中最高工资和最低工资? SELECT MAX(sal),min(sal) FROM emp e; 最高工资那个人是谁? 错误写法:select ename, sal from emp where sal=max(sal); 正确写法:select ename, sal fro

35、m emp where sal=(select max(sal) from emp); 注意:select ename, max(sal) from emp;这语句执行的时候会报错,说ORA-00937:非单组分组函数。因为max是分组函数,而ename不是分组函数. 但是select min(sal), max(sal) from emp;这句是可以执行的。因为min和max都是分组函数,就是说:如果列里面有一个分组函数,其它的都必须是分组函数,否则就出错。这是语法规定的问题:如何显示所有员工的平均工资和工资总和? 问题:如何计算总共有多少员工问题:如何扩展要求: 查询最高工资员工的名字,工

36、作岗位 SELECT ename, job, sal FROM emp e where sal = (SELECT MAX(sal) FROM emp); 显示工资高于平均工资的员工信息 SELECT * FROM emp e where sal (SELECT AVG(sal) FROM emp); group by 和 having子句 group by用于对查询的结果分组统计, having子句用于限制分组显示结果。 问题:如何显示每个部门的平均工资和最高工资? SELECT AVG(sal), MAX(sal), deptno FROM emp GROUP by deptno; (注意

37、:这里暗藏了一点,如果你要分组查询的话,分组的字段deptno一定要出现在查询的列表里面,否则会报错。因为分组的字段都不出现的话,就没办法分组了) 问题:显示每个部门的每种岗位的平均工资和最低工资? SELECT min(sal), AVG(sal), deptno, job FROM emp GROUP by deptno, job; 问题:显示平均工资低于2000的部门号和它的平均工资? SELECT AVG(sal), MAX(sal), deptno FROM emp GROUP by deptno having AVG(sal) 2000; 对数据分组的总结 1 分组函数只能出现在选

38、择列表、having、order by子句中(不能出现在where中) 2 如果在select语句中同时包含有group by, having, order by 那么它们的顺序是group by, having, order by 3 在选择列中如果有列、表达式和分组函数,那么这些列和表达式必须有一个出现在group by 子句中,否则就会出错。 如SELECT deptno, AVG(sal), MAX(sal) FROM emp GROUP by deptno HAVING AVG(sal) select * from salgrade; GRADE LOSAL HISAL - - -

39、1 700 1200 2 1201 1400 3 1401 2000 4 2001 3000 5 3001 9999 SELECT e.ename, e.sal, s.grade FROM emp e, salgrade s WHERE e.sal BETWEEN s.losal AND s.hisal; 扩展要求: 问题:显示雇员名,雇员工资及所在部门的名字,并按部门排序? SELECT e.ename, e.sal, d.dname FROM emp e, dept d WHERE e.deptno = d.deptno ORDER by e.deptno; (注意:如果用group by

40、,一定要把e.deptno放到查询列里面) 自连接自连接是指在同一张表的连接查询 问题:显示某个员工的上级领导的姓名? 比如显示员工FORD的上级 SELECT worker.ename, boss.ename FROM emp worker,emp boss WHERE worker.mgr = boss.empno AND worker.ename = FORD; 子查询 什么是子查询子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询。 单行子查询 单行子查询是指只返回一行数据的子查询语句 请思考:显示与SMITH同部门的所有员工? 思路:1 查询出SMITH的部门号 sel

41、ect deptno from emp WHERE ename = SMITH; 2 显示 SELECT * FROM emp WHERE deptno = (select deptno from emp WHERE ename = SMITH); 数据库在执行sql 是从左到右扫描的, 如果有括号的话,括号里面的先被优先执行。 多行子查询多行子查询指返回多行数据的子查询 请思考:如何查询和部门10的工作相同的雇员的名字、岗位、工资、部门号 SELECT DISTINCT job FROM emp WHERE deptno = 10; SELECT * FROM emp WHERE job IN (SELECT DISTINCT job FROM emp WHERE deptno = 10); (注意:不能用job=.,因为等

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 企业信息化

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报