数据库对象日常操作

1.用户

1.1基本语句

SYS用户执行:

  

--查看所有用户信息

select * from dba_users;

Select username,password,account_status,default_tablespace,temporary_tablespace,profile from dba_users;

--查询数据库dcs_sys用户下的所有对象

select * from all_objects where owner='DCS_SYS';

select owner,object_name,object_type,status from all_objects where owner='DCS_SYS';

-- 创建用户

create user test01 identified by test01;  #默认是user表空间

-- 授权

grant connect,resource to test01;

-- 撤销权限

revoke connect from test01;

-- 修改密码 

alter user test01 identified by 123456; 

--解锁用户

alter user test account unlock;

-- 删除用户,加上cascade则将用户连同其创建的东西全部删除

drop user test01 cascade;

--当前登录用户执行
select * from all_users;  查看你能管理的所有用户!
select * from user_users; 查看当前用户信息 !

1.2用户权限

1) 系统权限–对用户而言

connect:拥有Connect权限的用户只可以登录Oracle,不可以创建实体,不可以创建数据库结构。

resource:RESOURCE:拥有Resource权限的用户只可以创建实体,不可以创建数据库结构。

dba:拥有全部特权,是系统最高权限,只有DBA才可以创建数据库结构。

2) 实体权限 –针对表或视图而言的

select, update, insert, alter, index, delete, all //all包括所有权限,execute //执行存储过程权限

1.查询用户拥有的系统权限

SQL> SELECT GRANTEE,PRIVILEGE FROM DBA_SYS_PRIVS WHERE GRANTEE = 'SCOTT';dba权限)

2.查询用户拥有的对象权限

SQL> SELECT GRANTEE,TABLE_NAME,PRIVILEGE FROM DBA_TAB_PRIVS WHERE GRANTEE = 'SCOTT';dba权限)

3.查询用户拥有的角色

SQL> SELECT GRANTEE,GRANTED_ROLE FROM DBA_ROLE_PRIVS WHERE GRANTEE ='SCOTT';dba权限)

4.查看用户角色

SELECT * FROM USER_ROLE_PRIVS;

5.查看当前用户权限:

select * from session_privs;

6.查看所有用户所拥有的角色

SELECT * FROM DBA_ROLE_PRIVS;dba权限)

7.查看所有角色

select * from dba_roles;dba权限)

1.3用户会话

1、查询用户会话信息:
SQL> select username, sid, serial#, machine from v$session;

SQL> select * from v$session;

STATUS:这列用来判断session状态是:

  Achtive:正执行SQL语句(waiting for/using a resource)

  Inactive:等待操作(即等待需要执行的SQL语句)

  Killed:被标注为删除


2、删除用户会话信息:
SQL> Alter system kill session 'sid, serial#';

ORACLE数据库杀掉会话进程有三种方式:

1ALTER SYSTEM KILL SESSION

关于KILL SESSION Clause ,如下官方文档描述所示,alter system kill session实际上不是真正的杀死会话,它只是将会话标记为终止。等待PMON进程来清除会话。

可以使用ALTER SYSTEM KILL SESSION 'sid,serial#' IMMEDIATE 来快速回滚事物、释放会话的相关锁、立即返回当前会话的控制权。

2ALTER SYSTEM DISCONNECT SESSION

ALTER SYSTEM DISCONNECT SESSION 杀掉专用服务器(DEDICATED SERVER)或共享服务器的连接会话,它等价于从操作系统杀掉进程。它有两个选项POST_TRANSACTIONIMMEDIATE, 其中POST_TRANSACTION表示等待事务完成后断开会话,IMMEDIATE表示中断会话,立即回滚事务。

SQL> ALTER SYSTEM DISCONNECT SESSION 'sid,serial#' POST_TRANSACTION;

SQL> ALTER SYSTEM DISCONNECT SESSION 'sid,serial#' IMMEDIATE;

3KILL -9 SPID Linux) 或 orakill ORACLE_SID spid (Windows

可以使用下面SQL语句找到对应的操作系统进程SPID,然后杀掉。当然杀掉操作系统进程是一件危险的事情,尤其不要误杀。所以在执行前,一定要谨慎确认。

SELECT s.inst_id,

       s.sid,

       s.serial#,

       p.spid,

       s.username,

       s.program

FROM   gv$session s

       JOIN gv$process p ON p.addr = s.paddr AND p.inst_id = s.inst_id

WHERE  s.type != 'BACKGROUND';

2. 

-- 查询当前用户下有哪些表
SELECT * FROM user_tables

-- 查询你当前用户下可以访问哪些表

SELECT * FROM all_tables

-- 查询当前数据库所有的表, 需要你有 DBA 的权限
SELECT * FROM dba_tables

 

2.1表结构操作

1、创建表

     create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)

     根据已有的表创建新表:

     Aselect * into table_new from table_old (使用旧表创建新表)

     Bcreate table tab_new as select col1,col2… from tab_old definition only<仅适用于Oracle>

2、删除表

     drop table tabname

3、重命名表

     说明:alter table 表名 rename to 新表名

        egalter table tablename rename to newtablename

4、增加字段

     说明:alter table 表名 add (字段名 字段类型 默认值 是否为空);

        例:alter table tablename add (ID int);

       egalter table tablename add (ID varchar2(30) default '' not null);

5、修改字段(不能有数据)

     说明:alter table 表名 modify (字段名 字段类型 默认值 是否为空);

        egalter table tablename modify (ID number(4));

6、重命名字段(不能有数据)

     说明:alter table 表名 rename column 列名 to 新列名 (其中:column是关键字)

        egalter table tablename rename column ID to newID;

7、删除字段

     说明:alter table 表名 drop column 字段名;

        egalter table tablename drop column ID;

8、添加主键

     alter table tabname add primary key(col)

9、删除主键

     alter table tabname drop primary key(col)

10、创建索引

     create [unique] index idxname on tabname(col….)

11、删除索引

     drop index idxname

     注:索引是不可更改的,想更改必须删除重新建。

12、创建视图

     create view viewname as select statement

13、删除视图

     drop view viewname

2.2表数据操作

1、数据查询

     select <列名> from <表名> [where <查询条件表达试>] [order by <排序的列名>[ascdesc]]

2、插入数据

     insert into 表名 values(所有列的值);

     insert into test values(1,'zhangsan',20);

     insert into 表名() values(对应的值);

     insert into test(id,name) values(2,'lisi');

插入空值

insert into student (xh,xm,sex,birthday) values(‘021’,’BLYK’,’’,null);

 

3、更新数据

     update  set =新的值 [where 条件] -->更新满足条件的记录

     update test set name='zhangsan2' where name='zhangsan'

     update  set =新的值 -->更新所有的数据

     update test set age =20;

4、删除数据

  • delete from 表名 where 条件 -->删除满足条件的记录

     delete from test where id = 1;

     delete from test -->删除所有

     commit; -->提交数据

     rollback; -->回滚数据

     delete方式可以恢复删除的数据,但是提交了,就没办法了 delete删除的时候,会记录日志 -->删除会很慢很慢

  • truncate table 表名

     删除所有数据,不会影响表结构,不会记录日志,数据不能恢复 -->删除很快

  • drop table 表名

     删除所有数据,包括表结构一并删除,不会记录日志,数据不能恢复-->删除很快

2.3表结构/数据复制

  • 表数据复制able2已经存在,表结构和table1一样

     insert into table1 (select * from table2);

  • 存在一个表B和表A的表结构不一致,将A中的数据复制给B

insert into B (x1,x2,x3...) select x1,x2,x3... from A;

  • 复制表结构(只复制表结构,不复制其他表对象,如主外键等)

     create table table1 select * from table2 where 1>1;

  • 复制表结构,如果目标表table1不存在,使用下面语句

create table table1 as select * from table2 where 1>1;

  • 复制表结构和数据(只复制表结构和数据,不复制其他表对象,如主外键等)

     create table table1 select * from table2;

  • 复制表结构和数据,如果目标表table1不存在,使用下面语句

create table table1 as select * from table2

  • 复制指定字段

     create table table1 as select id, name from table2 where 1>1;

3. index索引

3.1查询/创建索引

--查看该表的所有索引

select * from user_indexes where table_name = 'TS_GATE'

--查看该表的所有索引列

select * from user_ind_columns where table_name= 'TS_GATE';

1.创建索引语法

CREATE [UNIQUE] | [BITMAP] INDEX index_name  --unique表示唯一索引ON table_name([column1 [ASC|DESC],column2    --bitmap,创建位图索引

[ASC|DESC],…] | [express])

[TABLESPACE tablespace_name]

[PCTFREE n1]                                 --指定索引在数据块中空闲空间

[STORAGE (INITIAL n2)]

[NOLOGGING]                                  --表示创建和重建索引时允许对表做DML操作,默认情况下不应该使用

[NOLINE]

[NOSORT];                                    --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用

如果不加创建索引的类型,默认是创建B树索引

2.修改索引

1)重命名索引

alter index index_sno rename to bitmap_index;

2)合并索引(表使用一段时间后在索引中会产生碎片,此时索引效率会降低,可以选择重建索引或者合并索引,合并索引方式更好些,无需额外存储空间,代价较低)

alter index index_sno coalesce;

3)重建索引

  方式一:删除原来的索引,重新建立索引

  方式二:alter index index_sno rebuild;

3.删除索引

drop index index_sno;

4.查看索引

select index_name,index-type, tablespace_name, uniqueness from all_indexes where table_name ='tablename';

 

 -- eg:    create index index_sno on student('name');select * from all_indexes where table_name='student';

3.2重建索引

一、重建索引的前提

1、表上频繁发生update,delete操作;
2、表上发生了alter table ..move操作(move操作导致了rowid变化)

二、重建索引的方式

、直接重建:

举例:

alter index indexname rebuild; 或alter index indexname rebuild online;

说明:此方式比较快,可以在24*7环境中实现,建议使用此方式。

2drop 原来的索引,然后再创建索引;

举例:
删除索引:drop index IX_PM_USERGROUP;
创建索引:create index IX_PM_USERGROUP on T_PM_USER (fgroupid);

说明:此方式耗时间,无法在24*7环境中实现,不建议使用。

注意点:

1、 执行rebuild操作时,需要检查表空间是否足够;
2、虽然说rebuild online操作允许dml操作,但是还是建议在业务不繁忙时间段进行;

Rebuild操作会产生大量redo log ;

4. Sequence序列

4.1定义

Oracle数据库中,序列(SEQUENCE)其实是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字)。其主要的用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值。

创建序列需要CREATE SEQUENCE系统权限。

序列的创建语法如下:

CREATE SEQUENCE 序列名 [INCREMENT BY n] [START WITH n] [{MAXVALUE/ MINVALUE n|NOMAXVALUE}] [] [{CACHE n|NOCACHE}];

参数说明如下:
INCREMENT BY 用于定义序列的步长,如果省略,则默认为1,如果出现负值,则代表序列的值是按照此步长递减的。

START WITH 定义序列的初始值(即产生的第一个值),默认为1。

MAXVALUE 定义序列生成器能产生的最大值。选项NOMAXVALUE是默认选项,代表没有最大值定义,这时对于递增序列,系统能够产生的最大值是10的27次方;对于递减序列,最大值是-1。

MINVALUE定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是?10的26次方;对于递增序列,最小值是1。

CYCLE和NOCYCLE 表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到最大值时,循环到最小值;对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。

CACHE(缓冲)定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。

4.2 查询/创建使用

--查询用户下的所有序列

select * from user_squences

1、Create Sequence

    首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限。

    创建语句如下:

CREATE SEQUENCE seqTest

INCREMENT BY 1 -- 每次加几个

START WITH 1 -- 从1开始计数

NOMAXvalue -- 不设置最大值

NOCYCLE -- 一直累加,不循环

CACHE 10; --设置缓存cache个序列,如果系统down掉了或者其它情况将会导致序列不连续,也可以设置为---------NOCACHE

2、得到Sequence值

定义好sequence后,你就可以用currVal,nextVal取得值。

    CurrVal:返回 sequence的当前值

    NextVal:增加sequence的值,然后返回 增加后sequence值

  得到值语句如下:

SELECT Sequence名称.CurrVal FROM DUAL;

  如得到上边创建Sequence值的语句为:

select seqtest.currval from dual

Sql语句中可以使用sequence的地方:

    - 不包含子查询、snapshot、VIEW的 SELECT 语句

    - INSERT语句的子查询中

    - INSERT语句的values中

    - UPDATE 的 SET中

如在插入语句中

 insert into 表名(id,name)values(seqtest.Nextval,'sequence 插入测试');

 注:

    - 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。

      CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。

       一次NEXTVAL会增加一次 SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。

    - 如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组 到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。

3、Alter Sequence

    拥有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence 再 re-create。

 例:

alter sequence SEQTEST maxvalue 9999999;

    另: SEQUENCE_CACHE_ENTRIES参数,设置能同时被cache的sequence数目。

 4、Drop Sequence

DROP SEQUENCE seqTest;

 5、一个例子

 复制代码

create sequence SEQ_ID

minvalue 1

maxvalue 99999999

start with 1

increment by 1

nocache

order;

建解发器代码为:

create or replace trigger tri_test_id

  before insert on S_Depart   --S_Depart 是表名

  for each row

declare

  nextid number;

begin

  IF :new.DepartId IS NULLor :new.DepartId=0 THEN --DepartId是列名

    select SEQ_ID.nextval --SEQ_ID正是刚才创建的

    into nextid

    from sys.dual;

    :new.DepartId:=nextid;

  end if;

end tri_test_id;

猜你喜欢

转载自www.cnblogs.com/lisonglin/p/10136861.html