一、概述

  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入门第一天——概述、数据表与约束操作的更多相关文章

  1. MySQL(9):数据表的约束(列的属性)

    1.首先我们看一下这个图: 1.NULL| not NULL是否为空      规定一个字段的值是否为NULL 2.Default value 字段默认值属性 常见的是一个字段不能为空,而且存在默认值 ...

  2. MySQL入门(4)——操作数据表

    MySQL入门(4)--操作数据表 创建数据库 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] 数据库名 [(create_definition,...)] [tab ...

  3. MySQL学习笔记_4_MySQL创建数据表(下)

    MySQL创建数据表(下) 五.数据表类型及存储位置 1.MySQL与大多数数据库不同,MySQL有一个存储引擎概念.MySQL可以针对不同的存储需求选择不同的存储引擎. 2. showengines ...

  4. mysql存储过程之游标遍历数据表

    原文:mysql存储过程之游标遍历数据表 今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕 ...

  5. mysql(三) 数据表的基本操作操作

    mysql(三) 数据表的基本操作操作 创建表,曾删改查,主键,外键,基本数据类型. 1. 创建表 create table 表名( 列名 类型 是否可以为空, 列名 类型 是否可以为空 )ENGIN ...

  6. C# 利用mysql.data 在mysql中创建数据库及数据表

    C# 利用mysql.data 在mysql中创建数据库及数据表 using System; using System.Collections.Generic; using System.Linq; ...

  7. mysql 导入导出数据库、数据表的方法

    mysql 导入导出数据库.数据表的方法. Linux操作系统中,均在控制台下操作.1,导入数据库:前提:数据库和数据表要存在(已经被创建)(1)将数据表 test_user.sql 导入到test ...

  8. MySQL 给已存在的数据表 增加字段和注释

    MySQL 给已存在的数据表 增加字段和注释 问题描述 在开发一个系统的过程中,经常会遇到随着系统服务功能的扩展,或者服务之间的关联,需要适当的修改原有的表结构,比如,增加一些必要的字段. 示例:在已 ...

  9. MySQL(九)之数据表的查询详解(SELECT语法)一

    这一篇是MySQL中的重点也是相对于MySQL中比较难得地方,个人觉得要好好的去归类,并多去练一下题目.MySQL的查询也是在笔试中必有的题目.希望我的这篇博客能帮助到大家! 重感冒下的我,很难受!k ...

随机推荐

  1. June 23rd 2017 Week 25th Friday

    Life doesn't get easier, you just get stronger. 生活从未变得轻松,是你在一点一点变得坚强. So in the same way we can get ...

  2. plus.webview.create mui.openWindow区别是什么呢

      create 只是创建这个webview,但是不显示,而且同一个页面.同一个id你甚至能重复创建多个(严重消耗性能,作死...),其实mui里面已经封装了这个方法 mui.preload(),并且 ...

  3. UML用例图间关系说明

    用例间一般存在如下四种关系: 1."通信"关系(<<cmmunicate>>构造型): "通信"关系:使用实心的关联线或带<< ...

  4. su

    参数选项:-,-l,--login 切换用户的同时,将用户的家目录.系统环境变量等重新按切换后的用户初始化.-c 向shell传递单个命令,仅希望在某个用户下执行命令,而不用直接切换到该用户下来操作. ...

  5. 使用Nginx 做负载均衡

    Nginx可以作为一个非常高效的负载均衡系统,通过分发HTTP请求到多个应用服务器来提高整个系统的吞吐量,性能和可用性. 负载均衡的算法/机制 下面是Nginx支持的机制 轮询机制 轮询算法 最少连接 ...

  6. Linux Shell 编程 文件转置问题

    给定一个文件 file.txt,转置它的内容. 你可以假设每行列数相同,并且每个字段由 ' ' 分隔. 示例: 假设 file.txt 文件内容如下: name age alice 21 ryan 3 ...

  7. 一段markdown编辑器代码研究

    一段markdown编辑器代码研究 说明 代码在 https://github.com/dukeofharen/markdown-editor 之所以选择这个来分析是一方面是因为它的代码结构比较简单, ...

  8. ringMVC——redirect重定向跳转传值

    spring MVC框架controller间跳转,需重定向.有几种情况:不带参数跳转,带参数拼接url形式跳转,带参数不拼接参数跳转,页面也能显示.     首先先来介绍一下不带参数的重定向:    ...

  9. 简要的谈一谈我对CSS中长度单位的理解

    CSS中的长度单位目前分为两种,分别是绝对长度和相对长度.绝对长度单位包括: in:英寸 cm:厘米 mm:毫米 pt:磅(1磅等于1/72英寸) pc:pica(1pica等于12磅) 以上五个就是 ...

  10. 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 ...