1、登录SQL plus
使用系统用户登录:
首先系统用户有:sys和system,这两个用户权限较高;
其中sys权限要高于system,必须以管理员或系统操作人员的权限才能登录;
system可以直接登录;
sysman用于操作企业管理器来使用,是管理人员级别用户;
Scott:默认的密码是tiger;上述三种的密码为系统设置的默认密码;
2、查看登录用户:show user命令
SQL plus中输入的命令不需要用“;”结尾;但是对于SQL语句要用“;”结尾,表示一个命令的结束;
dba_user数据字典:是数据库提供的表,用于查看数据库的信息;
Scott 用户:默认是被锁定的,则需要使用时,必须解锁;
启用用户的语句:alter user username account unlock;
在将Scott用户解锁后,即可使用Scott用户登录SQL plus:connect scott/tiger
3、表空间
表空间概述
理解表空间:表空间是数据库的逻辑存储空间;可以理解为在数据库中开辟的一个空间,用于存储数据库的对象;一个数据库可以由多个表空间来构成;表空间是由一个或多个数据文件构成的;数据文件的位置和大小可由用户自行定义;
表空间的分类:
永久表空间——永久化存储的对象,例如表、视图、存储过程等;
临时表空间——数据库操作当中中间执行的过程,当执行结束后,该存放的内容就会被释放,不会进行永久性保存;(每个用户只有一个临时表空间)
UNDO表空间——事务所修改数据的旧址,即被修改之前的数据;(便于对数据的回滚)
查看用户的表空间
dba_tablespaces和user_tablespaces数据字典:前者是系统管理员级的用户来查看的字典,后者是普通用户的字典;
dba_users和user_users数据字典:同样,前者是系统管理员级的用户字典,后者是普通用户级的字典;
设置用户的默认或临时表空间
ALTER USER username DEFAULT|TEMPORARY TABLESPACE tablespace_name(普通用户没有修改默认表空间的权限,要想修改,则必须利用管理员级别的用户为普通用户设置表空间,或者为其设置权限)
alter user system default tablespace system;将用户修改为system用户
创建表空间:create [temporary] tablespace tablespace_name tempfile|datafile 'xx.dbf' size xx;(永久表空间和临时表空间)
修改表空间:
%修改表空间的状态:
# 设置联机或脱机状态alter tablespace tablespace_name online|offline;(表空间的状态默认是联机状态)
# 设置只读或可读写状态 alter tablespace tablespace_name read only|read write;(表空间必须是联机在线状态)
%修改数据文件:
增加数据文件 alter tablespace tablespace_name add datafile 'xx.dbf' size xx;
删除数据文件 alter tablespace tablespace_name drop datafile 'filename.dbf';(不能删除创建表空间时的第一个数据文件,要想删除该文件,则需删除整个表空间)
删除表空间:
drop tablespace tablespace_name [INCLUDING CONTENTS];(【】里面的表示删除表空间的同时删除表空间中的数据文件)
4、操作表
# 认识表
表都是存放在表空间中;表是存储数据的最基本的单位;在Oracle中表都是二维结构,行(记录)和列(域或者字段)构成;
约定:每一列数据必须具有相同数据类型;列名唯一;每一行数据的唯一性;
# 数据类型
字符型 CHAR(N)(n最大值是2000)、NCHAR(N)(n最大值是1000)均是固定长度的类型,其中NCHAR是按照Unicode格式存放数据的,一般用来存储汉字;
VARCHAR2(N)(n最大值是4000)和NVARCHAR2(N)(n最大值是2000)是可变长度的数据类型,区别也是后者是按Unicode格式存放数据;
数值型 NUMBER(p, s)p是指有效数字,s是小数点后的位数;
FLOAT(n)主要用于存储二进制数据,能表示的二进制的位数是126位;当将二进制转换成十进制,将这个数*0.30103;
日期型 DATE 范围是公元前4712年1月1日到公元9999年12月31日,可以直接精确到秒;
TIMESTAMP时间戳类型,能精确到小数秒;
其他类型(存放大对象的数据)BLOB存放的是4G的数据,是以二进制的形式存放的;
CLOB也是4GB,是以字符串的形式存放的;
# 管理表
%创建表:(table_name在同一个用户下表名要是唯一的)
create table table_name
(
column_name datatype , ...
);
%修改表:(修改表的结构)
添加字段:alter table table_name add column_name datatype;
更改字段的数据类型: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;
%删除表
TRUNCATE TABLE table_name;(删除表中的全部数据,而不是删除这个表,即截断表,该方式的速度远远快于delete方式);
DROP TABLE table_name;(删除整张表)
5、操作表中的数据
#添加数据
INSERT语句:INSERT INTO table_name (column1, column2, ...) VALUES(value1, value2, ...);
ps:获取当前的日期的函数sysdate;
复制表数据:
在建表时复制CREATE TABLE table_new AS SELECT column1, ... | * FROM table_old;
在添加时复制INSERT INTO table_new [(column1, ...)] SELECT column1, ... |* FROM table_old;
#修改数据
UPDATE语句:UPDATE table_name SET column1=value1, ... [WHERE conditions];
#删除数据
DELETE语句:DELETE FROM table_name [WHERE conditions];
6、约束
约束的作用:定义规则、确保数据的完整性;
约束名是唯一的
#非空约束
在创建表时设置非空约束CREATE TABLE table_name(column_name datatype NOT NULL, ...);
在修改表时添加非空约束ALTER TABLE table_name MODIFY column_name datatype NOT NULL;(设置非空约束之前最好确保表中没有空值数据)
在修改表时去除非空约束ALTER TABLE table_name MODIFY column_name datatype NULL;
#主键约束
确保表中每一行数据的唯一性;非空、唯一;
一张表只能设计一个主键约束,主键约束可以由多个字段构成(联合主键或复合主键)
在创建表时设置主键约束:CREATE TABLE table_name(column_name datatype PRIMARY KEY, ...);
或者CONSTRAINT constraint_name PRIMARY KEY(column_name1, ...);(多个字段构成联合主键)(该子句位于所有字段写完之后再设置约束,即称为表级约束)
在修改表时添加主键约束:ALTER TABLE table_name ADD CONSTRAINT constraint_name PRIMARY KEY(column_name1, ...);
更改约束名称ALTER TABLE table_name RENAME CONSTRAINT old_name TO new_name;
删除主键约束ALTER TABLE table_name DISABLE|ENABLE CONSTRAINT constraint_name;(禁用/启用约束);
ALTER TABLE table_name DROP CONSTRAINT constraint_name;(直接删除约束)
ALTER TABLE table_name DROP PRIMARY KEY[CASCADE](因为一张表只有一个主键约束,所以可以直接通过primary key关键字删除主键约束)(CASCADE表示级联删除,当有外键约束时,可以删除其他表引用该主键约束的地方)
#外键约束:主从表的关系
在创建表时设置外键约束:CREATE TABLE table1 (column_name datatype REFERENCES table2 (column_name), ...);(列级约束)
表级外键约束:CONSTRAINT constraint_name FOREIGN KEY(column_name) REFERENCES table_name(column_name) [ON DELETE CASCADE];(同样,该子句位于所有字段写完之后再设置约束,即称为表级约束)
设置外键约束时,主表的字段必须是主键;主从表中相应的字段必须是同一个数据类型;从表中外键字段的值必须来自主表中的相应字段的值,或者为null值;
在修改表时添加外键约束:ALTER TABLE table_name ADD CONSTRAINT constraint_name FOREIGN KEY(column_name) REFERENCES table_name(column_name) [ON DELETE CASCADE];
删除外键约束:(禁用/启用约束)ALTER TABLE table_name DISABLE|ENABLE CONSTRAINT constraint_name;
ALTER TABLE table_nameDROP CONSTRAINT constraint_name;(直接彻底删除约束)
#唯一约束
作用:保证字段值的唯一性
唯一约束和主键约束的区别:主键字段值必须是非空的,唯一约束允许有一个空值;主键在每张表中只能有一个,而唯一约束在每张表中可以有多个;
在创建表时设置唯一约束:CREATE TABLE table_name(column_name datatype UNIQUE, ...);(列级约束)
(表级约束) CONSTRAINT constraint_name UNIQUE (column_name1);当要设置多个字段约束为唯一约束,要写多个这样的子句,而不是直接接多个字段名;即每一个唯一约束都有其唯一的约束名字;
在修改表时添加主键约束:ALTER TABLE table_name ADD CONSTRAINT constraint_name UNIQUE(column_name);
删除唯一约束:ALTER TABLE table_name DISABLE|ENABLE CONSTRAINT constraint_name;(禁用/启用约束);
ALTER TABLE table_name DROP CONSTRAINT constraint_name;(直接删除约束)
#检查约束
作用:表中的值更具有实际意义;
在创建表时设置检查约束:CREATE TABLE table_name(column_name datatype CHECK(expressions), ...);(列级约束)(检查约束会自动为其生成检查约束的名称)
(表级约束) CONSTRAINT constraint_name CHECK(expressions);
在修改表时添加检查约束:ALTER TABLE table_name ADD CONSTRAINT constraint_name CHECK(expressions);
删除检查约束:ALTER TABLE table_name DISABLE|ENABLE CONSTRAINT constraint_name;(禁用/启用约束);
ALTER TABLE table_name DROP CONSTRAINT constraint_name;(直接删除约束)
总结:五种约束
其中只有主键约束是在每张表中只能有一个,但是可以由多个字段构成;
外键约束是唯一一个涉及两张表之间的关系;
在创建表时设置约束,只有非空约束是只能在列级设置,不能在表级设置,其他的约束既可以在表级设置也可以在列级设置;并且设置非空约束时,非空约束是没有名字的;
在修改表时添加约束,与其他约束不同的是,非空约束用到的语句实际是修改字段的语句,即ALTER TABLE table_name MODIFY column_name datatype NOT NULL;
更改约束的名称,除了非空约束,其他的约束都可以改名;当不知道约束名称时,可以通过数据字典(user_constraints)来查看,可以根据需查看的表的名称来查看这张表中所具有的约束的名称、类型、和状态等信息;RENAME CONSTRAINTS old_name TO new_name;(将该语句加在更改表的语句后面ALTER TABLE table_name);
删除约束,对于非空约束是特殊的,仍然用到的是修改字段的语句;将非空约束改为可以为空,ALTER TABLE table_name MODIFY column_name datatype NULL;其他的约束,可以有禁用和彻底删除两种情况,即DISABLE|ENABLE CONSTRAINT constraint_name;和DROP CONSTRAINT constraint_name;;当删除主键约束时,可以通过DROP PRIMARY KEY来删除;
7、查询语句
# 基本查询语句:
PS:以下是基于一张表的查询
SELECT [DISTINCT] column_name1, ...|* FROM table_name [WHERE conditions];(DISTINCT表示不显示重复的数据)
#在SQL PLUS中的设置格式
%更改字段名(更改的只是查询之后的结果的字段名,并不是真正将表中的字段名进行修改):COLUMN column_name HEADING new_name;(其中COLUMN可以简写成COL)
%设置结果显示的格式:COLUMN column_name FORMAT dataformat;
dataformat的格式:对于字符型时,只能设置其显示的长度,字符型用a表示,例如a10,表示字符型的长度为10;
对于数值类型的,用“9”代表一个数字,例如9999.9表示4位整数一位小数;还可以为其加上美元$符号
%清除之前设置过的格式:COLUMN column_name CLEAR;
#查询表中的所有字段及指定字段
%查询所有字段:SELECT * table_name;
%查询指定字段:SELECT column_name1, column_name2, ... FROM table_name;
#给字段设置别名
更改的只是查询之后的结果显示的字段名,并不是真正将表中的字段名进行修改;在上述SQL PLUS设置别名的方法中,一次只能为一个字段设置别名;该方法可以一次为多个字段同时设置别名;
SELECT column_name AS new_name, ... FROM table_name;(AS可以省略,用空格隔开即可)
#运算符和表达式
表达式=操作数+运算符
oracle中的操作数可以有变量。常量和字段;
算术运算符(+、 -、 *、 /)
比较运算符(>、 >=、 <、 <=、 =、 <>)
逻辑运算符(and、or、not)
#带条件的查询 where子句
%带一个条件的查询:条件一般都是使用比较运算符连接的表达式
%多条件的查询:使用逻辑运算符和比较运算符连接的表达式
当有多个运算符时,运算符之间是有优先级的;逻辑运算符的优先级从高到低是not、and、or;比较运算符的优先级高于逻辑运算符;
#模糊查询 LIKE
like关键字也可以归结到比较运算符
通配符的使用(_、%),其中一个“_”只能代替一个字符;%可以代替0到多个任意字符
#范围查询
BETWEEN... AND..
IN/NOT IN()括号中的是具体的值,而不是范围,类似于集合的概念,判断是否处于该集合中;
#对查询的结果进行排序
SELECT .. FROM ...[WHERE...] ORDER BY column1 DESC/ASC, ...;
网友评论