2023-02-15

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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第一天 7月13日OCP笔记: Oracle Ocp11g准备资料: OracleFundmentals 书 管理...
    fjxCode阅读 2,847评论 0 4
  • 深入模型 在上一个章节中,我们提到了Django是基于MVC架构的Web框架,MVC架构追求的是“模型”和“视图”...
    EchoPython阅读 576评论 0 1
  • 1.SQL概述 •SQL语言(Structured Query Language)是一种数据库查询和程序设计语言,...
    初见_0308阅读 388评论 0 0
  • 1.SQL概述 SQL语言(Structured Query Language)是一种数据库查询和程序设计语言,用...
    Rannio阅读 607评论 0 4
  • 1.起列别名是,有三种特殊情况需要加引号,以下不属于这三种情况之一的选项是( )A.区分大小写B.含有特殊字符C....
    le_u阅读 496评论 0 0