DDL语句
数据定义语言,定义数据的结构。
比如,创建修改删除。
1. CREATE
创建表
CREATE TABLE TABLENAME(
字段1 数据类型
字段2 数据类型
字段n 数据类型
)
例:创建A表,包括:
编号A_NO,名称A_NAME,年龄AGE,性别SEX。
CREATE TABLE A1(
A_NO NUMBER(5),
A_AGE NUMBER(3),
A_NAME VARCHAR(10),
A_SEX NUMBER(2)
);
2. 复制表结构
CREATE TABLE TABLE_NAME AS SELECT语句
--新建TABLE名字EMP99,赋值EMP的文本,所有数据,表结构。
CREATE TABLE EMP99 AS
SELECT * FROM EMP;
新建TABLE名字EMP98,赋值EMP的表结构 没有数据。
CREATE TABLE EMP98 AS
SELECT * FROM EMP
WHERE EMPNO=99999999
--或者WHERE 1=2 之类的无法被找到的条件。
DROP
DROP TABLE 表名[PURGE]
如过没有关键字[PURGE],则删除的表会进入回收站。
添加关键字[PURGE],会彻底删除。
--删除EMP1
DROP TABLE EMP1;
--代表删除EMP1进入回收站。
DROP TABLE EMP1[PURGE]
--代表彻底删除EMP1.
SELECT * FROM RECYCLEBIN
--查看所有的回收站表。
--找回EMP1
FLALSHBACK TABLE 表名 TO BEFORE DROP;
--清空回收站的表
PURGE RECYCLEBIN;
3.修改
给表重新命名
语法:ALTER TABLE 表名 RENAME TO 新表名;
RENAME 表名 TO 新表名;
ALTER TABLE A1 RENAME TO AA1;
MODIFY 修改表中字段的数据类型
ALTER TABLE 表名 MODIFY (
字段名 数据类型
字段n 数据类型
)
ALTER TABLE AA11 MODIFY(A_NO VARCHAR(10))
修改表中的字段名
ALTER TABLE TABLE_NAME
RENAME COLUMN 旧字段 TO 新字段
--AA11表中有一字段A_NO,改为EMPNO
ALTER TABLE AA11 RENAME COLUMN A_NO TO EMPNO
给表增加新字段
ALTER TABLE TABLE_NAME ADD(字段名 数据类型)
ALTER TABLE AA11 ADD(A_NO NUMBER(8))
删除表中的字段
ALTER TABLE TABLE_NAME DROP COLUMN 字段名
--删AA11中的ENAME字段
ALTER TABLE AA11 DROP COLUMN ENAME;
清空表中的内容。
TRANCATE TABLE TABLE_NAME --清空表中的数据。
但保留字段和数据类型
--清空DEPT1表。
TRUNCATE TABLE DEPT1;
DML语句
主要对表进行增删改。
INSERT INTO
插入
INSERT INTO TABLE_NAME(
字段1,字段2...字段n
)VALUES(字符串1,字符串2...字符串n)
--在EMP1中插入姓名,职业,工资收入。
--如:张三,数据开发,666
INSERT INTO EMP1(
ENAME,JOB,SAL
)VALUE(
张三,数据开发,666
)
备注:INSERT INTO之后要提交才可使用SELECT
COMMIT;
--提交
ROLLBACK;
--回滚
备注:VALUES的内容应满足当前字段的类型,长度要求。
否则报错。
--第二种写法
INSERT INTO TABLE_NAME(
字段1,字段2....字段n
)SQL 查询语句
此种写法方便与两表合并。
--在EMP1中插入EMP的怨怒共编号,姓名,工资。
INSERT INTO EMP1(
EMANE,
JOB,
SAL
)SELECT
EMPNO,
JOB,
SAL
FROM EMP;
COMMIT;
当已知俩表的结构完全相同,则有
INSERT INTO EMP1
SELECT * FROM EMP
WHERE DEPTNO='20';
COMMIT;
UPDATE
更新
UDPATE TABLE_NAME SET
字段1 = 新值1,
字段2 = 新值2
WHERE...
--更改EMP1中部门20的工资为666
UPDATE EMP1 SET
SAL='666'
WHERE DEPTNO='20';
COMMIT;
--部门10增加10%,20增加20%,30增加30%
UPDATE EMP1 SET
SAL = CASE WHEN DEPTNO='10' THEN SAL*1.1
WHEN DEPTNO='20' THEN SAL*1.2
WHEN DEPTNO='30' THEN SAL*1.3
ELSE SAL*1.4
END
COMMIT;
DELETE
删除
DELETE FROM TANLE_NAME
WHERE 筛选条件0
--删除EMP1表部门30的员工信息。
DELETE FROM EMP1
WHERE DEPTNO='30';
COMMIT;
区别:
DROP:删除表/数据库,不保留字段。
TRUNCATE:清空表中数据,保留字段及其数据类型
DELETE:条件删除,保留字段,条件为空时候删除全部,但保留字段。
DELETE会保持高水位,TRUNCATE不会。
从速度上来说,DROP的速度>TRUNCATE>DELETE
约束
强制条件。针对于表。
约束一般的命名规则:约束的首字母K_表名_列名
CREATE TABLE 表名(
字段名1 数据类型[约束类型]
--如果是这种写法,则系统自动分配约束名称。
字段名2 数据类型[CONSTRAINT 约束名称 约束类型]
--如果是这种写法,则自定义约束名称。
)
1. NOT NULL 非空约束
创建TEXT1表,包括ENO,ENAME,SAL
要求:ENO添加非空约束。
CREATE TABLE TEST1(
ENO NUMBER(10) NOT NULL,
ENAME VARCHAR2(10),
SAL NUMBER(12);
)
2. UNIQUE 唯一约束
拥有唯一约束的字段只能拥有一条数据,其余为空值。
创建TEXT1表,包括ENO,ENAME,SAL
要求:ENAME添加唯一约束
CREATE TABLE TEXT1(
ENO NUMBER(10) CONSTRAINT 约束1 NOT NULL,
ENAME VARCHAR2(10) CONSTRAINT 约束2 UNIQUE,
SAL NUMBER(12)
)
3. PRIMARY KEY 主键约束
唯一约束+非空约束
一个表中只能有一个主键约束
主键字段必须要有索引。其内容通过索引实现。如果主键没有索引则会自己创建。
创建TEXT1表,包括ENO,ENAME,SAL
要求:ENO添加主键约束。
CREATE TABLE TEXT1(
ENO NUMBER(10) CONSTRAINT 主键约束 PRIMARY KEY,
ENAME VARCHAR2(10) CONSTRAINT 约束2 UNIQUE,
SAL NUMBER(12) CONSTRAINT 约束1 NOT NULL
)
4.复合主键
两字段同时有非空和唯一的需求
创建TEXT1表,包括ENO,ENAME,SAL
要求:给ENO和ENAME两个列创建一个主键。(表积写法)
CREATE TABLE TEXT1(
ENO NUMBER(10),
SAL NUMBER(12),
CONSTRAINT PRIMARYKEY_ENO_ENAME_TEXT1 PRIMARY KEY(ENO,ENAME)
)
此时若想INSERT数据,以下情况会报错:
1. 两个主键的组合,在表中已经存在。但相互调换顺序是不影响的。
2. 两个主键任一为空,即会报错。
5.检查约束
我们可以限制 值在某个范围内。
要求:约束员工编号1-100 性别男女。
CREATE TABLE TEXT5(
ENO NUMBER(10) CONSTRAINT CK_ENO_TEXT5 CHECK(ENO BETWEEN 1 AND 5),
SAL NUMBER(12),
SEX VARCHAR(2) CONSTRAINT CK_SEX_TEXT5 CHECK(SEX IN('男','女'))
);
6.增加约束
在建表之后添加约束。
ALTER TABLE TABLE_NAME
MODIFY 字段名 CONSTRAINT 约束名称 约束类型;
7.修改约束名称
修改已经存在的约束名字。
ALTER TABLE TABLE_NAME
RENAME CONSTRAINT 旧约束名称 TO 新约束名称
8.删除约束
删除已存在的约束。
ALTER TABLE TABLE_NAME
DROP 约束名称;
--删除TEXT3中的PK_ENO_TEXT3_1
ALTER TABLE TEXT3
DROP PK_ENO_TEXT3_1;
9.禁用约束
ALTER TABLE TABLE_NAME
DISABLE CONSTRAINT 约束名称;
--禁用TEXT3表中的UK_ENAME_TEXT3;
ALTER TABLE TABLE_NAME
DISABLE CONSTRAINT UK_ENAME_TEXT3;
10.启动约束
ALTER TABLE TABLE_NAME
ENABLE CONSTRAINT 约束名称;
ALTER TABLE TEXT3
ENABLE CONSTRAINT UK_ENAME_TEXT3