oracle基本操作

1.创建表

create table 表名(

列名1 类型,

列名2 类型

);

2.修改类属性

alter table 表名 modify(列名 类型);

3.添加列

alter table 表名 add(列名 类型);

4.添加主键约束和非空约束

alter table 表名 add constraint pk_表名 primary key(列名);

alter table 表名 modify(列名 not null);

5.删除主键约束

alter table 表名 drop primary key;

alter table 表名 drop constraint pk_表名;

6.失效约束

alter table 表名 disable primary key;

alter table 表名 disable constraint pk_表名;

7.有效约束

alter table 表名 enable primary key;

alter table 表名 enable constraint pk_表名;

8.删除列

alter table 表名 drop column 列名;

9.设置某列不可用,然后删除

alter table 表名 set unused(列名);

alter table 表名 drop unused columns;

10.修改表名

rename 表名1 to 表名2

alter 表名1 rename to 表名2;

11.截断表

truncate table 表名;

12.截断表保留行空间

truncate table 表名 resue storage;

13.查看表结构

desc table 表名;

14.删除表

drop table 表名;

15.插入记录

例:insert into 表名 values(内容1,内容2,内容3,内容4);

16.带参数对话方式插入行

例:insert into 表名 values(&列名1,&列名2);

   insert into 表名 values(内容1,内容2);

17.插入某几列记录

insert into 表名(列名1,列名2) values(内容1,内容2);

18.为列插入空值(其列不能为not null)

insert into 表名 values(内容1,null,null);

19.创建表(包括主键及外键设置)方法一

create table 表名(

   列名1 类型

   constraint pk_表名 primary key,

   列名2 类型 not null,

   列名3 类型

   constraint fk_表名 reference 表名(列名),

   列名3 类型

   constraint ck_表名 check(列名3 in(''内容1'',''内容2'',''内容3''))

);

20.查询所有行

select * from 表名;

21.查询某几列

select 列名1,列名2 from 表名;

22.重复行消除

select distict 列名 from 表名;

23.where语句查询

select * from 表名 where 条件 order by 列名;

(注:如number类型查出自动按升序排列,如要按降序排列,则select * from 表名 where 条件 order by 列名 desc;)

24.创建表,方法二

create table 表名(

列名1 类型 primary key,

列名2 类型 not null,

列名3 类型 check(列名3 in('''','''','''')),

列名4 类型 refernce 表名(列名)

);

25.修改 列=‘?’的数据

update 表名 set (列=?) where 列=‘?’;

26.删除行

delete from 表名 where 条件;

27.事务处理

--事务处理

update 表名

set 列名(日期) = ''30-5月-98''

where 条件;

savepoint mark1;

delete from 表名 where 条件;

savepoint mark2;

rollback to savepoint mark1;

rollback;

28.建立用户user1,密码为password

授予用户connect,resource的权限

connect角色用于登录

resource角色用于建表等.

connect system/manager

create user user1 identified by password;

grant connect,resource to password;

29.数据控制语言

connect scott/tiger

30.把对表1查询和修改的权限授予user1

grant select,update on 表1 to user1;

31.把对表表1中列1和列2修改的权限授予user1

grant update(列1,列2) on 表1 to user1;

32.把对表表1查询的权限授予用户user1

并且user1用户还可以把这个权限授予别的用户(with grant option)

grant select on 表1 to user1 with grant option;

33.从用户user1撤销对表1查询和修改的权限

revoke select,update on 表1 from user1;

34.创建表空间语句

create tablespace tableSpaceName datafile filename size **M    online;

例如:

create tablespace photo datafile 'e:/photo.dbf' size 1000M   online;

35. 修改表空间语句

alter database datafile filename resize    **M    online;

例如:

alter database datafile 'e:/photo.dbf' resize    2000M    online;

36. 增加额外的数据文件到表空间

alter tablespace tablespaceName add datafile filename size **M

例如:

alter tablespace photo add datafile 'e:/photo2.dbf' size 2000M

36. 修改表空间名称

ALTER TABLESPACE oldTSName RENAME TO newTSName

37、查看表空间的名称及大小

select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size

from dba_tablespaces t, dba_data_files d

where t.tablespace_name = d.tablespace_name

group by t.tablespace_name;

38、查看表空间物理文件的名称及大小

select tablespace_name, file_id, file_name,

round(bytes/(1024*1024),0) total_space

from dba_data_files

order by tablespace_name;

39、查看回滚段名称及大小

select segment_name, tablespace_name, r.status,

(initial_extent/1024) InitialExtent,(next_extent/1024) NextExtent,

max_extents, v.curext CurExtent

From dba_rollback_segs r, v$rollstat v

Where r.segment_id = v.usn(+)

order by segment_name ;

40、查看控制文件

select name from v$controlfile;

select member from v$logfile;

41、查看表空间的使用情况

select sum(bytes)/(1024*1024) as free_space,tablespace_name

from dba_free_space

group by tablespace_name;

SELECT A.TABLESPACE_NAME,A.BYTES TOTAL,B.BYTES USED, C.BYTES FREE,

(B.BYTES*100)/A.BYTES "% USED",(C.BYTES*100)/A.BYTES "% FREE"

FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_USED B,SYS.SM$TS_FREE C

WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME AND A.TABLESPACE_NAME=C.TABLESPACE_NAME;

42、查看数据库库对象

select owner, object_type, status, count(*) count# from all_objects group by owner, object_type, status;

43、查看数据库的版本 

Select version FROM Product_component_version

Where SUBSTR(PRODUCT,1,6)='Oracle';

44、查看数据库的创建日期和归档方式

Select Created, Log_Mode, Log_Mode From V$Database;

原文地址:https://www.cnblogs.com/jcomet/p/1242537.html