ORACLE数据库设计.doc
《ORACLE数据库设计.doc》由会员分享,可在线阅读,更多相关《ORACLE数据库设计.doc(82页珍藏版)》请在咨信网上搜索。
1、海颐软件股份有限公司ORACLE技术文档之一 源码网整理:目录第1章Oracle数据库安装配置31.1 配置监听程序31.2 配置网络服务名4第2章管理用户访问42.1表空间、用户及方案概述42.2用户访问52.3创建用户62.4修改用户62.5 锁定用户账户72.6 解锁用户账户72.7 默认角色72.8 授予用户访问权72.9撤消用户92.10废除用户访问92.11创建角色92.12 新建的用户怎样才能成功创建一个表10第3章建立和管理表113.1简介123.2建表133.3修改表143.4截断和删除表143.5显示表信息15第4章 Oracle操作符16第5章 基本查询195.1简单查询
2、语句195.2排序数据21第6章 复杂查询226.1数据分组226.2连接查询236.3相等连接(包括SQL:1999标准内连接、自然连接)246.4不等连接246.5自连接246.6内连接和外连接246.6.1内连接256.6.2左外连接256.6.3右外连接256.6.4完全外连接256.7子查询256.7.1单行子查询(单列)256.7.2多行子查询(单列)256.7.3多列子查询266.7.4其他子查询266.8使用集合操作符27第7章 常用SQL函数27第8章 操纵数据418.1插入数据418.2更新数据438.3删除数据44第9章 使用事务459.1概述469.2事务分类469.3
3、回复修改479.4回复部分事务489.5事务和锁49第10章 使用约束4910.1约束简介4910.2定义约束5010.3维护约束5110.5显示约束信息52第11章 使用视图5311.1视图简介5311.2建立视图5411.3维护视图5511.4显示视图信息55第12章 使用其它对象(索引序列同义词)5612.1使用索引5612.1.1建立索引5712.1.2维护索引5712.1.3显示索引信息5811.2使用序列5811.21建立序列5811.2.2使用序列5811.2.3维护序列5911.2.4显示序列信息5911.3使用同义词5911.3.1建立同义词5911.3.2删除同义词59第1
4、3章 PL/SQL语句6013.1 PL/SQL简介6013.2 PL/SQL块6213.2.1定义并使用变量6313.2.2异常6413.2.2游标6713.3过程函数包71第14章 过程函数包及触发器7114.1过程7114.1.1建立过程7114.1.2显示过程代码7214.2函数7214.2.1建立函数7214.2.2删除函数7314.2.3显示函数代码7314.3包7314.3.1建立包规范7314.3.2建立包体7414.3.3删除包7514.3.4显示包代码7514.4触发器7514.4.1语句触发器7514.4.2行触发器7614.4.3使用触发器的注意事项7714.4.4编译
5、触发器7714.4.5删除触发器7714.4.6显示触发器代码77第十五章 使用EXP和IMP7715.1使用EXP7815.1.1导出表7815.1.2导出方案7815.1.3导出数据库7815.2使用IMP7815.2.1导入表7915.2.2导入方案7915.2.3导入数据库79第1章Oracle数据库安装配置当安装Oracle Database时,如果没有建立数据库,在安装完成之后可以使用DBCA工具建立数据库。数据库配置助手(Database Configuration Assistant)用于建立数据库、配置数据库选项、删除数据库和管理模板。当建立了Oracle数据库之后,为了使得
6、服务器端可以监听该Oracle数据库,必须配置监听程序。为了使得客户端可以访问该数据库,必须在客户端配置网络服务名。只有合理地配置了监听程序和网络服务名之后,客户应用才能访问该数据库。配置监听程序和网络服务名可以使用网络管理工具Net Manager完成。(源码网整理:)1.1 配置监听程序监听程序用于接收客户端的连接请求。当客户应用访问Oracle Server时,监听程序会接收并检查连接请求,以确定是否可以为该客户应用提供数据服务。在建立了Oracle数据库之后,为了使得客户应用可以访问Oracle数据库,必须在监听程序中追加该数据库。一个监听程序可以监听多个Oracle数据库,多个监听程
7、序也可以监听同一个Oracle数据库。当安装数据库产品时,会自动建立默认监听程序LISTENER。配置监听程序的具体步骤如下:l 展开监听程序,并选中LISTENER节点,此时在NET MANAGER窗口右端会显示默认监听位置,其中“协议”用于指定监听程序要使用的网络协议(默认为TCP/IP);“主机”用于指定服务器所在机器的主机名或IP地址;“端口”用于指定监听程序要使用的TCP/IP端口号(默认1521)。l 在Net Manager窗口上端的下拉列表中选择数据库服务,此时会显示默认的数据库配置,“全局数据库名”用于指定数据库的全局数据库名;“Oracle主目录”用于指定Oracle数据库
8、软件的安装路径;“SID”用于指数据库例程名。为了监听新建的数据库(如DEMO),必须追加该数据库。l 单击“添加数据库”按钮,然后进行相应配置,在“全局数据库名”处输入DEMO数据库的初始化参数SERVICEHOME所对应的值,在SID处输入DEMO数据库的例程名。配置了监听程序之后,保存网络配置信息。l 保存了监听程序配置之后,为了使得其网络配置生效,必须重新启动监听程序。(通过服务器管理器重新启动监听程序)1.2 配置网络服务名l 选中“服务命名”,然后单击+按钮,此时会显示“Net 服务名”界面,建议使用数据库名作网络服务名。l 选取与监听程序一致的网络协议“TCP/IP”。l 指定数
9、据库所在主机名及其监听端口号。l 指定监听程序所配置的全局数据库名或者SID。l 测试网络服务名配置是否成功,如果成功则表示网络服务名配置正确。l 完成网络服务名配置之后,保存网络配置信息。第2章管理用户访问本章主要内容:l 表空间、用户及方案概述l 用户访问l 创建用户l 修改用户l 授予用户访问权l 撤消用户l 废除用户访问l 创建角色2.1 表空间、用户及方案概述表空间是数据库的逻辑组成部分。从物理上说,数据库数据存放在数据文件中;从逻辑上说,数据库数据存放在表空间(tablespace)中,并且表空间是由一个或多个数据文件组成的。一个表空间是由一个或多个数据文件组成的。用户(也称为帐户
10、)是定义在数据库中的一个名称,它是Oracle数据库的基本访问控制机制。当连接到Oracle数据库时,默认情况下必须要提供用户名和口令。只有在输入了正确的用户名和口令之后,才能够连接到数据库,并执行各种管理操作和数据访问操作。方案(Schema)是用户所拥有数据库对象的集合。在Oracle数据库中对象是以用户来组织的,用户与方案是一一对应的关系,并且二者名称相同。例SCOTT用户所拥有的所有对象都属于SCOTT方案,而SYSTEM用户所拥有的所有对象都属于SYSTEM方案。当访问数据库对象时,有一些注意事项:l 在同一个方案中不能存在同名对象,但不同方案可以具有同名对象。l 用户可以直接访问其
11、方案对象,但如果要访问其他方案对象,则必须具有对象权限。如用户SCOTT可以直接查询其方案表EMP,但如果用户SMITH要检索SCOTT方案的表EMP,则必须在EMP表上具有SELECT对象权限。l 当用户访问其他方案对象时,必须加方案名为前缀。例,如用户SMITH要访问SCOTT方案的EMP表,则必须使用SCOTT.EMP。2.2 用户访问在多用户环境里,一个数据库可能有多个用户同时在访问。当有不同的用户同时访问数据库时,保护数据库安全,防范非授权访问非常重要。因此,必须在数据库里创建用户,并为用户指定用户名和密码,这样可以保证只有经过授权的,即有正确用户名和密码的用户才能访问数据库。数据库
12、管理员(DBA)是最高级别的用户,他可以创建其他用户。在创建了用户后,DBA需要按用户的需求为用户分配权限。权限指用户执行特定语句的许可,这意味并非所有用户都被允许修改重要数据。例如,某个用户可能只需要有连接数据库和查询某些表的记录的权限。类似地,另一个用户可能要求有创建和修改表的权限。DBA有访问数据库的一切权限,并有权为其他用户分配权限。下表列出了部分DBA权限:DBA权限有权执行CREATE USER创建新用户DROP USER撤消用户DROP ANY TABLE撤消表BACKUP ANY TABLE为表制作备份SELECT ANY TABLE查询数据库对象,如表和视图CREATE AN
13、Y TABLE创建表为了维护存储在数据库中数据的安全,Oracle提供了以下数据库安全措施:l 管理和控制数据库访问l 用Oracle数据字典验证权限l 为指定用户提供对数据库特定对象(表、视图和序列等)的访问l 为数据库对象提供同义词可被数据库操作采用的数据库的安全策略包括:l 系统安全:系统安全涉及系统级的访问,如允许用户通过指出用户名和密码连接Oracle,为用户分配磁盘空间,限定用户所能执行的操作。用户能执行的操作包括:查询数据库对象的内容、创建数据库对象和更改数据库对象。l 数据安全:数据安全涉及对数据库对象的访问和使用,以及用户在数据库对象上所拥有的权限的程度。2.3 创建用户CR
14、EATE USER语句用于创建新用户。在创建新用户时,必须为新用户指定用户名和密码。为了使新用户能登录服务器和访问数据库,DBA必须显式地为用户分配权限。只有拥有CREATE USER权限的用户才能创建新用户。例如,DBA创建了新用户Susan,但Susan无权创建其他新用户。只有当Susan有了CREATE USER这个权限后,她才能创建别的新用户。创建用户的语法示例:CREATE USER user IDENTIFIED BY passwordDEFAULT TABLESPACE data01TEMPORARY TABLESPACE tempQUOTA 3M ON data01PASSWO
15、RD EXPIRE;其中IDENTIFIED BY用于指定用户口令;DEFAULT TABLESPACE用于指定用户的默认表空间,当建立表或者索引时,如果不指定TABLESPACE子句,那么Oracle会自动在默认表空间上为这些对象分配空间;TEMPORARY TABLESPACE用于指定用户的临时表空间,当用户执行排序操作时,或临时数据超过PGA工作区,则会在该表空间上建立临时段;QUOTA用于指定表空间配额,即用户对象在表空间上可占用的最大空间;PASSWORD EXPIRE用于指定终止口令,最终强制用户在登录时改变口令。当建立了新用户之后,需要注意以下问题:l 初始创建的数据库用户没有任
16、何权限,不能执行任何数据库操作。l 如果在建立用户时不指定DEFAULT TABLESPACE子句,那么Oracle会将数据库默认表空间作为用户的默认表空间。在Oracle Database 10g之前,如果不指定DEFAULT TABLESPACE子句,那么Oracle会将SYSTEM表空间作为用户的默认表空间。l 如果在建立用户时不指定TEMPORARY TABLESPACE子句,那么Oracle会将数据库默认临时表空间作为用户的临时表空间。l 如果在建立用户时没有为特定表空间指定QUOTA子句,那么用户在特定表空间上的配额为0,这样用户将不能在相应表空间上建立数据对象。2.4 修改用户修
17、改用户信息是使用ALTER USER命令完成的。一般情况下,该命令是由DBA来执行的,如果以其他用户身份修改用户信息,必须要具有ALTER USER系统权限。1修改口令创建用户时为每个用户指定一个初始密码。之后可修改密码,修改密码的方法有两种:l 管理员修改:ALTER USER user IDENTIFIED BY password;(password为用户的新密码)l 用户自己修改:用户登录后输入命令:PASSWORD;修改表空间配额表空间配额用于限制用户对象在表空间上可占用的最大空间。如果用户对象己经占满了表空间配额所允许的最大空间,那么该用户将不能在该表空间上分配新的空间。此时如果执行
18、了涉及到空间分配的SQL操作(如INSERT、UPDATE、CREATE TABLE等),则会显示错误,修改表空间语法:ALTER USER user QUOTA 10M ON data01;2.5 锁定用户账户为了禁止特定数据库用户用户访问数据库,DBA可以锁定用户账户,ALTER USER user ACCOUNT LOCK;2.6 解锁用户账户为了使得数据库用户可以访问数据库,DBA可以解锁用户账户。ALTER USER user ACCOUNT UNLOCK;2.7 默认角色当将多个角色授予数据库用户之后,通过使用ALTER USER 命令可以设置用户的默认角色。(当为用户指定了默认角
19、色后,以该用户身份登录时会自动激活其默认角色,并不激活非默认角色)ALTER USER user DEFAULT ROLE select_role;补充: 默认角色和非默认角色的区别是什么? 这个理解有多种,第一种:默认角色可以是我们创建数据库就可以见的connect/dba等,非默认角色需要我们自己创建;第二种:一个用户可以有多个角色,默认的角色登录即生效,非默认的需要激活才能使用。 默认角色和权限集是Oracle安装过程中预先定义的。每个版本的默认角色都有所变化。CREATE USER SMIS IDENTIFIED BY SMIS;grant dba,connect to SMIS;cr
20、eate role r_px; grant r_px to SMIS;select * from dba_role_privs where grantee=SMIS;alter user SMIS default role all except r_px;select * from dba_role_privs where grantee=SMIS;2.8 授予用户访问权用户创建后,数据库管理员需要为他分配权限。权限关系到数据库的安全,它决定了用户在数据库上所能执行的操作。GRANT语句用于为用户分配权限。语法如下:GRANT privilege TO user; 注释:授予所有系统权限GRA
21、NT ALL PRIVILEGES to test_2;注释:授予所有对象权限 GRANT ALL PRIVILEGES ON DEMO.DEPT TO TEST_1;可分配给用户的权限有:l 系统权限:允许用户访问数据库的权限称为系统权限。l 对象权限:允许用户在数据库对象上执行查询、更新、删除或添加数据等操作的权限,此称为对象权限。常用的系统权限有:系统权限有权执行CREATE SESSION连接数据库CREATE TABLE创建表CREATE VIEW创建视图CREATE PUBLIC SYNONYM建立同义词CREATE SEQUENCE创建序列CREATE PROCEDURE建立过程
22、、函数和包CREATE TRIGGER建立触发器CREATE CLUSTER建立簇CREATE TYPE建立对象类型CREATE DATABASE LINK建立数据库链另外,Oracle还提供了一类ANY系统权限,当用户具有该类系统权限时,可以在任何方案中执行相应操作。例如,如果用户具有SELECT ANY TABLE系统权限,那么用户可以查询任何方案的表(除数据字典基表和数据字典视图DBA_XXX-DBA和特权用户专访)。如:GRANT CREATE SESSION,CREATE SEQUENCE,CREATE VIEW TO john;上述命令执行后,用户john将拥有创建会话、视图和序列
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- ORACLE 数据库 设计
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【a199****6536】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【a199****6536】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。