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

推荐阅读更多精彩内容

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