2009年9月22日星期二
2009年7月3日星期五
oracle_sid , service_name , db_name,instance_name
数据库名:db_name 数据库实例名:instance_name
操作系统环境变量:oracle_sid 数据库服务名:service_names
数据库域名:db_domain 全局数据库名:global_db_name
在oracle7、oracle8数据库中只有数据库名以及实例名,在oracle8i、oracle9i中出现了数据库域名、服务名以及全局数据库名。
数据库名(db_name):用于区分一个数据的内部标识,是oracle的内部标记,是以二进制方式存储于数据库控制文件的参数。
数据库名的作用:数据库名是数据库的内部管理标记,在安装数据库、创建新的的数据库、创建数据库控制文件、修改数据库结构、使用数据库备份与恢复工具进行数据库备份时都需要使用数据名。
数据库安装完成后,数据库名称存储在参数文件(pfile,spfile)中,同时以二进制方式存储在控制文件中,两者必须匹配。如果两者不匹配,数据库在启动时提示ORA-01103号错误。
■ 对数据名称的查询:
1、查询参数文件 db_name的数值
2、select name from v$database
3、SQL>show parameter db_name
■ 修改数据库名(修改复杂,建议不要修改)
1、修改参数文件的数据库名称。
2.重建数据库的控制文件。
数据库实例名(instance_name):用于和操作系统之间的联系。
操作系统与数据库之间的交互则必须使用数据库实例名。数据库安装完成后,数据库实例名称存储在参数文件中,同时存储在注册表中。
数据库名与实例名一般是一一对应的关系,即:有一个数据库名就有一个实例名,而在oracle9i的并行服务器结构中是一对多的关系,即:一个数据库对应多个实例。
■ 对数据名称的查询:
1、查询参数文件 instance_name的数值
2、select instance_name from v$instance
3、SQL>show parameter instance_name
操作系统环境变量(oracle_sid):用于与数据库实例名相对应。instance_name是oracle数据库参数-oracle_sid是操做系统环境变量,即在操作系统要得到实例名必须通过操做系统环境变量oracle_sid,oracle_sid与 instance_name必须相同。
是数据库和操作系统的接口,由操作系统使用,是操作系统区分多个数据库的依据。oracle_sid存储在注册表中。如果数据库的oracle_sid与实际的instance_name不同,在操作系统下运行的oracle所有命令将产生错误。
■ 对数据实例名的定义:
SQL>set oracle_sid=数据库实例名
数据库域名(db_domain):在数据库名称后增加域名构成,使得数据库的取名在整个网络环境中惟一,主要用于oralce分布式环境中数据的远程复制。数据库域名存储在参数文件中。
以下情况要考虑使用数据库域名:1、在oracle分布式环境下,两个数据库之间要通过数据链路进行数据的远程传输。2、在同一网络环境下,两个数据库名相同。
■ 对数据库域名的查询:
1、查询参数文件 db_domain的数值
2、select value from v$parameter where name='db_domain'
3、SQL>show parameter db_domain
■ 修改数据库域名:
1、关闭数据库
2、修改数据库参数文件中的db_domain、service_names。
数据库服务名service_names:数据库名+数据库域名,意义与全局数据库名相同。
数据库服务名存储在参数文件中。
■ 对数据库服务名的查询:
1、查询参数文件 service_names的数值
2、select value from v$parameter where name='service_names'
3、SQL>show parameter service_names
全局数据库名global_db_name:数据库名+数据库域名。
数据库实例名、服务名与网络连接
ORACLE服务器版本 客户端网络驱动
ORACLE7 (支持实例名) SQL_NET(支持实例名)
ORACLE8 (支持实例名) NET8 (支持实例名)
ORACLE8i
(支持实例名、服务名) NET8i (支持实例名、服务名)
ORACLE9i
(支持实例名、服务名) ORACLE NET SERVICE
(支持实例名、服务名)
对于网络连接字符串使用实例名、服务名的问题,需要根据客户端驱动的版本和oracle服务器的版本共同确定,即两者都支持实例名和服务名的使用服务名,否则使用实例名。
2009年6月25日星期四
linux添加用户
要在系统上添加用户:
使用 useradd 命令来创建一个锁定的用户账号: 中
useradd <username>
使用 passwd 命令,通过指派口令和口令老化规则来给某账号开锁:
passwd <username>
useradd 的命令行选项在表 25-1中被列出。
-c comment 用户的注释。
-d home-dir 用来取代默认的 /home/ username 主目录。
-e date 禁用账号的日期,格式为:YYYY-MM-DD
-f days 口令过期后,账号禁用前的天数(若指定了 0 ,账号在口令过期后会被立刻禁用。若指定了 -1 ,口令过期后,账号将不会被禁用)。
-g group-name 用户默认组群的组群名或组群号码(该组群在指定前必须存在)。
-G group-list 用户是其中成员的额外组群名或组群号码(默认以外的)列表,用逗号分隔(组群在指定前必须存在)。
-m 若主目录不存在则创建它。
-M 不要创建主目录。
-n 不要为用户创建用户私人组群。
-r 创建一个 UID 小于 500 的不带主目录的系统账号。
-p password 使用 crypt 加密的口令。
-s 用户的登录 shell,默认为 /bin/bash 。
-u uid 用户的 UID,它必须是独特的,且大于 499。
表 25-1. useradd 命令行选项
添加组群
要给系统添加组群,使用 groupadd 命令:
groupadd <group-name>
groupadd 的命令行选择在表 25-2中被列出。
-g gid 组群的 GID,它必须是独特的,且大于 499。
-r 创建小于 500 的系统组群。
-f 若组群已存在,退出并显示错误(组群不会被改变)。如果指定了 -g 和 -f 选项,而组群已存在, -g 选项就会被忽略。
表 25-2. groupadd 命令行选项
口令老化
为安全起见,要求用户定期改变他们的口令是明智之举。这可以在 用户管理器 的 「口令信息」 标签上添加或编辑用户时做到。
要从 shell 提示下为用户配置口令过期,使用 chage 命令,随后使用表 25-3中的选项,以及用户的用户名。
重要:要使用 chage 命令,屏蔽口令一定要被启用。
-m days 指定用户必须改变口令所间隔的最少天数。如果值为 0,,口令就不会过期。
-M days 指定口令有效的最多天数。当该选项指定的天数加上 -d 选项指定的天数小于当前的日期,用户在使用该账号前就必须改变口令。
-d days 指定自从 1970 年 1 月 1 日起,口令被改变的天数。
-I days 指定口令过期后,账号被锁前不活跃的天数。如果值为 0,账号在口令过期后就不会被锁。
-E date 指定账号被锁的日期,日期格式为 YYYY-MM-DD。若不用日期,也可以使用自 1970 年1月1日后经过的天数。
-W days 指定口令过期前要警告用户的天数。
2009年5月19日星期二
Sorting Multilingual Data
Oracle9i之前,中文是按照二进制编码进行排序的。在oracle9i中新增了按照拼音、部首、笔画排序功能。
1、设置NLS_SORT参数值
SCHINESE_RADICAL_M 按照部首(第一顺序)、笔划(第二顺序)排序
SCHINESE_STROKE_M 按照笔划(第一顺序)、部首(第二顺序)排序
SCHINESE_PINYIN_M 按照拼音排序
2、Session级别的设置,修改ORACLE字段的默认排序方式:
按拼音:alter session set nls_sort = SCHINESE_PINYIN_M;
按笔画:alter session set nls_sort = SCHINESE_STROKE_M;
按偏旁:alter session set nls_sort = NLS_SORT=SCHINESE_RADICAL_M;
3、语句级别设置排序方式:
按照笔划排序
select * from dept order by nlssort(name,'NLS_SORT=SCHINESE_STROKE_M');
按照部首排序
select * from dept order by nlssort(name,'NLS_SORT=SCHINESE_RADICAL_M');
按照拼音排序,此为系统的默认排序方式
select * from dept order by nlssort(name,'NLS_SORT=SCHINESE_PINYIN_M');
4、修改系统参数(数据库所在操作系统):
set NLS_SORT=SCHINESE_RADICAL_M ;export NLS_SORT (sh)
setenv NLS_SORT SCHINESE_RADICAL_M (csh)
HKLC\SOFTWARE\ORACLE\home0\NLS_SORT (win注册表)
Oracle 官方说明
NLS_SORT NLS_SORT specifies the collating sequence for ORDER BY queries. NLS_COMP NLS_COMP specifies the collation behavior of the database session.
Property
Description
Parameter type
String
Syntax
NLS_SORT = { BINARY | linguistic_definition }
Default value
Derived from NLS_LANGUAGE
Modifiable
ALTER SESSION
Range of values
BINARY or any valid linguistic definition name
- If the value is BINARY, then the collating sequence for ORDER BY queries is based on the numeric value of characters (a binary sort that requires less system overhead).
-
If the value is a named linguistic sort, sorting is based on the order of the defined linguistic sort. Most (but not all) languages supported by the NLS_LANGUAGE parameter also support a linguistic sort with the same name.
Note:
Setting NLS_SORT to anything other than BINARY causes a sort to use a full table scan, regardless of the path chosen by the optimizer. BINARY is the exception because indexes are built according to a binary order of keys. Thus the optimizer can use an index to satisfy the ORDER BY clause when NLS_SORT is set to BINARY. If NLS_SORT is set to any linguistic sort, the optimizer must include a full table scan and a full sort in the execution plan.
You must use the NLS_SORT operator with comparison operations if you want the linguistic sort behavior.
Property
Description
Parameter type
String
Syntax
NLS_COMP = { BINARY | LINGUISTIC | ANSI }
Default value
BINARY
Modifiable
ALTER SESSION
Basic
No
Values:
- BINARY
Normally, comparisons in the WHERE clause and in PL/SQL blocks is binary unless you specify the NLSSORT function.
- LINGUISTIC
Comparisons for all SQL operations in the WHERE clause and in PL/SQL blocks should use the linguistic sort specified in the NLS_SORT parameter. To improve the performance, you can also define a linguistic index on the column for which you want linguistic comparisons.
- ANSI
A setting of ANSI is for backwards compatibility; in general, you should set NLS_COMP to LINGUISTIC