美文网首页
MySQL笔记(一)之新建数据库和数据表

MySQL笔记(一)之新建数据库和数据表

作者: cnkai | 来源:发表于2017-09-03 15:15 被阅读0次

创建数据库

CREATE DATABASE database_name

创建数据表

CREATE TABLE table_name
(
列1 数据类型,
列2 数据类型,
列3 数据类型,
....
)

#常见的数据类型  
integer(size)  整型  
int(size)   整型  
numeric(size,d)  浮点型  
char(size)  固定长度字符型  
varchar(size)  可变长度字符型  
date(yyyymmdd)  日期类型  

数据表的约束

NOT NULL

强制列不接受 NULL 值

CREATE TABLE Persons
(
Id_P int NOT NULL,
City varchar(255)
)

DEFAULT

用于向列中插入默认值。

  1. 创建时添加约束
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255) DEFAULT 'Sandnes'

OrderDate date DEFAULT GETDATE()   # 可以使用函数
)
  1. 创建后添加约束
ALTER TABLE Persons
ALTER City SET DEFAULT 'SANDNES'
  1. 撤销约束
ALTER TABLE Persons
ALTER City DROP DEFAULT

UNIQUE

唯一标识数据库表中的每条记录,一个数据表中可以有多个UNIQUE约束。

  1. 创建时添加UNIQUE约束
CREATE TABLE table_name
(
Id_P int NOT NULL,
City varchar(255),
UNIQUE (Id_P)       # 为一列指定UNIQUE约束
CONSTRAINT uc_PersonID UNIQUE (Id_P,City)  # 命名UNIQUE 约束,并且为多列指定UNIQUE约束
)
  1. 创建后添加约束
#添加一个约束
ALTER TABLE Persons
ADD UNIQUE (Id_P)

#命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束
ALTER TABLE Persons
ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)

3.撤销UNIQUE约束

ALTER TABLE table_name
DROP INDEX uc_PersonID

PRIMARY KEY

主键必须包含唯一的值,主键列不能包含 NULL 值。
每个表都应该有一个主键,并且每个表只能有一个主键。

  1. 创建时添加PRIMARY KEY约束
CREATE TABLE Persons
(
Id_P int NOT NULL,
City varchar(255),
PRIMARY KEY (Id_P)   # 为一列指定UNIQUE约束
CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,City) #命名 PRIMARY KEY 约束,以及为多个列定义 PRIMARY KEY 约束
)
  1. 创建后添加PRIMARY KEY 约束
ALTER TABLE Persons
ADD PRIMARY KEY (Id_P)

ALTER TABLE Persons
ADD CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,LastName)
  1. 撤销 PRIMARY KEY 约束
ALTER TABLE Persons
DROP PRIMARY KEY

FOREIGN KEY

指向另一个表中的 PRIMARY KEY

  1. 创建时添加FOREIGN KEY约束
CREATE TABLE Orders
(
Id_O int NOT NULL,
OrderNo int NOT NULL,
Id_P int,
PRIMARY KEY (Id_O),
FOREIGN KEY (Id_P) REFERENCES Persons(Id_P)  # 一个约束

CONSTRAINT fk_PerOrders FOREIGN KEY (Id_P) REFERENCES Persons(Id_P)  # 命名约束且指定多个约束
)
  1. 创建后添加PFOREIGN KEY 约束
ALTER TABLE Orders
ADD FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P)

ALTER TABLE Orders
ADD CONSTRAINT fk_PerOrders
FOREIGN KEY (Id_P)
REFERENCES Persons(Id_P)
  1. 撤销 FOREIGN KEY 约束
ALTER TABLE Orders
DROP FOREIGN KEY fk_PerOrders

CHECK

束用于限制列中的值的范围

  1. 创建时添加CHECK约束
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CHECK (Id_P>0)

CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
)

  1. 创建后添加CHECK约束
ALTER TABLE Persons
ADD CHECK (Id_P>0)

ALTER TABLE Persons
ADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
  1. 撤销 CHECK 约束
ALTER TABLE Persons
DROP CHECK chk_Person

相关文章

  • MySQL存储引擎MyISAM与InnoDB的优劣

    使用MySQL当然会接触到MySQL的存储引擎,在新建数据库和新建数据表的时候都会看到。 MySQL默认的存储引擎...

  • nodejs-mysql基础操作

    新建数据表 使用Navicat for mysql之类的工具新建数据 新建名为my_news_test的数据库 在...

  • MySQL基础

    打开MySQL 查看数据库 连接数据库 查看表 退出 新建数据库 新建数据表 插入数据查看表中的数据 我们尝试向 ...

  • mac终端下修改MySQL的编码格式

    说明:最近在学习终端操作mysql数据库,对于mysql默认新建数据库,数据表,以及数据字段默认latin1,在每...

  • MySQL笔记(一)之新建数据库和数据表

    创建数据库 创建数据表 数据表的约束 NOT NULL 强制列不接受 NULL 值 DEFAULT 用于向列中插入...

  • Laravel数据库操作之-DB facade

    数据库操作之-DB facade 新建数据表与连接数据库 使用DB facade实现CURD 创建数据表 连接数据...

  • MySQL学习笔记一之MySQL语法

    title: MySQL学习笔记一之MySQL语法tags: MySQL 数据库categories: MySQL...

  • thinkphp-登入接口示例

    接着上一个笔记编写第一个后台接口 新建数据表 在数据库zero中新建一个数据表,命名为db_account 编辑列...

  • 开启数据库服务器

    1.开启数据库服务器 2.新建数据库 MySQL学习笔记(与视频配套) 一天学会 MySQL 数据库(由于不能转载...

  • MySQL学习笔记

    MySQL学习笔记 一、SQL语句 DDL(数据定义语言):定义数据库,数据表的结构:create(创建)、dro...

网友评论

      本文标题:MySQL笔记(一)之新建数据库和数据表

      本文链接:https://www.haomeiwen.com/subject/drhjjxtx.html