Oracle10g数据库基础教程
‘壹’ 如何手工创建一个Oracle 10g数据库
手动创建oracle10g数据库
以创建名为“MYNEWDB”为例
1. 创建必须的文件和文件夹
(1)在D:\oracle\proct\10.2.0\admin下建MYNEWDB文件夹
在D:\oracle\proct\10.2.0\admin\MYNEWDB下建amp,bmp,cmp,ump文件夹
(2)在D:\oracle\proct\10.2.0\oradata下建MYNEWDB文件夹
(3)在D:\oracle\proct\10.2.0\db_1\database下建initMYNEWDB.ora文件,内容如下
MYNEWDB.__db_cache_size=356515840
MYNEWDB.__java_pool_size=4194304
MYNEWDB.__large_pool_size=4194304
MYNEWDB.__shared_pool_size=209715200
MYNEWDB.__streams_pool_size=0
*.audit_file_dest='D:\oracle\proct\10.2.0/admin/MYNEWDB/amp'
*.background_mp_dest='D:\oracle\proct\10.2.0/admin/MYNEWDB/bmp'
*.compatible='10.2.0.1.0'
*.control_files='D:\oracle\proct\10.2.0/oradata/MYNEWDB/\control01.ctl','D:\oracle\proct\10.2.0/oradata/MYNEWDB/\control02.ctl','D:\oracle\proct\10.2.0/oradata/MYNEWDB/\control03.ctl'
*.core_mp_dest='D:\oracle\proct\10.2.0/admin/MYNEWDB/cmp'
*.db_block_size=8192
*.db_domain=''
*.db_file_multiblock_read_count=16
*.db_name='MYNEWDB'
*.db_recovery_file_dest='D:\oracle\proct\10.2.0/flash_recovery_area'
*.db_recovery_file_dest_size=2147483648
*.dispatchers='(PROTOCOL=TCP) (SERVICE=MYNEWDBXDB)'
*.job_queue_processes=10
*.open_cursors=300
*.pga_aggregate_target=192937984
*.processes=150
*.remote_login_passwordfile='EXCLUSIVE'
*.sga_target=579862528
*.undo_management='AUTO'
*.undo_tablespace='UNDOTBS1'
*.user_mp_dest='D:\oracle\proct\10.2.0/admin/MYNEWDB/ump'
2.建议设置下ORACLE_HOME=D:\oracle\proct\10.2.0\db_1,因为下面在执行创建数据库时会自动执行$ORACLE_HOME\rdbms\admin\sql.bsq的脚本,不设怕找不到
3. 创建实例
选择“程序-->运行”,输入“cmd”命令,打开DOS界面
(1)将环境变量ORACLE_SID设置为“MYNEWDB”
C:\SET ORACLE_SID=MYNEWDB
(2)利用ORADIM命令创建MYNEWDB数据库
C:\ORADIM -NEW -SID MYNEWDB -INTPWD MYNEWDB -STARTMODE MANUAL -PFILE D:\oracle\proct\10.2.0\db_1\database
注意:ORADMIN是Oracle提供的一个对实例进行管理的工具,可以创建、修改、删除、启动和关闭一个
4、连接并启动实例
1. C:\sqlplus /nolog
2. SQL>connect sys/mynewdb as sysdba;
3. SQL>startup nomount;
5、使用create database 语句创建数据库
1. SQL> create database MYNEWDB
2. maxlogfiles 10
3. maxlogmembers 5
4. maxdatafiles 20
5. maxloghistory 200
6. maxinstances 5
7. logfile
8. group 1 'D:\oracle\proct\10.2.0\oradata\mynewdb\redo01.log' size 10m,
9. group 2 'D:\oracle\proct\10.2.0\oradata\mynewdb\redo02.log' size 10m,
10. group 3 'D:\oracle\proct\10.2.0\oradata\mynewdb\redo03.log' size 10m
11. datafile 'D:\oracle\proct\10.2.0\oradata\mynewdb\system01.dbf' size 100m
12. sysaux datafile 'D:\oracle\proct\10.2.0\oradata\mynewdb\sysaux01.dbf' size 50m
13. undo tablespace UNDOTBS1
14. datafile 'D:\oracle\proct\10.2.0\oradata\mynewdb\undo01.dbf' size 40m
15. default temporary tablespace temp
16. tempfile 'D:\oracle\proct\10.2.0\oradata\mynewdb\temp01.dbf' size 20m
17. extent management local uniform size 128k
18. character set ZHS16GBK
19. national character set AL16UTF16
注意:sysaux是创建10g数据库时必须的,创建9i可以不要
UNDOTBS1这个名字不能改成其他的,否则报错
在执行create database 语句的同时,自动执行$ORACLE_HOME\rdbms\admin\sql.bsq脚本,创建SYSTEM表空间和SYSTEM回退段、建立SYS和SYSTEM账号、建立数据字典基础表、建立数据字典索引、创建预定义角色等。
6、创建附加的表空间(未验证)
用create database语句创建的数据库中只有SYSTEM、UNDOTBS和TEMPTBS三个表空间,还需要创建其他
一些额外的表空间
1. SQL>create tablespace users
2. datafile 'd:\oracle\oradata\mynewdb\users01.dbf' size 100M
3. reuse autoextend on next 1280K maxsize unlitited
4. extend management local;
5. SQL>create tablespace index
6. datafile 'd:\oracle\oradata\mynewdb\index01.dbf' size 100M
7. reuse autoextend on next 1280K maxsize unlimited
extend management local;
8、运行脚本创建数据字典视图
执行两个脚本语句:
----用于创建数据字典视图,包括V$动态性能视图和它们的同义词,同时将授予PUBLIC角色对这些同义
词的访问权限
1. SQL>@D:\oracle\proct\10.2.0\db_1\rdbms\admin\catalog.sql;
----用于建立对PL/SQL程序设计的支持
1. SQL>@D:\oracle\proct\10.2.0\db_1\rdbms\admin\catproc.sql;
9、创建服务器初始化参数文件
1. SQL>create spfile from file='d:\oracle\proct\10.2.0\db_1\database\initMYNEWDB.ora';(未验证)
执行该语句将在$ORACLE_HOME\database 目录下创建名为spfileMYNEWDB.ora的服务器初始化参数文件
需要重启数据库
1. SQL>shutdown immediate;
2. SQL>connect sys/mynewdb as sysdba;
SQL>startup ;
最后注意的地方:因为我在创建数据库的时候没有提示我输入sys和system密码,所以下面我们还需要修改sys密码(就当忘设了),方法如下:
sqlplus /nolog;
connect / as sysdba
alter user sys identified by 新密码;
alter user system identified by 新密码;
‘贰’ oracle数据库10g安装步骤
运行解压缩出的 Oracle 10g 安装程序。打开oracle10g的安装目录,找到setup.exe,双击即可进入安装状态
‘叁’ oracle数据库入门教程
oracle是块结构语言,oracle程序划分成几个部分,并在每个部分中写入逻辑代码块,每个块由三个子部分组成。
声明部分:此部分是以关键字DECLARE开头。这是一个可选部分,并定义了程序中要使用的所有变量,游标,子程序和其他元素。
可执行命令部分:此部分包含在关键字BEGIN和END之间,这是一个强制性部分。由程序的可执行oracle语句组成。应该有至少一个可执行代码行,可以只是一个NULL命令,表示不执行任何操作。
异常处理部分 :此部分以关键字EXCEPTION开头。这是一个可选部分,包含处理程序中错误的异常。
每个oracle语句以分号(;)结尾。使用BEGIN和END可以将oracle块嵌套在其他oracle块中。以下是Poracle块的基本结构。
oracle变量的名称由可选的字母,数字,美元($)符号,下划线和数字符号组成,不能超过30个字符。 默认情况下,变量名不区分大小写。不能将保留的oracle关键字用作变量名称。
oracle编程语言允许定义各种类型的变量,如:日期时间数据类型,记录,集合等,我们将在后面的章节中介绍。 在本章中仅学习基本的变量类型。
‘肆’ oracle10g怎么创建数据库
在Oracle中建库,通常有两种方法。一是使用Oracle的建库工具DBCA,这是一个图形界面工具,使用起来方便且很容易理解,因为它的界面友好、美观,而且提示也比较齐全。在Windows系统中,这个工具可以在Oracle程序组中打开(”开始”—“程序”—“ Oracle - OraDb10g_home1”—“ Configuration and Migration Tools”—“ Database Configuration Assistant”),也可以在命令行(”开始”—“运行”—“cmd”)工具中直接输入dbca来打开。另一种方法就是手工建库,下面我会一一举例说明。
‘伍’ Oracle数据库基础教程的目录
第1章Oracle10g简介1
1.1Oracle10g产品概述1
1.2Oracle10g数据库系统的体系结构1
1.2.1Oracle10g体系结构概述1
1.2.2网格结构2
1.2.3数据库逻辑结构3
1.2.4数据库物理结构7
1.2.5数据库例程8
1.2.6内部存储结构8
1.2.7进程结构9
1.2.8应用程序结构11
1.2.9事务13
习题13
第2章安装和卸载Oracle10g数据库15
2.1安装前准备15
2.1.1安装Oracle10g数据库的硬件需求15
2.1.2安装Oracle10g数据库的软件需求15
2.2Oracle10g数据库安装过程16
2.2.1服务器安装过程16
2.2.2客户端安装过程20
2.2.3设置环境变量21
2.2.4常用Oracle服务22
2.3完全卸载Oracle10g23
习题25
第3章Oracle数据库管理工具26
3.1企业管理器26
3.1.1EnterpriseManager10g26
3.1.2OracleEnterpriseManager30
3.
3.2.1启动
3.2.2设置默认实例和注册表变量31
3.2.3设置操作系统数据库管理员和操作员32
3.2.4Oracle数据库管理32
3.3网络配置工具33
3.3.1OracleNet简介33
3.3.2NetManager34
3.3.3NetConfigurationAssistant36
3.4SQL*Plus和iSQL*Plus38
3.4.1使用SQL*Plus38
3.4.2使用iSQL*Plus41
习题43
第4章数据库管理、配置和维护44
4.1关闭和启动数据库44
4.1.1Oracle数据库实例的状态44
4.1.2关闭数据库实例44
4.1.3启动数据库实例47
4.1.4改变数据库的状态49
4.2创建和删除数据库49
4.2.1创建数据库49
4.2.2删除数据库56
4.3配置数据库57
4.3.1查看和设置内存参数57
4.3.2还原管理59
4.3.3初始化参数管理60
4.4用户管理63
4.4.1Oracle数据库用户类型63
4.4.2默认数据库管理员用户64
4.4.3数据库管理员(DBA)的权限64
习题65
第5章数据库存储管理67
5.1表空间管理67
5.1.1查看表空间信息67
5.1.2创建表空间68
5.1.3设置和修改表空间属性70
5.1.4删除表空间72
5.1.5段和数据块管理72
5.1.6撤销表空间73
5.2控制文件管理74
5.2.1创建控制文件74
5.2.2恢复控制文件76
5.2.3删除控制文件76
5.2.4查看控制文件信息76
5.3重做日志管理77
5.3.1重做日志的基本概念77
5.3.2查看重做日志信息78
5.3.3创建重做日志组和成员80
5.3.4重命名重做日志成员81
5.3.5删除重做日志组和成员81
5.3.6清空重做日志文件82
5.4归档日志管理82
5.4.1归档日志文件和归档模式82
5.4.2管理归档模式83
5.4.3指定归档目的地84
5.4.4查看归档日志信息84
习题86
第6章数据库安全管理87
6.1Oracle认证方法87
6.1.1操作系统身份认证87
6.1.2网络身份认证87
6.1.3Oracle数据库身份认证87
6.1.4数据库管理员认证88
6.2用户管理90
6.2.1创建用户90
6.2.2修改用户92
6.2.3权限管理语句93
6.2.4删除用户94
6.3角色管理95
6.3.1Oracle系统角色95
6.3.2创建角色96
6.3.3对角色授权98
6.3.4指定用户的角色99
6.3.5修改角色99
6.3.6删除角色99
习题99
第7章数据库对象管理101
7.1表管理101
7.1.1创建表101
7.1.2修改表105
7.1.3删除表106
7.1.4插入数据107
7.1.5修改数据108
7.1.6删除数据108
7.2数据查询108
7.2.1SELECT语句的基本应用108
7.2.2定义显示标题110
7.2.3设置查询条件110
7.2.4对查询结果排序111
7.2.5使用统计函数112
7.2.6连接查询113
7.3视图管理114
7.3.1视图的基本概念114
7.3.2视图管理页面114
7.3.3创建视图115
7.3.4修改视图116
7.3.5删除视图116
7.4索引管理117
7.4.1索引的概念117
7.4.2索引管理页面118
7.4.3创建索引118
7.4.4修改索引120
7.4.5删除索引120
7.5序列管理120
7.5.1创建序列121
7.5.2修改序列122
7.5.3删除序列123
7.5.4序列的使用123
习题124
第8章备份和恢复125
8.1使用EM进行备份和恢复125
8.1.1使用EM备份数据库125
8.1.2使用EM恢复数据库132
8.2RMAN技术136
8.2.1基本概念136
8.2.2将数据库设置为归档日志模式137
8.2.3创建恢复目录所使用的表空间138
8.2.4创建RMAN用户并授权138
8.2.5创建恢复目录139
8.2.6注册目标数据库139
8.2.7RMAN备份和恢复139
8.3闪回(Flashback)技术142
8.3.1闪回技术概述142
8.3.2闪回数据库143
8.3.3闪回表146
8.3.4闪回回收站147
8.3.5闪回查询(FlashbackQuery)149
8.3.6闪回版本查询149
8.3.7闪回事务查询150
习题151
第9章PL/SQL语言基础152
9.1PL/SQL简介152
9.1.1PL/SQL语言的结构152
9.1.2PL/SQL示例程序152
9.2PL/SQL组件153
9.2.1声明部分153
9.2.2执行部分154
9.2.3异常处理部分158
9.3常用函数160
9.3.1数值型函数161
9.3.2字符型函数162
9.3.3日期型函数163
9.3.4统计函数164
习题164
第10章游标、存储过程和触发器166
10.1游标166
10.1.1游标的基本概念166
10.1.2游标控制语句167
10.1.3游标属性169
10.1.4游标FOR循环171
10.2存储过程管理174
10.2.1过程174
10.2.2函数176
10.2.3程序包179
10.3触发器管理182
10.3.1触发器的基本概念182
10.3.2创建及使用触发器182
习题184
第11章ADO数据访问技术185
11.1ADO数据模型185
11.2数据库访问控件186
11.2.1ADOData控件187
11.2.2DataList控件和DataCombo控件189
11.2.3DataGrid控件192
11.3常用ADO对象195
11.3.1Connection对象195
11.3.2Command对象197
11.3.3Recordset对象198
11.3.4Field对象200
习题201
第12章图书借阅管理系统203
12.1系统总体设计203
12.1.1系统功能描述203
12.1.2创建数据库用户204
12.1.3数据库表结构设计204
12.2设计工程框架208
12.2.1创建工程208
12.2.2添加模块208
12.2.3添加类模块211
12.3系统主界面和登录模块设计215
12.3.1设计主界面215
12.3.2登录模块设计216
12.4图书分类管理模块设计217
12.4.1使用TreeView控件管理图书分类的方法217
12.4.2设计图书分类信息编辑窗体219
12.4.3设计图书分类信息管理窗体221
12.4.4设计图书分类选择窗体224
12.5图书信息管理模块设计224
12.5.1设计图书信息编辑窗体225
12.5.2设计图书信息管理窗体225
12.5.3设计图书选择窗体228
12.6图书库存管理模块设计230
12.6.1设计图书库存编辑模块231
12.6.2设计图书库存管理模块231
12.6.3设计库存盘点编辑模块232
12.6.4设计库存盘点管理模块232
12.7借阅证件管理模块设计233
12.7.1设计借阅证信息编辑窗体233
12.7.2设计借阅证信息管理窗体235
12.7.3设计图书借阅记录窗体236
12.8图书借阅管理模块设计236
12.8.1设计图书借阅信息编辑窗体237
12.8.2设计图书借阅信息管理窗体238
12.8.3设计图书催还信息管理窗体239
习题240
附录1实验241
实验1数据库管理241
目的和要求241
实验准备241
实验内容241
1.使用SHUTDOWN命令关闭数据库实例241
2.使用STARTUP命令启动数据库实例242
3.使用OracleEnterpriseManager关闭数据库实例242
4.使用OracleEnterpriseManager启动数据库实例242
5.使用SQL语句创建数据库243
6.使用SQL语句删除数据库243
实验2角色和用户管理244
目的和要求244
实验准备244
实验内容244
1.使用SQL语句创建数据库角色244
2.使用SQL语句为数据库角色授权244
3.使用SQL语句创建数据库用户245
4.使用SQL语句指定用户角色245
实验3表和视图管理245
目的和要求245
实验准备245
实验内容245
1.使用SQL语句创建表246
2.使用SQL语句向表中插入数据246
3.练习使用SQL语句修改表中的数据247
4.练习使用SQL语句删除表中的数据248
5.练习使用SELECT语句查询数据248
6.练习使用SQL语句创建视图248
实验4管理索引和序列249
目的和要求249
实验准备249
实验内容249
1.使用SQL语句创建索引249
2.在创建表的同时创建索引249
3.使用SQL语句创建序列250
4.在插入数据时使用序列250
实验5PL/SQL编程250
目的和要求250
实验准备250
实验内容250
1.使用条件语句251
2.使用分支语句251
3.使用循环语句251
4.使用系统函数251
实验6使用游标、存储过程和触发器251
目的和要求251
实验准备251
实验内容251
1.创建和使用游标252
2.编写和执行自定义过程252
3.编写和执行自定义函数252
4.创建和使用触发器252
大作业1:VB+Oracle学生档案管理系统253
项目1数据库结构设计253
项目2设计工程框架256
项目3系统主界面和登录模块设计259
项目4院系管理模块设计260
项目5学生信息管理模块设计265
项目6学生奖惩管理模块设计271
项目7学籍变动管理模块设计272
项目8用户管理模块设计275
大作业2:ASP+Oracle网上购物系统279
项目1数据库结构设计279
项目2目录结构与通用模块282
项目3管理主界面与登录程序设计284
项目4公告信息管理模块设计287
项目5商品类别管理模块设计293
项目6商品管理模块设计296
项目7订单管理模块设计302
项目8系统主界面与登录程序设计305
项目9设计商品查询及购买模块306
附录2下载Oracle10g315
附录3Oracle10g系统权限318
参考文献322
……
‘陆’ Oracle数据库基础教程的内容简介
Oracle数据库管理和应用系统开发已经成为国内外高校计算机专业和许多非计算机专业的必修或选修课程。
《Oracle数据库基础教程》结合大量的实例,介绍如何利用Oracle10g来管理和维护数据,以及使用VisualBasic和ASP等开发工具开发C/S(Client/Server)模式和B/S(Browser/Server)模式网络数据库应用程序。
《Oracle数据库基础教程》可作为大学本科相关课程教材,也可供广大Oracle数据库管理员和数据库应用程序开发人员参考。
‘柒’ oracle怎么学习
Oracle是目前最流行的数据库之一。功能强大,性能卓越。
oracle完全可以代表数据库技术的最高水平,因此学习oracle需要你具备一定基础:
1.学习过一门编程语言(java,c,c++均可)。
2.最好学习过一门别的数据库(sql server,mysql,access)。
严禁没有任何基础的同志学习oracle,那样你会浪费时间,同时还打击学习oracle的信心,我个人认为学习流程为:
第一阶段:计算机基础(了解它的基本原理)。
第二阶段:学习一门编程语言(java或者c,c++)。
第三阶段:学习oracle数据库或是别的数据库。
成为一个oracle高手的秘诀就是:
理解小的知识点->做小练习->把小的知识点连成线(知识线)->做oracle项目->把知识线形成知识面->深刻理解
基础部分:
Oracle基本使用
Oracle用户管理
Oracle表管理
高级部分:
Oracle表的查询
Oracle的函数
Oracle数据库管理
Oracle的权限、角色
Pl/sql编程
索引,约束和事务