博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL笔记(一)之新建数据库和数据表
阅读量:5249 次
发布时间:2019-06-14

本文共 2514 字,大约阅读时间需要 8 分钟。

创建数据库

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

用于向列中插入默认值。

  • 创建时添加约束
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()   # 可以使用函数)
  • 创建后添加约束
ALTER TABLE PersonsALTER City SET DEFAULT 'SANDNES'
  • 撤销约束
ALTER TABLE PersonsALTER City DROP DEFAULT

UNIQUE

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

  • 创建时添加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约束)
  • 创建后添加约束
#添加一个约束ALTER TABLE PersonsADD UNIQUE (Id_P)#命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束ALTER TABLE PersonsADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
  • 撤销UNIQUE约束
ALTER TABLE table_nameDROP INDEX uc_PersonID

PRIMARY KEY

主键必须包含唯一的值,主键列不能包含 NULL 值。

每个表都应该有一个主键,并且每个表只能有一个主键。

  • 创建时添加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 约束)
  • 创建后添加PRIMARY KEY 约束
ALTER TABLE PersonsADD PRIMARY KEY (Id_P)ALTER TABLE PersonsADD CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,LastName)
  • 撤销 PRIMARY KEY 约束
ALTER TABLE PersonsDROP PRIMARY KEY

FOREIGN KEY

指向另一个表中的 PRIMARY KEY

  • 创建时添加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)  # 命名约束且指定多个约束)
  • 创建后添加PFOREIGN KEY 约束
ALTER TABLE OrdersADD FOREIGN KEY (Id_P)REFERENCES Persons(Id_P)ALTER TABLE OrdersADD CONSTRAINT fk_PerOrdersFOREIGN KEY (Id_P)REFERENCES Persons(Id_P)
  • 撤销 FOREIGN KEY 约束
ALTER TABLE OrdersDROP FOREIGN KEY fk_PerOrders

CHECK

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

  • 创建时添加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'))
  • 创建后添加CHECK约束
ALTER TABLE PersonsADD CHECK (Id_P>0)ALTER TABLE PersonsADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
  • 撤销 CHECK 约束
ALTER TABLE PersonsDROP CHECK chk_Person

转载于:https://www.cnblogs.com/cnkai/p/7469587.html

你可能感兴趣的文章
Html 小插件5 百度搜索代码2
查看>>
P1107 最大整数
查看>>
多进程与多线程的区别
查看>>
Ubuntu(虚拟机)下安装Qt5.5.1
查看>>
java.io.IOException: read failed, socket might closed or timeout, read ret: -1
查看>>
java 常用命令
查看>>
CodeForces Round #545 Div.2
查看>>
卷积中的参数
查看>>
51nod1076 (边双连通)
查看>>
Item 9: Avoid Conversion Operators in Your APIs(Effective C#)
查看>>
深入浅出JavaScript(2)—ECMAScript
查看>>
STEP2——《数据分析:企业的贤内助》重点摘要笔记(六)——数据描述
查看>>
ViewPager的onPageChangeListener里面的一些方法参数:
查看>>
Jenkins关闭、重启,Jenkins服务的启动、停止方法。
查看>>
CF E2 - Array and Segments (Hard version) (线段树)
查看>>
Linux SPI总线和设备驱动架构之四:SPI数据传输的队列化
查看>>
SIGPIPE并产生一个信号处理
查看>>
CentOS
查看>>
Linux pipe函数
查看>>
java equals 小记
查看>>