有将近一个星期都没有更新mysql了。相反linux的东西倒是学习不少。可能我个人情感上对linux更感兴趣一点。但mysql我也不烦,只是一旦将精力投入到了一样事情上去,就很难将精力分散去搞其他的东西。

最近我也调整了学习计划和健身计划。以前是每天晚上下班后,运动半个小时到一个小时,现在是晚上早睡,基本上如果没有特别的安排,10:30是肯定要入睡的。从下班到家,然后抽出二到三个小时学习一下。至于健身,要放在了早上,昨天试验了一下,早上还是起的来的。5:30起床,跑步半个小时,甚至还有时间去早市吃早餐。

实际上,如果下班不干点自己感兴趣的事情,一天也就这么过去了。

mysql的这部分,实际上平时都练习的比较熟悉。本来想要跳过这个章节,后来想到想要将自己的知识组织成为一个系列。即使以后遇到难题了,遗忘了知识点,也可以迅速的从这些笔记中找到答案,迅速的回忆起来。

稳固的知识体系是很重要的,希望我这个好习惯能够一直的坚持下去。


用于测试的sql代码和数据:

#班级表
create table classes(
class_no int auto_increment primary key,
class_name char(20) not null unique,
department_name char(20) not null
)engine=innodb default charset=utf8; #下面是一些测试数据:
insert into classes(class_name,department_name) values
('英语二班','高一英语二班'),
('英语三班','高一英语三班'),
('英语四班','高一英语四班'),
('英语五班','高一英语五班'),
('英语六班','高一英语六班'),
('数学一班','高一数学一班'),
('数学二班','高一数学二班'),
('数学三班','高一数学三班'),
('数学四班','高一数学四班'),
('数学五班','高一数学五班'),
('数学六班','高一数学六班'),
('语文一班','高一语文一班'),
('语文二班','高一语文二班'),
('语文三班','高一语文三班'),
('语文四班','高一语文四班'),
('语文五班','高一语文五班'),
('语文六班','高一语文六班');

1、表结构之增、删、改、插

注意:这里演示以classes表作为基础。在实际应用中,可以替换成你自己的表名。

原有的表结构如下图:

查看表结构以及字段:

desc   classes;

增加字段:

alter table classes add testfield1 varchar(10) not null default '';

删除字段:

alter table classes drop testfield1;

修改字段名:

    (为了操作方便,再重新加上字段:alter table classes add testfield1 varchar(10) not null default '';)

alter table  classes change testfield1  test varchar(10) not null default '';

仅修改字段类型:

alter table classes modify test chat(10);

modify 和change的作用差不多。区别在于,change是更换字段的名字。而modify只改变该字段的字段类型。

平时使用的使用的时候可以区别使用。

2、对表约束的增、删、改、查。

在工作中经常会遇到给表增加约束,或者删除约束的状况。

添加约束条件:

语法为:alter  table  你的表名  add constraint  约束名   约束类型(字段名)

alter table classes add constraint myunique unique(class_no);

删除约束条件:

删除约束条件之前我们要清楚的知道自己的表里已经有了那些约束。

可以通过 show create table  表名 \G 来显示。这里的\G  意思是group 的意思(我主观臆测的)。

show create  table classes \G  注意\G后没有;号。

要删除约束条件,还要知道有那些约束条件。

约束条件一般有主键约束(primary key) 外键约束(foreign key) ,唯一索引名(index)

这里先简单的介绍一下什么是外键约束,先看看foreign 是什么意思:外来的外国的。也就是说这张表中的这个字段来源与另外一张表,其中的值不能五中生有,必须从另外一 张表中来。

更加详细的介绍,我们看后面的文章。

删除主键约束:

语法:alter table 表名 drop primary key.

栗子:alter table classes drop primary key.

删除外键约束:

一张表可以有一个主键,但可以有多个外键。因此删除外键的时候要删除当时给外键起的那个名字,即约束名。

语法: aleter table 表名 drop foreign key  约束名;

删除唯一约束:

什么是唯一约束:举个栗子,比如我们的身份证号码是不会重复的,那么在录入身份证的过程中我们就会防止由于失误而录入重复的身份证号码。这就是唯一约束。unqiue(独特的,独一无二的、稀罕的)。当然了唯一约束一个表也可以有多个的,比如用户表里可以既有身份证号、也可以有电话号码。那么我们删除的时候,也要删除约束名。

语法:alter table 表名 drop index 约束名。

alter table classes drop index class_name;

修改表的其他选项:如修改存储引擎类型、修改字符集、修改自增初始值。

修改存储引擎:    alter table 表名 engine=新存储引擎;

修改字符集:       alter table 表名 charset=新的字符集;

修改自增初试值:  alter table 表名 auto_increment=新的初始值;

3、对表名的修改和删除

      修改表名虽然很简单,但是我经常用到。

再项目准备阶段、设计数据库的时候。表名为了更加的方便理解,因此设计上应当尽量的人性化,所以难免有修改表名的时候。

修改表名:

alter table  表名 rename  新表名。

这里我们区分一下修改表名和修改字段名的区别:alter table 表名 change 原字段 新字段 约束条件;

啰嗦一下:change强调的是数据结构发生改变,而change强调的是表的名字发生了改变,数据本身并不发生变化。因此可见外国人命名的时候还是非常严禁的。

删除表名:

alter table 表名 ;

在删除表的时候。如果该表中存在外键,那就会报错。为什么呢?大家想一想。

当然删表对于myisam存储引擎就不会报错。这又是为什么呢?

Mysql学习笔记(二)对表结构的增删改查的更多相关文章

  1. ASP.NET学习笔记(3)——用户增删改查(三层)

    说明(2017-10-6 11:21:58): 1. 十一放假在家也没写几行代码,本来还想着利用假期把asp.net看完,结果天天喝酒睡觉,回去的票也没买到,惨.. 2. 断断续续的把用户信息的页面写 ...

  2. 【EF学习笔记04】----------EF简单增删改查

    第一步:创建上下文对象 using(var db = new Entities()) { //数据操作 } 新增 UserInfo user = new UserInfo() { UserName = ...

  3. Android学习笔记_9_SQLiteOpenHelper对象之数据库增删改查以及事务回滚操作

    一.SQLite数据库: 在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进 ...

  4. mongo学习笔记(一):增删改查

    安装:我是按这篇来弄的 一.Insert 1.db.person.insert({"name":"jack","age":20}) 2.va ...

  5. Mybatis学习(二) - CRUD操作(增删改查操作)

    直接上例子: 1.项目结构: 2.具体代码及配置 User.java package com.mybatis.bean; public class User { private int id; pri ...

  6. ASP.NET学习笔记(2)——用户增删改查

    说明(2017-7-4 11:48:50): 1. index.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transition ...

  7. Mysql入门-对表数据的增删改查

    这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mysql的时候, ...

  8. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

  9. GZFramwork数据库层《二》单据表增删改查(自动生成单据号码)

    运行效果: 使用代码生成器(GZCodeGenerate)生成tb_EmpLeave的Model 生成器源代码下载地址: https://github.com/GarsonZhang/GZCodeGe ...

随机推荐

  1. HoloLens开发手记 - 测试 Testing

    测试HoloLens应用的做法和测试Windows应用很类似.所有常规的内容都应该被考虑在内(功能.互操作性.性能.安全性.可靠性等等),然而有些特性是HoloLens特有的,在PC或者手机上无法测试 ...

  2. (十七)迭代器模式详解(foreach的精髓)

    作者:zuoxiaolong8810(左潇龙),转载请注明出处,特别说明:本博文来自博主原博客,为保证新博客中博文的完整性,特复制到此留存,如需转载请注明新博客地址即可. 各位好,很久没以LZ的身份和 ...

  3. [HDU5903]Square Distance(DP)

    题意:给一个字符串t ,求与这个序列刚好有m个位置字符不同的由两个相同的串拼接起来的字符串 s,要求字典序最小的答案. 分析:按照贪心的想法,肯定在前面让字母尽量小,尽可能的填a,但问题是不知道前面填 ...

  4. 匈牙利算法(codevs2776)

    type node=^link; link=record des:longint; next:node; end; var n,m,i,t,num:longint; p:node; nd:..] of ...

  5. Google 面试

    坚持完成这套学习手册,你就可以去 Google 面试了 系统 指针 value Google 面试 阅读10266   本文为掘金投稿,译文出自:掘金翻译计划 原文地址:Google Intervie ...

  6. redis入门配置

    简介: Redis是Nosql中比较出名的,分布式数据库缓存,提升相应的速度,降低对数据库的访问! Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,(永久 ...

  7. 一个奇怪的MySQL错误返回

    (0, '') python查询结果,乍一看还以为是下标出错了 一番调试,发现是因为 mysql数据库连接关闭上出了错. 结尾 在对数据库进行操作的时候要注意连接的开启和关闭动作规范

  8. Failed to execute goal org.codehaus.cargo:cargo-maven2-plugin:1.2.3:run (default-cli) on project Maven_WebTest: Execution default-cli of goal org.codehaus.cargo:cargo-maven2-plugin:1.2.3:run failed: C

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  9. IOS_SearchBar搜索栏及关键字高亮

    搜索框的效果演示: 这个就是所谓的搜索框了,那么接下来我们看看如何使用代码来实现这个功能. 我所使用的数据是英雄联盟的英雄名单,是一个JSON数据的txt文件, JSON数据的处理代码如下所示: ? ...

  10. linux基础-第十五单元 软件包的管理

    使用RPM安装及移除软件 什么是RPM rpm的文件名 rpm软件安装与移除工作中经常使用的选项 查看RPM软件包中的信息 查询已安装的软件包信息 RPM包的属性依赖性问题 什么是RPM包的属性依赖性 ...