版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/wangtongxue123456/article/details/79681846
sys@CNHTM> create user scott identified by tiger; --创建 scott 用户并设置密码 tiger
sys@CNHTM> grant connect,resource to scott; --赋予权限
[USERNAME/PASSWORD][@SERVER][as sysdba|sysoper]
-- 如果连接远程orcle 需要输入用户名
orcle 就是设置自己设置的服务名
--连接登录实例
sql>connect scott/tiger
show user
desc dba_users
我们知道oarcle数据库真正存放数据的是数据文件(datafiles),Oarcle表空间(tablespaces)实际上是一个逻辑的概念,他在物理上是并不存在的,那么把一组data files 捻在一起就成为一个表空间。
表空间属性:
一个数据库可以包含多个表空间,一个表空间只能属于一个数据库 一个表空间包含多个数据文件,一个数据文件只能属于一个表空间 表这空间可以划分成更细的逻辑存储单元
ALTER USER username DEFAULT|TEMPORARY TABLESPACE tablespace_name
--username 登录用户名
--DEFAULT 默认表空间 TEMPORARY 临时表空间
--tablespace_name 表空间名
--实例
SQL> ALTER USER system DEFAULT TABLESPACE system;
CREATE [TEMPORARY] TABLESPACE tablespace_name TEMPFILE|DATAFILE 'XX.dbf' SIZE xx
--TEMPORARY 创建临时表空间时添加
--tablespace_name 表空间的名字
--XX.dbf 文件名
--SIZE 数据文件的大小
sql>create TABLESPACE test1_tablespace datafile 'test1file.dbf' size 10m --创建永久表空间
sql>create temporary tablespace temptest1_tablespace tempfile 'tempfile1.dbf' size 10m --创建临时表空间
ALTER TABLESPACE tablespace_name OFFLINE|ONELINE
--实例
sql> ALTER TABLESPACE test1_tablespace OFFLINE --脱机状态
sql> select status from dba_tablespace where tablespace_name='test1_tablespace' --查看表空间状态
sql> ALTER TABLESPACE test1_tablespace onelie --联机状态
ALTER TABLESPACE tablespace_name READ ONLY | ORAD WRITE
--默认联机状态就是读状态
SQL> alter tablespace test1_tablespace read only --只读状态
sql> alter tablespace test1_tablespace read write --读写状态
ALTER TABLESPACE tablespace_name ADD DATAFILE 'XX.dbf' size xx
ALTER TABLESPACE tablespace_name DROP DATAFILE 'XX.dbf'
DROP TABLESPACE tablespace_name [INCLUDING CONTENTS]
--INCLUDING CONTENTS 添加后 会把该表空间下的数据文件也一并删除
更改字段的数据类型
alter table table_name MODIFY column_name datatype;
删除字段
alter table table_name DROP COLUMN column_name;
修改字段名
alter TABLE table_name RENAME COLUMN column_name TO new_column_name;
修改表名
RENAME table_name to new_table_name;
DROP 删除表 DROP TABLE table_name;
INSERT INTO table_name (column1,…)values(value1,…)
INSERT INTO table_new [(column1,…)] select column1,…|*from table_old;
– DELTE 语句 DELETE FROM table_name [WHERE conditions];
约束条件也称作完整性约束条件,是在数据表上强制执行的一些数据检验规则,当执行DML操作时必须符合约束条件,否则不能成功执行。 约束条件包括有非空(Not null)、唯一(Unique)、主键(Primary Key)、外键(Foreign Key)和检查(Check)。 约束条件可以在建表时建立也可以在建表后建立。约束条件需要命名,可以由用户指定,否则由系统按照SYS_Cn的默认格式来命名,n是一串数字。
约束字典 user_constraints
非空(Not Null)约束用于确保字段值不为空。非空约束是五个约束条件中唯一一个只能定义在列级的约束条件。非空约束条件可以在建表时建立,也可以在建表后建立。
创建表时添加非空约束
CREATE TABLE table_name(
column_name datatype NOT NULL,..
)
建表后添加非空约束
ALTER TABLE table_name MODIFY(column datatype NOT NULL);
建表后去除非空约束
ALTER TABLE table_name MODIFY(column datatype NULL);
主键是能确定一条记录的唯一标识的一个字段和多个字段组合 主键约束条件从功能上看相当于非空且唯一。主键可以是单字段也可以是多字段组合。在一个表上只允许建立一个主键,而其他约束条件则没有明确的个数限制。
在创建表时添加剂主键
CREATE TABLE table_name(
column_name datatype PRIMARY KEY
)
CREATE TABLE table_name(
column_name datatype,
constraint constraint_name PRIMARY KEY(column1_name,..)
)
--constraint_name 约束的名字
在修改表时添加主键
ALTER TABLE table_name ADD CONSTRAINT column_name PRIMARY KEY(column_name1,...)
--column_name 约束的名字
更改主键约束的名字
ALTER TABLE table_name rename CONSTRAINT old_name TO new_name
删除主键约束
ALTER TABLE table_name
DISABLE | ENABLE CONSTRAINT constraint_name;
--DISABLE 禁用约束 , ENABLE 启用被禁用约束
--constraint_name 约束名字
--删除约束 (两种都可以)
ALTER TABLE table_name
DROP CONSTAINT constraint_name
ALTER TABLE table_name
DROP PRIMARY KEY[CASCAD]
如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键,外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。外键又称作外关键字 外键约束条件定义在两个表的两个字段或一个表的两个字段上,用于保证相关两个字段的关系。外键约束包括两个方面的数据约束: (1):子表上定义的外键的列值,必须从主表被参照的列值中选取,或者为NULL; (2):当主表参照的值被子表参照时,主表的该行记录不允许被删除。
CREATE TABLE table1(
column_name datatype REFERENCES table2(column_name,...)
)
CREATE TABLE table1(
column_name datatype,
CONSTRAINT constraint_name FOREIGN KEY(column_name)REFERENCES table_name(column_name)[ON DELETE CASCADE]
)
-- constraint_name 外键约束名
-- table_name 关联的主表
-- ON DELETE CASCADE 可选 选择后增加级联删除的功能
修改表的时候添加外键约束
ALTER TABLE table1_name CONSTRAINT constraint_name FOREIGN KEY(column_name)REFERENCES table_name(column_name)[ON DELETE CASCADE]
--table1_name 添加外键的表
--table_name 关联的主表
删除外键约束
--禁用外键约束
ALTER TABLE table_name DISABLE | ENABLE CONSTRAINT constraint_name
-- DISABLE 禁用主键约束
-- ENABLE 启用主键约束
--删除外键约束
ALTER TABLE table_name DROP CONSTRAINT constraint_name;
唯一约束保证值得唯一性,区别主键,主键不允许值为空,唯一约束允许一个值为NULL,主键在一个表中只能有一个,唯一约束可以有多个。
再创建表时设置唯一约束
CREATE TABLE table_name (
column_name datatype UNIQUE
)
--第二种方式
CREATE TABLE table_name(
column_name datatype,
CONSTRAINT constraint_name UNIQUE(column_name)
)
修改表时添加唯一约束
ALTER TABLE table_name ADD CONSTRAINT constraint_name UNIQUE(column_name)
删除唯一约束
ALTER TABLE table_name DISABLE | ENABLE CONSTRAINT constraint_name
-- DISABLE 禁用约束
-- ENABLE 启用约束
--删除约束
ALTER TABLE table_name DROP CONSTRAINT constraint_name;
select constraint_name,constraint_type,status from user_constraints WHERE table_name='TESTUL';
检查约束的作用:让字段值更具有意义。 创建表时设置
CREATE TABLE table_name (
column_name datatye CHECK(expressions)
)
CREATE TABLE table_name (
column_name datatye,
CONSTRAINT constraint_name CHECK(expressions)
)
在修改表时添加
ALTER TABLE table_name ADD CONSTRAINT constraint_name CHECK(expressions)
删除唯一约束
ALTER TABLE table_name DISABLE | ENABLE CONSTRAINT constraint_name
-- DISABLE 禁用约束
-- ENABLE 启用约束
--删除约束
ALTER TABLE table_name DROP CONSTRAINT constraint_name;
默认值约束的作用对象为列,每个列只能有一个默认值约束。
创建默认值约束
CREATE TABLE table_name(
column_name datatype default def_name
)
修改默认值约束
ALTER TABLE table_name MODIFY column_name datatype default def_name;
视图是数据库中特有的对象,视图用于储存查询,但不会储存数据(物化视图外)。可以利用视图进行查询、插入、更新和删除数据.Orcle中有4中视图。
关系视图是四种视图中最简单,同时也是最常用的视图,可以将关系视图看做对简单或复杂的定义。它的输出可以看做一个虚拟的表,该表的数据是有其他基础数据提供。由于关系视图并不储存真正的数据,因此占用数据库资源也较少。
创建关系视图
CREATE VIEW view_table_name as select * from table_name
修改关系视图
CREATE OR REPLACE view_table_name as select * from tale_name
-- CREATE OR REPLACE 命令用于创建或者替换视图。
删除视图
drop view view_table_name
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有