MySQL中数据表的基本操纵
本文基于对国家863中部软件孵化器编著的《MySQL从入门到精通》一书的操作实践。
一、创建数据表
数据表属于数据库,在创建数据表之前,应该使用语句 USE 数据库名 指定操作是在那个数据库中进行。
创建数据表的语句为CREATE TABLE ,语法规则如下:
CREATE TABLE 表名
( //为括号
字段名1 数据类型 [列级别约束条件] [默认值],
字段名1 数据类型 [列级别约束条件] [默认值],
......
[表级约束条件]
); //要有分号
使用CREATE TABLE 创建表时,要注意一下几点:
(1)要创建表名,不区分大小写,不能使用SQL语言中的关键字,如DROP、ALTER等;
(2)数据表中每一个字段的名称和数据类型,如果要创建多个,要用逗号隔开。
1、主键约束
主键,又称主码,是表中一列或者多列的组合。主键约束(Primary Key Constraint)要求主键列的数据唯一,并且不允许为空。主键能够唯一标识表中的一条记录,可以结合外键来定义不同数据表之间的关系,并且可以加快数据库查询的速度。主键和记录之间的关系如同身份证和人之间的关系,它们之间一一对应。主键分为两种类型:单字段主键和多字段联合主键。

(1)单字段主键
a)在定义列的同时指定主键,语法规则如下:
字段名 数据类型 PRIMARY KEY [默认值]

b)在定义完所有列之后指定主键,语法格式如下:
PRIMARY KEY [字段名]

(2)多字段联合主键
语法规则如下:
PRIMARY KEY [字段1,字段2....,字段名n]

2、外键约束
外键用来在两个表的数据之间建立连接,它可以是一列或多列,一个表可以有一个多多个外键。外键对应的是参照完整性,一个表的外键可以为空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值。主键所在的表为主表,外键所在的表为从表。
创建外键的语法如下:
[CONSTRAINT 外键名] FOREIGN KEY 字段名1 [字段名2...] REFERENCES 主表名 主键列1 [,主键列2...]

注意:子表的外键必须关联父表的主键,且关联字段的数据类型必须匹配,如果类型不一样,则创建子表是,就会出现错误提示。
3、非空约束
非空约束(NOT NULL Constraint)是指字段的值不能为空。语法规则如下:
字段名 数据类型 NOT NULL

4、唯一性约束
唯一性约束要求该列唯一,允许为空,但是只能出现一个空值。唯一约束可以确保一列或基类都不出现重复值。
1)语法
字段名 数据类型 UNIQUE

2)语法
在定义往所有列之后指定唯一约束,语法如下:
[CONSTRAINT <约束名>] UNIQUE(<字段名>)

5、默认约束
默认约束指定某列的默认值。语法如下:
字段名 数据类型 DEFAULT 默认值

注:UNIQUE和PRIMARY KEY的区别:
1)一个表可以有多个字段声明为UNIQUE,但是只能由一个PRIMARY KEY声明;
2)声明为PRIMARY KEY 的类不允许有空值,但是声明为UNIQUE的字段允许空值的存在。
6、设置数据表的属性值自动增加
在数据库应用中,希望在每次插入新记录时,系统自动生成字段的主键值。可以通过表主键添加AUTO_INCREMENT关键字来实现。
一个表只能由一个字段使用AUTO_INCREMENT约束,且该字段必须为主键的一部分。语法如下:
字段名 数据类型 AUTO_INCREMENT

然后对数据表中插入相应的数据以后看:


二、查看数据表结构
1、查看表基本结构
语法如下:
DESCRIBE(DESC) 表名;

2、查看表详细结构
语法格式如下:
SHOW CREATE TABLE <表名\G>;

三、修改数据表
1、修改表名
语法如下:
ALTER TABLE <旧表名>RENAME [TO]<新表名>;

注:修改表名并不修改表的结构。
2、修改字段数据类型
ALTER TABLE<表名>MODIFY<字段名><数据类型>;

3、修改字段名
ALTER TABLE<表名>CHANGE<旧字段名><新字段名><新数据类型>;

4、添加字段
ALTER TABLE<表名>ADD<新字段名><数据类型>[约束条件][FIRST/AFTER 已存在的字段名];
默认的添加位置是数据表的最后列
1)添加无完整性约束条件的字段

2)添加有完成约束条件的字段

3)在表的第一类添加一个字段

4)在表中指定列之后添加一个字段

5、删除字段
ALTER TABLE <表名>DROP<字段名>;

6、修改字段排序
ALTER TABLE<表名>MODIFY<字段1><数据类型>FIRST AFTER<字段2>;

7、修改表的存储引擎
ALTER TABLE<表名>ENGINE=<更改后的存储引擎名>;
8、删除表的外键约束
ALTER TABLE<表名>DROP FOREIGN KEY<外键约束名>;
四、删除数据表
DROP TABLE 表1,表2....
值得注意的是,删除数据表时,若有外键约束,应先删除约束条件,再删除主表。也可以先删除子表,再删除主表。
总结:
1、数据表的修改用ALTER TABLE
2、数据表的删除用DROP
MySQL中数据表的基本操纵的更多相关文章
- 查看MYSQL中数据表占用的空间
由于数据太大了.所以MYSQL需要瘦身,那前提就是需要知道每个表占用的空间大小. 首先打开指定的数据库: use information_schema; 如果想看指定数据库中的数据表,可以用如下语句: ...
- MySQL中数据表的查操作
查询数据表的全部内容 mysql> show tables;#查看当前数据库下的全部表 +--------------------+ | Tables_in_ceshi_ku | +------ ...
- MySql中数据表增加字段很慢怎么办
正确的做法是这样,对于数据量很大的表,需要添加所有或者修改字段的做法是如下: 1.先创建一张一样的表 create table new_tb like tb_old; 2.修改创建表的字段 alter ...
- mysql中数据表记录的增删查改(2)
select `数据表.字段1`, group_concat(`数据表.字段2`) from `数据表` group by `数据表.字段1` order by `数据表.字段1` desc; sel ...
- mysql中数据表记录的增删查改(1)
数据记录的增删改查 insert into `数据表名称` (`字段名称`, ...) values ('1', ...); delete from `数据表名称` where 子句; update ...
- MySQL中数据表的增操作
今天学习到表的增操作,写个博客总结一下,PS:以下所有的凝视都是我在电脑上所有操作完毕后,再拷贝到记事本上加入的.至于在运行的时候可不能够那样加入凝视,就有待考证了. 选择库 mysql> sh ...
- 给MySQL中数据表添加字段
添加一个char字段: mysql> alter table stock add src char(20); Query OK, 3766 rows affected (0.65 sec) Re ...
- MySQL查询数据表中数据记录(包括多表查询)
MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...
- MySQL为数据表的指定字段插入数据
username not null 没有默认值/有默认值 insert不插入username字段 均不报错 2014年07月23日21:05 百科369 MySQL为数据表的指定字段插入数据 ...
随机推荐
- “腾讯WeTest助力《龙珠直播》盘点APP质量问题”
WeTest 导读 据调查数据表明,移动端用户在使用APP时如果遇到了闪退等兼容性问题,20%的用户会选择直接卸载. 2016年,被称为中国直播元年.随着各类直播平台的疯狂生长与扩散,直播产品在内容, ...
- 「专题训练」Boredom(CodeForces Round #260 Div.1 A)
题意(Codeforces-455A) 给你\(n\)个数,你每次可以选择删除去一个数\(x\)获得\(x\)分,但是所有为\(x+1\)和\(x-1\)的数都得删去.问最大获得分数. 分析 这是一条 ...
- Selenium(Python)驱动Chrome浏览器
Chrome浏览器与chromedriver.exe驱动可以是官网上最新的, 随意! Chrome.py: from selenium import webdriverfrom selenium.we ...
- MySQL☞in语句
in语句: 1)列名 in(数值1,数值2,数值3…):求出满足该列的多个列值 格式: select 列名1,列名2 from 表名 where 列名 in (数值1,数值2,数值3...) 如下图 ...
- Python列表操作大全(非常全)
Python列表操作大全(非常全!!!) 对于python列表的理解可以和C语言里面的数组进行比较性的记忆与对照,它们比较相似,对于python里面列表的定义可以直接用方括号里加所包含对象的方法,并且 ...
- 【MySQL解惑笔记】忘记MySQL数据库密码
破解MySQL密码 一.MySQL5.7.5之前 只要有系统root密码就可以破解: [root@host- ~]# vim /etc/my.cnf //在配置文件中加入如下内容 [mysqld] s ...
- 最小生成树与Prim算法
最小生成树(MST) 定义 首先是一棵树(废话 其次没有回路(废话 包含全部顶点和V-1条边 边的权重和最小!!!!! 所以如果是单棵最小生成树,至少说明图是连通的.不然就是森林. 生成思路 既然是根 ...
- leetcode个人题解——#19 Remove Nth Node From End of List
思路:设置两个指针,其中第二个指针比第一个延迟n个元素,这样,当第二个指针遍历到指针尾部时,对第一个指针进行删除操作. 当然,这题要注意一些边界值,比如输入[1,2] n=2时如果按照思路走会指向未分 ...
- MyBatis 插件 : 打印 SQL 及其执行时间
Plugins 摘一段来自MyBatis官方文档的文字. MyBatis允许你在某一点拦截已映射语句执行的调用.默认情况下,MyBatis允许使用插件来拦截方法调用: Executor(update. ...
- 压力测试工具-webbench
简述 偶然情况下看到一款性能测试工具webbench,看着挺不错的记录一下安装过程,在以后项目上线过程中可以压一压一些页面的并发情况,对项目性能有个大致的了解. 原理 webbench首先fork出多 ...