一、使用DDL定义数据库和表结构
- 结构化查询语言:(Structured Query Language,SQL)是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,专用于存取数据以及查询、更新和管理关系数据库系统,同时也是数据库脚本文件的扩展名
- 数据定义语言(Data Definition Language,DDL):主要工作是用于定义和维护数据库以及数据表结构
- 数据库
- 创建:CREATE DATABASE database_name
- 删除:DROP DATABASE database_name
- 显示所有数据库:SHOW DATABASES
- 数据表
创建:
CREATE TABLE table_name(
column_name data_type [NOT NULL] [DEFAULT default_value] [AUTO_INCREMENT] [],
...
[PRIMARY KEY(pk_name),]
[FOREIGN KEY(fk_name) REFERENCES referenced_table_name(ref_pk_name)]
)
- “[]”中的内容为可选项。table_name:表名。
- column_name:字段名。
- data_type:字段数据类型。default_value:默认值。
- auto_increment:主键值自动增长。pk_name:当前表中的主键名。
- fk_name:当前表中的外键名。
- referenced_table_name:被引用表名(主表名)。ref_pk_name:被引用表主键名。
二、使用DDL维护数据库表结构
- 修改语法:alter table table_name
- 新增字段:add column_name data_type [not null]
- 更改字段:CHANGE column_name new_column_name data_type [NOT NULL]
- 更新字段:MODIFY column_name new_data_type [NOT NULL]
- 删除字段:drop column column_name
- 删除唯一约束:DROP UNIQUE constraint_name
2、重命名表:RENAME TABLE table_name TO new_table_name3、添加外键约束:
ALTER TABLE table_name
ADD CONSTRAINT constraint_name FOREIGN KEY(fk_name) REFERENCES referenced_table_name(ref_pk_name)]
三、使用 DML 新增和更新表数据
- 数据操纵语言(Data Manipulation Language,DML) 由 DBMS 提供,用于让用户或程序员使用,实现对数据库中数据的操作。基本的 DML 分为两类四种:检索(查询)和更新(插入、删除、修改)
- 插入数据语法:INSERT [INTO] table_name[( 字段列表 )] VALUES( 值列表
- 向字符串类型的 char、varchar、text 以及日期型字段插入数据时,字段值要括于单引号中。(在 MySQL 中单引号和双引号没有任何区别,但单引号为 SQL 标准,所以提倡使用单引号。)
- 向自增型 auto_increment 字段插入数据时,建议插入 null 值,此时将向自增型字段插入下一个编号。
- 向默认值约束字段插入数据时,字段值可以使用 default 关键字,表示插入的是该字段的默认值。
- 插入新纪录时,需要注意表之间的外键约束关系,原则上先为主(父)表插入数据,然后再为从(子) 表插入数据。
3、修改数据语法:UPDATE table_name set
字段名 1= 值 1, 字段名 2= 值 2,..., 字段名 n= 值 n
[WHERE 条件表达式 ]