MySQL入门第一天——概述、数据表与约束操作
一、概述
1.安装
初学MySQL,我们下载msi的安装版:http://dev.mysql.com/downloads/file.php?id=457403
安装的过程文字简述可以参考之前随笔:http://www.cnblogs.com/jiangbei/p/6696202.html
图文安装推荐:http://www.jb51.net/article/96898.htm
如何启动:
开启——net start mysql (实际上,所有的windows服务都可以通过此指令进行启动:net start 服务名)
登陆——mysql -u -p进行登陆 (mysql -uroot -proot,直接-p回车将会提示输入密码而不必输入明文密码)
退出 ——exit或者quit (exit;)
关于cmd界面无法启动mysql:
1. 必须要使用管理员身份运行cmd程序
2. 如果下载MySQL5.7版本的,在windows服务上Mysql的名字默认是MySQL57,因此在cmd运行 net start/stop mysql 是无效的,必须改成 net start/stop mysql57才行
3.安装的时候没勾选开启命令行,导致Path路径中没有bin目录,解决办法如下:
右键点击“我的电脑”-“属性”-“高级”-“环境变量”-“系统 变量”-双击“Path”-将mysql的路径“D:wampbinmysqlmysql5.0.51bbin (这里假设您的MYSQL目录和我安装的一样,其实你定位到你的 MYSQL安装目录之后再找到bin目录就可以把全路径写上去了)”添加进去-“确定”
MySQL字符集修改:
show variables like 'character_set%';
mysql> set character_set_client=utf8;
Query OK, 0 rows affected (0.00 sec)
mysql> set character_set_connection=utf8;
Query OK, 0 rows affected (0.00 sec)
mysql> set character_set_database=utf8;
Query OK, 0 rows affected (0.00 sec)
mysql> set character_set_results=utf8;
Query OK, 0 rows affected (0.00 sec)
mysql> set character_set_server=utf8;
Query OK, 0 rows affected (0.00 sec)
mysql> set character_set_system=utf8;
Query OK, 0 rows affected (0.01 sec)
mysql> set collation_connection=utf8;
Query OK, 0 rows affected (0.01 sec)
mysql> set collation_database=utf8;
Query OK, 0 rows affected (0.01 sec)
mysql> set collation_server=utf8;
Query OK, 0 rows affected (0.01 sec)
登陆成功如下:

//mysql命令提示符的修改暂不展开
2.常用命令
常用系统表(查询表结构信息等):https://www.aliyun.com/jiaocheng/1398395.html

实例:

//记得打分号
语句规范:

3.操作数据库
1.创建数据库:(大括号必选,中括号可选)

实例:

//请尽量遵守语句规范
2.查看数据库列表:

实例:

3.修改数据库:

实例:

4.删除数据库

二、数据类型与数据表
1.数据类型
数字类型:

时间类型

字符类型

2.操作数据表
1.创建表

只复制表结构:
两种方法复制表结构:
1.create table B as select * from A where 1=2;
或者:
2.create table B like A;
实例:

2.查看表

实例:

删除表:
DROP TABLE [IF EXISTS] tb_name;

3.查看表结构

实例:

4.记录插入

实例:(省略字段时所有字段都要赋值)

5.记录查找

实例:(后续会有详细的查找补充)

6.空值与非空

实例:

7.自动编号

实例将与主键约束一同展示
8.主键约束
主键:唯一、非空、被引用

实例:


【推荐】可以统一在字段创建完成后创建主键约束(其他同理)
CREATE TABLE t1(
id int not null,
name char(20),
primary key (id)
);
9.唯一约束
只唯一、不非空

实例:

10.默认约束

实例:(性别为枚举类型)


三、约束与数据表操作
1.约束
更多CHECK级别约束参照W3school:http://www.w3school.com.cn/sql/sql_check.asp

//两个以上字段称为表级约束
1.外键约束

外键要求:

修改配置文件实现存储引擎的修改:

实例:(调了一下白底黑字和字体为宋体。)

创建外键:可以看到即使类型一致,有无符号位也会造成外键的创建失败


自动创建约束验证:

2.外键约束参照操作

实例:(其中 SHOW CREATE TABLE user就相当于可视化工具中的DDL)

//这里外键约束表示在父表中删除行时同时删除子表相应的行
实例:(先插父表,后插子表)

插入子表:这里有一条不符合条件的插入,这里主键也自动递增了

删除父表中的记录,发现子表中外键关联的相关记录:

当然,物理外键约束性是非常大的,这里我们常常使用的是逻辑外键,这样更加灵活
所谓的逻辑外键指的是就是我们在定义两张表的结构的时候,我们是按照存在的某种结构的方式去定义,但是不去使用FOREIGN KEY这个关键词来定义。
3.表级约束与列级约束

2.修改数据表
1.添加删除列

实例:不指定位置则默认最后

当然,添加多列也是可以的:

2.删除列

实例:

3.添加约束

实例:

其中CONTRAINT关键字是可选的,可以用来自定义约束名


实例:


完整外键相关约束,参见:https://www.cnblogs.com/love_study/archive/2010/12/02/1894593.html
实例:

约束/检验的DDL示例:

4.添加删除默认约束

实例:

5.删除约束

实例:(主键已经不是Id)


实例:(先查看约束,\G为以网格形式呈现),要删除约束需要知道约束的名字



实例:查看DDL可以看到有一个系统默认赋予我们的外键的名字:

实例:

6.修改列定义
列名字未出错,但列定义:包括列类型与位置等的修改

实例:

7.修改列名称
CHANGE不仅可以修改列名称,还可以修改列定义

实例:(TINYINT这里稍微注意下读音 ['taɪnɪ])

8.修改表名称

实例:

实际中请尽量减少列名称与表名称的修改!
MySQL入门第一天——概述、数据表与约束操作的更多相关文章
- MySQL(9):数据表的约束(列的属性)
1.首先我们看一下这个图: 1.NULL| not NULL是否为空 规定一个字段的值是否为NULL 2.Default value 字段默认值属性 常见的是一个字段不能为空,而且存在默认值 ...
- MySQL入门(4)——操作数据表
MySQL入门(4)--操作数据表 创建数据库 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] 数据库名 [(create_definition,...)] [tab ...
- MySQL学习笔记_4_MySQL创建数据表(下)
MySQL创建数据表(下) 五.数据表类型及存储位置 1.MySQL与大多数数据库不同,MySQL有一个存储引擎概念.MySQL可以针对不同的存储需求选择不同的存储引擎. 2. showengines ...
- mysql存储过程之游标遍历数据表
原文:mysql存储过程之游标遍历数据表 今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕 ...
- mysql(三) 数据表的基本操作操作
mysql(三) 数据表的基本操作操作 创建表,曾删改查,主键,外键,基本数据类型. 1. 创建表 create table 表名( 列名 类型 是否可以为空, 列名 类型 是否可以为空 )ENGIN ...
- C# 利用mysql.data 在mysql中创建数据库及数据表
C# 利用mysql.data 在mysql中创建数据库及数据表 using System; using System.Collections.Generic; using System.Linq; ...
- mysql 导入导出数据库、数据表的方法
mysql 导入导出数据库.数据表的方法. Linux操作系统中,均在控制台下操作.1,导入数据库:前提:数据库和数据表要存在(已经被创建)(1)将数据表 test_user.sql 导入到test ...
- MySQL 给已存在的数据表 增加字段和注释
MySQL 给已存在的数据表 增加字段和注释 问题描述 在开发一个系统的过程中,经常会遇到随着系统服务功能的扩展,或者服务之间的关联,需要适当的修改原有的表结构,比如,增加一些必要的字段. 示例:在已 ...
- MySQL(九)之数据表的查询详解(SELECT语法)一
这一篇是MySQL中的重点也是相对于MySQL中比较难得地方,个人觉得要好好的去归类,并多去练一下题目.MySQL的查询也是在笔试中必有的题目.希望我的这篇博客能帮助到大家! 重感冒下的我,很难受!k ...
随机推荐
- June 23rd 2017 Week 25th Friday
Life doesn't get easier, you just get stronger. 生活从未变得轻松,是你在一点一点变得坚强. So in the same way we can get ...
- plus.webview.create mui.openWindow区别是什么呢
create 只是创建这个webview,但是不显示,而且同一个页面.同一个id你甚至能重复创建多个(严重消耗性能,作死...),其实mui里面已经封装了这个方法 mui.preload(),并且 ...
- UML用例图间关系说明
用例间一般存在如下四种关系: 1."通信"关系(<<cmmunicate>>构造型): "通信"关系:使用实心的关联线或带<< ...
- su
参数选项:-,-l,--login 切换用户的同时,将用户的家目录.系统环境变量等重新按切换后的用户初始化.-c 向shell传递单个命令,仅希望在某个用户下执行命令,而不用直接切换到该用户下来操作. ...
- 使用Nginx 做负载均衡
Nginx可以作为一个非常高效的负载均衡系统,通过分发HTTP请求到多个应用服务器来提高整个系统的吞吐量,性能和可用性. 负载均衡的算法/机制 下面是Nginx支持的机制 轮询机制 轮询算法 最少连接 ...
- Linux Shell 编程 文件转置问题
给定一个文件 file.txt,转置它的内容. 你可以假设每行列数相同,并且每个字段由 ' ' 分隔. 示例: 假设 file.txt 文件内容如下: name age alice 21 ryan 3 ...
- 一段markdown编辑器代码研究
一段markdown编辑器代码研究 说明 代码在 https://github.com/dukeofharen/markdown-editor 之所以选择这个来分析是一方面是因为它的代码结构比较简单, ...
- ringMVC——redirect重定向跳转传值
spring MVC框架controller间跳转,需重定向.有几种情况:不带参数跳转,带参数拼接url形式跳转,带参数不拼接参数跳转,页面也能显示. 首先先来介绍一下不带参数的重定向: ...
- 简要的谈一谈我对CSS中长度单位的理解
CSS中的长度单位目前分为两种,分别是绝对长度和相对长度.绝对长度单位包括: in:英寸 cm:厘米 mm:毫米 pt:磅(1磅等于1/72英寸) pc:pica(1pica等于12磅) 以上五个就是 ...
- Xcode 7提示App Transport Security has blocked a cleartext HTTP (http://) resource load的解决办法
Xcode 7提示App Transport Security has blocked a cleartext HTTP (http://) resource load的解决办法 今天使用Xcod ...