Oracle数据库中的数据定义语言(DDL)

person 孤岛中的灯塔    watch_later 2024-11-03 14:45:16
visibility 75    class DDL,ORACLE    bookmark 专栏

在Oracle数据库中,数据定义语言(DDL)用于定义和管理数据库结构。它包括创建、修改和删除数据库对象,如表、视图和索引,以及定义约束(如主键、外键和唯一约束)。本文将详细介绍这些DDL操作及其使用示例。

一、数据定义语言(DDL)概述

DDL是一组用于定义数据库结构的SQL语句,主要用于创建和修改数据库对象。常见的DDL操作包括:

  1. 创建表(CREATE TABLE)
  2. 修改表(ALTER TABLE)
  3. 删除表(DROP TABLE)
  4. 创建视图(CREATE VIEW)
  5. 删除视图(DROP VIEW)
  6. 创建索引(CREATE INDEX)
  7. 删除索引(DROP INDEX)

二、创建、修改与删除表

1. 创建表(CREATE TABLE)

创建表的基本语法如下:

CREATE TABLE table_name (
    column1 datatype [constraints],
    column2 datatype [constraints],
    ...
);

示例

-- 创建一个名为employees的表
CREATE TABLE employees (
    employee_id NUMBER PRIMARY KEY,
    first_name VARCHAR2(50),
    last_name VARCHAR2(50) NOT NULL,
    hire_date DATE DEFAULT SYSDATE,
    salary NUMBER CHECK (salary > 0)
);

2. 修改表(ALTER TABLE)

ALTER TABLE语句用于修改已存在的表。可以添加列、修改列、删除列或添加约束。

a. 添加列

ALTER TABLE employees
ADD (department_id NUMBER);

b. 修改列

ALTER TABLE employees
MODIFY salary NUMBER(10, 2);

c. 删除列

ALTER TABLE employees
DROP COLUMN department_id;

3. 删除表(DROP TABLE)

DROP TABLE语句用于删除表及其所有数据。

DROP TABLE employees;

三、视图的创建与删除

1. 创建视图(CREATE VIEW)

视图是基于SQL查询的虚拟表。它不存储数据,而是动态生成结果。

基本语法如下:

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

示例

-- 创建一个名为employee_view的视图,显示薪水高于60000的员工
CREATE VIEW employee_view AS
SELECT first_name, last_name, salary
FROM employees
WHERE salary > 60000;

2. 删除视图(DROP VIEW)

DROP VIEW语句用于删除视图。

DROP VIEW employee_view;

四、索引的创建与删除

索引是提高数据库查询性能的对象。创建索引的基本语法如下:

CREATE INDEX index_name ON table_name (column1, column2, ...);

示例

-- 创建一个索引以加速对last_name列的查询
CREATE INDEX idx_last_name ON employees (last_name);

删除索引

DROP INDEX idx_last_name;

五、约束的使用

约束用于限制表中的数据,以保证数据的完整性和准确性。主要约束包括:

1. 主键(PRIMARY KEY)

主键约束用于唯一标识表中的每一行。

示例

在创建表时指定主键:

CREATE TABLE departments (
    department_id NUMBER PRIMARY KEY,
    department_name VARCHAR2(50) NOT NULL
);

2. 外键(FOREIGN KEY)

外键约束用于确保数据的完整性,建立表之间的关系。

示例

在创建表时指定外键:

CREATE TABLE employees (
    employee_id NUMBER PRIMARY KEY,
    first_name VARCHAR2(50),
    last_name VARCHAR2(50) NOT NULL,
    department_id NUMBER,
    FOREIGN KEY (department_id) REFERENCES departments(department_id)
);

3. 唯一约束(UNIQUE)

唯一约束用于确保列中的所有值都是唯一的。

示例

在创建表时指定唯一约束:

CREATE TABLE users (
    user_id NUMBER PRIMARY KEY,
    username VARCHAR2(50) UNIQUE,
    email VARCHAR2(100) UNIQUE
);

六、总结

本文详细介绍了Oracle数据库中的数据定义语言(DDL),包括创建、修改与删除表、视图、索引,及约束的使用(主键、外键和唯一约束)。掌握这些基本的DDL操作将有助于你更好地管理Oracle数据库结构和数据完整性。

如果你有任何问题或需要进一步的讨论,请随时联系我!希望这篇博客对你有所帮助!

评论区
评论列表
menu