()SQL*PLUS编程用户的规范
·存储结构的规范
考虑到用SQL*PLUS编程可实现各行各业各公司各部门多种多样的应用需求我们的SQL*PLUS编程用户也应该朝这个方向规范:不同种类的应用必须有不同的用户;不同种类的应用必须有不同的存储位置包括物理文件缺省表空间临时表空间的创建和规划:当准备编写某一较大规模(从ORACLE数据量和面向用户量考虑)应用程序时首先应该创建一个逻辑的存储位置表空间同时定义物理文件的存放路径和所占硬盘的大小
①物理文件缺省的存放路径在/oracle_home/dbs下在命令行下用UNIX指令df k 可查看硬盘资源分区的使用情况如果oracle_home使用率达‰以上而且有一个或多个较为空闲的硬盘资源分区可以利用我们最好把物理文件缺省的存放路径改到较为空闲的硬盘资源分区路径下在此路径下我们可以这样规划资源物理文件的存储:
xxx表空间
xxx行业/ xxx公司/ xxx 部门/ xxx 服务dbf
DEMO表空间
default_datafile_home/col /elec/sys/demodbf
default_datafile_home/col /elec/sys/demodbf
公司系统四部摹拟演示系统物理文件
HUMAN表空间
default_datafile_home/col/elec/human/humandbf
公司人事部人事管理系统物理文件
BOOK表空间
default_datafile_home/col/elec/book/bookdbf
公司资料室图书管理系统物理文件
QUESTION表空间
default_datafile_home/col/elec/client/questiondbf
公司客户服务部问题库系统物理文件
PC表空间
default_datafile_home/col/chaoxun/client/pcdbf
公司PC机售后服务系统物理文件
……表空间
default_datafile_home/……………………………
等等
说明:其中default_datafile_home指oracle_home/dbs;
default_datafile_home指较为空闲的硬盘资源分区路径
②物理文件的大小根据应用系统的数据量数据对象程序包的多少来定一般用于摹拟演示的小系统表空间初始的物理文件为M即能满足要求如果信息量满还可以增加物理文件扩充表空间(每次扩充大小也可暂定为M);一般实际运行的应用系统可适当增加表空间初始的物理文件大小但也不要一次分配太大(因为不易回收空间却易扩充空间)这也需要根据具体情况具体分析:信息量大需长时间保存的应用在条件允许情况下表空间可以大到几百M甚至上G;信息量小短期经常刷新的应用表空间可以控制在M以下
③表空间的名称应该采用同系统应用相似的英文字符或字符缩写表空间所对应的一个或多个物理文件名也应有相关性不同用户所处的缺省表空间不同存储的信息就不能互相访问这比把所有用户信息都储存在系统表空间安全性大大提高了如果用ORACLE WEB SERVER管理端口创建的用户其缺省和临时表空间一定是系统表空间DBA切记要改变用户的缺省表空间临时表空间存放临时数据段处理一些排序合并等中间操作根据实际应用的需求可以把它们放在专门创建的表空间里;如果系统表空间大也可以把它们放在系统表空间用户创建的数据索引最好和数据文件分开存放在不同表空间以减少数据争用和提高响应速度
·密码和用户名的规范
有相当数量的ORACLE用户名和密码一致这是个很不安全的因素我们建议ORACLE用户名和密码一定不要一样密码最好在五六位字符以上不同用户间不应该使用相同的密码用户名的定义可根据实际应用的英文名来设而依据编程人员的姓名定义的用户名实际上不规范可在日后的工作中结合上述有关存储结构规范的说明逐步改进
()特殊要求用户的规范
在ORACLE数据库使用过程中还会遇到一些有特殊要求的用户:非编程人员需要对某个表有查询增加删除修改的权利DBA应创建一个这样的用户先确定用户名和密码再规定相关应用所在缺省表空间(包含某个表)和临时表空间最后TABLE属主给其授权:赋予CONNECT角色SELECTINSERTDELETEUPDATE ON THE TABLE的对象级权限这可根据实际需求自由取捨
举例:●给新用户授于对象级权限(命令行方式):
假设新用户NEW需要有查询删除修改DCD用户的表EMP
%svrmgrl
SVRMGR>connect internal; 以系统管理员登录
SVRMGR>create user new identified by new default tablespace app;
SVRMGR>connect dcd/dcdpwd; 以dcd用户登录
SVRMGR>grant connect to new;
SVRMGR>grant select on emp to new;
SVRMGR>grant delete on emp to new;
SVRMGR>grant update on emp to new;
说了这么多关于用户的问题那么接下来我们就详细得说一下关于密码文件的使用以及维护在Oracle数据库系统中用户如果要以特权用户身份(INTERNAL/SYSDBA/SYSOPER)登录Oracle数据库可以有两种身份验证的方法:即使用与操作系统集成的身份验证或使用Oracle数据库的密码文件进行身份验证因此管理好密码文件对于控制授权用户从远端或本机登录Oracle数据库系统执行数据库管理工作具有重要的意义
Oracle数据库的密码文件存放有超级用户INTERNAL/SYS的口令及其他特权用户的用户名/口令它一般存放在ORACLE_HOME\DATABASE目录下
·密码文件的创建:
在使用Oracle Instance Manager创建一数据库实例的时侯在ORACLE_HOME\DATABASE目录下还自动创建了一个与之对应的密码文件文件名为PWDSIDORA其中SID代表相应的Oracle数据库系统标识符此密码文件是进行初始数据库管理工作的基础在此之后管理员也可以根据需要使用工具ORAPWDEXE手工创建密码文件命令格式如下:
C:\ >ORAPWDFILE=< FILENAME >PASSWORD =< PASSWORD > ENTRIES=< MAX_USERS >
各命令参数的含义为:
FILENAME:密码文件名;
PASSWORD:设置INTERNAL/SYS帐号的口令;
MAX_USERS:密码文件中可以存放的最大用户数对应于允许以SYSDBA/SYSOPER权限登录数据库的最大用户数由于在以后的维护中若用户数超出了此限制则需要重建密码文件所以此参数可以根据需要设置得大一些
有了密码文件之后需要设置初始化参数REMOTE_LOGIN_PASSWORDFILE来控制密码文件的使用状态
·设置初始化参数REMOTE_LOGIN_PASSWORDFILE:
在Oracle数据库实例的初始化参数文件中此参数控制着密码文件的使用及其状态它可以有以下几个选项:
NONE:指示Oracle系统不使用密码文件特权用户的登录通过操作系统进行身份验证;
EXCLUSIVE:指示只有一个数据库实例可以使用此密码文件只有在此设置下的密码文件可以包含有除INTERNAL/SYS以外的用户信息即允许将系统权限SYSOPER/SYSDBA授予除INTERNAL/SYS以外的其他用户
SHARED:指示可有多个数据库实例可以使用此密码文件在此设置下只有INTERNAL/SYS帐号能被密码文件识别即使文件中存有其他用户的信息也不允许他们以SYSOPER/SYSDBA的权限登录此设置为缺省值
在REMOTE_LOGIN_PASSWORDFILE参数设置为EXCLUSIVESHARED情况下Oracle系统搜索密码文件的次序为:在系统注册库中查找ORA_SID_PWFILE参数值(它为密码文件的全路径名);若未找到则查找ORA_PWFILE参数值;若仍未找到则使用缺省值ORACLE_HOME\DATABASE\PWDSIDORA;其中的SID代表相应的Oracle数据库系统标识符
·向密码文件中增加删除用户:
当初始化参数REMOTE_LOGIN_PASSWORDFILE设置为EXCLUSIVE时系统允许除INTERNAL/SYS以外的其他用户以管理员身份从远端或本机登录到Oracle数据库系统执行数据库管理工作;这些用户名必须存在于密码文件中系统才能识别他们由于不管是在创建数据库实例时自动创建的密码文件还是使用工具ORAPWDEXE手工创建的密码文件都只包含INTERNAL/SYS用户的信息;为此在实际操作中可能需要向密码文件添加或删除其他用户帐号
由于仅被授予SYSOPER/SYSDBA系统权限的用户才存在于密码文件中所以当向某一用户授予或收回SYSOPER/SYSDBA系统权限时他们的帐号也将相应地被加入到密码文件或从密码文件中删除由此向密码文件中增加或删除某一用户实际上也就是对某一用户授予或收回SYSOPER/SYSDBA系统权限
要进行此项授权操作需使用SYSDBA权限(或INTERNAL帐号)连入数据库且初始化参数REMOTE_LOGIN_PASSWORDFILE的设置必须为EXCLUSIVE具体操作步骤如下:
创建相应的密码文件;
设置初始化参数REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE;
使用SYSDBA权限登录: CONNECTSYS/internal_user_passswordASSYSDBA;
启动数据库实例并打开数据库;
创建相应用户帐号对其授权(包括SYSOPER和SYSDBA): 授予权限:GRANTSYSDBATOuser_name;
收回权限:REVOKESYSDBAFROMuser_name;
现在这些用户可以以管理员身份登录数据库系统了;
·使用密码文件登录:
有了密码文件后用户就可以使用密码文件以SYSOPER/SY