oracle数据库中的SQL语言基础

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,458评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,454评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,171评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,062评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,440评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,661评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,906评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,609评论 0 200
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,379评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,600评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,085评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,409评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,072评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,088评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,860评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,704评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,608评论 2 270

推荐阅读更多精彩内容