当前位置:  数据库>oracle
本页文章导读:
    ▪oracle权限的分配 - houqijun      一、创建  sys;   //系统管理员,拥有最高权限  system;//本地管理员,次高权限  scott; //普通用户,密码默认为tiger,默认未解锁  二、登陆  sqlplus / as sysdba;  //登陆s.........
    ▪SQL PL/SQL语法手册 - Powerful Man      SQL  PL/SQL语法手册                       目   录 第一部分  SQL语法部分3一、CREAT.........
    ▪Oracle translate 函数 - Little_cheeper      项目里要求对军人身份证特殊处理,只要数字位。本想用正则表达式,但是oracle9i不支持正则。后来发现translate 可以实现功能.translate(string,from_str,to_str)     按字符替换string中的.........

[1]oracle权限的分配 - houqijun
    来源:    发布时间: 2013-10-29

一、创建

  sys;   //系统管理员,拥有最高权限

  system;//本地管理员,次高权限

  scott; //普通用户,密码默认为tiger,默认未解锁

  二、登陆

  sqlplus / as sysdba;  //登陆sys帐户

  sqlplus sys as sysdba;//同上

  sqlplus scott/tiger;  //登陆普通用户scott

  三、管理用户

  create user zhangsan;//在管理员帐户下,创建用户zhangsan

  alert user scott identified by tiger;//修改密码

  四,授予权限

  1、默认的普通用户scott默认未解锁,不能进行那个使用,新建的用户也没有任何权限,必须授予权限

  /*管理员授权*/

  grant create session to zhangsan;    //授予zhangsan用户创建session的权限,即登陆权限

  grant unlimited session to zhangsan;//授予zhangsan用户使用表空间的权限

  grant create table to zhangsan;//授予创建表的权限

  grante drop table to zhangsan; //授予删除表的权限

  grant insert table to zhangsan;//插入表的权限

  grant update table to zhangsan;//修改表的权限

  grant all to public; //这条比较重要,授予所有权限(all)给所有用户(public)

  2、oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的,需要互相授权

  /*oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的*/

  grant select on tablename to zhangsan;//授予zhangsan用户查看指定表的权限

  grant drop on tablename to zhangsan;//授予删除表的权限

  grant insert on tablename to zhangsan;//授予插入的权限

  grant update on tablename to zhangsan;//授予修改表的权限

  grant insert(id) on tablename to zhangsan;

  grant update(id) on tablename to zhangsan;//授予对指定表特定字段的插入和修改权限,注意,只能是insert和update

  grant alert all table to zhangsan;//授予zhangsan用户alert任意表的权限

  五、撤销权限

  基本语法同grant,关键字为revoke

  六、查看权限

  select * from user_sys_privs;//查看当前用户所有权限

  select * from user_tab_privs;//查看所用用户对表的权限

  七、操作表的用户的表

  /*需要在表名前加上用户名,如下*/

  select * from zhangsan.tablename;

  八、权限传递

  即用户A将权限授予B,B可以将操作的权限再授予C,命令如下:

  grant alert table on tablename to zhangsan with admin option;//关键字 with admin option

  grant alert table on tablename to zhangsan with grant option;//关键字 with grant option效果和admin类似

  九、角色

  角色即权限的集合,可以把一个角色授予给用户

  create role myrole;//创建角色

  grant create session to myrole;//将创建session的权限授予myrole

  grant myrole to zhangsan;//授予zhangsan用户myrole的角色

  drop role myrole;删除角色

  /*但是有些权限是不能授予给角色的,比如unlimited tablespace和any关键字*/


本文链接:http://www.cnblogs.com/houqijun/p/3239879.html,转载请注明。


    
[2]SQL PL/SQL语法手册 - Powerful Man
    来源:    发布时间: 2013-10-29

SQL  PL/SQL语法手册

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

目   录

 

第一部分  SQL语法部分3

一、CREATE TABLE 语句3

二、CREATE SEQUENCE语句5

三、CREATE VIEW语句6

四、INSERT语句:7

五、UPDATE语句:9

六、DELETE语句:10

七、TRUNCATE语句:11

八、各类FUNCTIONS:12

1.转换函数:12

2.日期函数16

3.字符函数20

4.数值函数28

5.单行函数:33

6.多行函数35

第二部分  PL/SQL语法部分41

一、PL/SQL语言简介41

二、变量说明48

三、PL/SQL控制程序流52

四、存储过程54

五、存储函数54

六、PACKAGE54

七、触发器56

八、应用实例58

 

 

 

 

 


第一部分  SQL语法部分

 

 

一、 Create table 语句

 

语句:   CREATE TABLE [schema.]table_name

     ( { column datatype [DEFAULT expr] [column_constraint] ...

       | table_constraint}

    [, { column datatype [DEFAULT expr] [column_constraint] ...

       | table_constraint} ]...)

    [ [PCTFREE  integer] [PCTUSED  integer]

      [INITRANS integer] [MAXTRANS integer]

      [TABLESPACE tablespace]

      [STORAGE storage_clause]

      [ RECOVERABLE | UNRECOVERABLE ]

    [  PARALLEL ( [ DEGREE { integer | DEFAULT } ]

                  [ INSTANCES { integer | DEFAULT } ]

                )

     | NOPARALLEL ]

    [  CACHE | NOCACHE  ]

    | [CLUSTER cluster (column [, column]...)] ]

    [ ENABLE   enable_clause

    | DISABLE disable_clause ] ...

[AS subquery]

表是Oracle中最重要的数据库对象,表存储一些相似的数据集合,这些数据描述成若干列或字段.create table 语句的基本形式用来在数据库中创建容纳数据行的表.create table 语句的简单形式接收表名,列名,列数据类型和大小.除了列名和描述外,还可以指定约束条件,存储参数和该表是否是个cluster的一部分.

Schema 用来指定所建表的owner,如不指定则为当前登录的用户.

Table_name 用来指定所创建的表名,最长为30个字符,但不可以数字开头(可为下划线),但不可同其它对象或Oracle的保留字冲突.

   Column 用来指定表中的列名,最多254个.

Datatype 用来指定列中存储什么类型的数据,并保证只有有效的数据才可以输入.

column_constraint 用来指定列约束,如某一列不可为空,则可指定为not null.

table_constraint 用来指定表约束,如表的主键,外键等.

Pctfree 用来指定表中数据增长而在Oracle块中预留的空间. DEFAULT为10%,也就是说该表的每个块只能使用90%,10%给数据行的增大时使用.

Pctused 用来指定一个水平线,当块中使用的空间低于该水平线时才可以向该中加入新数据行.

Parallel 用来指定为加速该表的全表扫描可以使用的并行查询进程个数.

Cache 用来指定该表为最应该缓存在SGA数据库缓冲池中的候选项.

Cluster 用来指定该表所存储的 cluster.

Tablespace 用来指定用数据库的那个分区来存储该表的数据.

Recoverable|Unrecoverable 用来决定是否把对本表数据所作的变动写入Redo 文件.以恢复对数据的操作.

As 当不指定表的各列时,可利用As子句的查询结果来产生数据库结构和数据.

例:

   1) create table mytab1e(mydec decimal,

                       myint inteter)

                 tablespace user_data

                 pctfree   5

                 pctused   30;

   2) create table mytable2

             as ( select * from mytable1);

二、 
create sequence语句

 

语句:  CREATE SEQUENCE [schema.]sequence_name

[INCREMENT BY integer] 

    [START WITH integer]

    [MAXVALUE integer | NOMAXVALUE]

    [MINVALUE integer | NOMINVALUE]

    [CYCLE | NOCYCLE]

    [CACHE integer | NOCACHE]

    [ORDER | NOORDER]

序列用来为表的主键生成唯一的序列值.

Increment by 指定序列值每次增长的值

Start with 指定序列的第一个值

Maxvalue 指定产生的序列的最大值

Minvalue 指定产生的序列的最小值

Cycle 指定当序列值逵到最大或最小值时,该序列是否循环.

Cache 指定序列生成器一次缓存的值的个数

Order 指定序列中的数值是否按访问顺序排序.

例:

    1) create sequence myseq

         increment by 4

         start with 50

         maxvalue 60

         minvalue 50

         cycle 

         cache 3;

2)

   sql> create sequence new_s;

   sql>insert into new (new_id,last_name,first_name)

       values(new_s.nextval,’daur’,’permit’);

 

 

 

 

 

三、 
create view语句 

 


    
[3]Oracle translate 函数 - Little_cheeper
    来源:    发布时间: 2013-10-29

项目里要求对军人身份证特殊处理,只要数字位。本想用正则表达式,但是oracle9i不支持正则。

后来发现translate 可以实现功能.

translate(string,from_str,to_str)     按字符替换string中的值。对一些字符,出现在from_str(要被替换掉字符)中,但是to_str(替换之后的字符)没有对应替换的字符,oracle会自动把这部分字符替换成NULL。

translate(exp,x||exp,x)  这样我们就把exp中字符穿x保留下来,其他的字符系统自动剔除掉了。


本文链接:http://www.cnblogs.com/cheeper/p/3248366.html,转载请注明。


    
最新技术文章:
▪current online redo log缺失后的恢复
▪ORA-600 2662错误解决实例
▪ORA-00600 2662错误解决方法
▪Oracle Hidden Parameter:_allow_resetlogs_corruption
▪Oracle诊断事件列表
▪Oracle 隐含参数 _disable_logging 详解
▪ORA-00600 [2662]错误解决过程
▪Oracle里常见的执行计划
▪Oracle里另外一些典型的执行计划
▪Oracle服务器自动备份
▪Oracle固定SQL的执行计划(一)---SQL Profile
▪Oracle固定SQL的执行计划(二)---SPM
▪同一环境下新建Standby RAC库
▪Oracle快速克隆安装
▪Oracle单实例启动多个实例
▪Oracle的PLSQL别名中文出现乱码解决方法
▪ORA-00379: no free buffers available in buffer pool DEFAULT ...
▪RMAN-06023: no backup or copy of datafile 16 found to restor...
▪RMAN还原数据库报错问题解决案例
▪OEL6.8_X86平台部署Oracle 10gR2检测失败问题
▪Oracle 性能优化建议
▪Oracle SQL语句优化心得
▪Oracle慢SQL监控脚本实现
▪Oracle dblink 查询 tns:无法解析指定的连接标识...
▪Red Hat Enterprise Linux 6使用udev配置Oracle ASM总结...
▪Linux6.6及以上版本配置Oracle ASM共享储存-UDEV
▪Oracle 12C 开启数据库归档模式
▪Solairs系统中配置Oracle 12c 开机启动
▪重建DBMS_STATS解决ORA-31626 ORA-21633以及ORA-04063 ORA...
▪Oracle ASMM 与AMM之间相互切换
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3