美文网首页
oracle数据库中的SQL语言基础

oracle数据库中的SQL语言基础

作者: 方研梅 | 来源:发表于2017-11-22 20:45 被阅读0次

    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, ...;

    相关文章

      网友评论

          本文标题:oracle数据库中的SQL语言基础

          本文链接:https://www.haomeiwen.com/subject/pgwovxtx.html