MySQL使用

Posted 周先森

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL使用相关的知识,希望对你有一定的参考价值。

 

 

 

 

 

 

mysql

目录

Mysql    1

数据库简介    1

E-R模型    1

三范式    1

基本使用    1

安装    2

管理服务    2

允许远程连接    2

数据完整性    2

字段类型    3

约束    3

使用图形窗口连接    3

数据库操作    4

表操作    5

数据操作    6

逻辑删除    7

使用命令连接    7

远程连接    8

数据库操作    9

表操作    9

数据操作    10

备份与恢复    11

总结    11

查询    11

条件    11

比较运算符    12

逻辑运算符    12

模糊查询    12

范围查询    13

空判断    13

优先级    14

聚合    14

分组    14

分组后的数据筛选    15

对比where与having    15

排序    15

分行    16

示例:分页    16

总结    17

高级    17

简介    17

关系    17

外键    18

外键的级联操作    19

连接    19

连接查询    20

练习    20

自关联    21

子查询    22

内置函数    22

字符函数    22

数学函数    23

日期时间函数    24

视图    25

事务    26

示例1    26

示例2    27

总结    27

练习    28

 

数据库简介

  • 人类在进化的过程中,创造了数字、文字、符号等来进行数据的记录,但是承受着认知能力和创造能力的提升,数据量越来越大,对于数据的记录和准确查找,成为了一个重大难题
  • 计算机诞生后,数据开始在计算机中存储并计算,并设计出了数据库系统
  • 数据库系统解决的问题:持久化存储,优化读写,保证数据的有效性
  • 当前使用的数据库,主要分为两类
  • 文档型,如sqlite,就是一个文件,通过对文件的复制完成数据库的复制
  • 服务型,如mysqlpostgre,数据存储在一个物理文件中,但是需要使用终端以tcp/ip协议连接,进行数据库的读写操作

    E-R模型

  • 当前物理的数据库都是按照E-R模型进行设计的
  • E表示entry,实体
  • R表示relationship,关系
  • 一个实体转换为数据库中的一个表
  • 关系描述两个实体之间的对应规则,包括
  • 一对一
  • 一对多
  • 多对多
  • 关系转换为数据库表中的一个列 *在关系型数据库中一行就是一个对象

    三范式

  • 经过研究和对使用中问题的总结,对于设计数据库提出了一些规范,这些规范被称为范式
  • 第一范式(1NF):列不可拆分
  • 第二范式(2NF):唯一标识
  • 第三范式(3NF):引用主键
  • 说明:后一个范式,都是在前一个范式的基础上建立的

    基本使用

     

    安装

  • 安装

    sudo apt-get install mysql-server mysql-client

    然后按照提示输入

    管理服务

  • 启动

    service mysql start

  • 停止

    service mysql stop

  • 重启

    service mysql restart

     

    允许远程连接

  • 找到mysql配置文件并修改

    sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf

    bind-address=127.0.0.1注释

  • 登录mysql,运行命令

    grant all privileges on *.* to \'root\'@\'%\' identified by \'mysql\' with grant option;

    flush privileges;

  • 重启mysql

    数据完整性

  • 一个数据库就是一个完整的业务单元,可以包含多张表,数据被存储在表中
  • 在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候,为表添加一些强制性的验证,包括数据字段的类型、约束

     

    字段类型

  • mysql中包含的数据类型很多,这里主要列出来常用的几种
  • 数字:int,decimal
  • 字符串:varchar,text
  • 日期:datetime
  • 布尔:bit

    约束

  • 主键primary key
  • 非空not null
  • 惟一unique
  • 默认default
  • 外键foreign key

     

    使用图形窗口连接

  • 下发windowsnavicat
  • 点击"连接"弹出窗口,按照提示填写连接信息,如下图

  • 连接成功后,会在连接名称下面显示出当前的数据库
  • 双击选中数据库,就可以编辑此数据库
  • 下次再进入此软件时,通过双击完成连接、编辑操作

    数据库操作

  • 在连接的名称上右击,选择"新建数据库",弹出窗口,并按提示填写

    • 在数据库上右击,选择"删除数据库"可以完成删除操作

     

    表操作

  • 当数据库显示为高亮时,表示当前操作此数据库,可以在数据中创建表
  • 一个实体对应一张表,用于存储特定结构的数据
  • 点击"新建表",弹出窗口,按提示填写信息

     

  • 主键的名称一般为id,设置为int型,无符号数,自动增长,非空
  • 自动增长表示由mysql系统负责维护这个字段的值,不需要手动维护,所以不用关心这个字段的具体值
  • 字符串varchar类型需要设置长度,即最多包含多少个字符
  • 点击"添加栏位",可以添加一个新的字段
  • 点击"保存",为表定义名称

    数据操作

  • 表创建成功后,可以在右侧看到,双击表打开新窗口,如下图

  • 在此窗口中可以增加、修改、删除数据

    逻辑删除

  • 对于重要数据,并不希望物理删除,一旦删除,数据无法找回
  • 一般对于重要数据,会设置一个isDelete的列,类型为bit,表示逻辑删除
  • 大于大量增长的非重要数据,可以进行物理删除
  • 数据的重要性,要根据实际开发决定

    使用命令连接

  • 命令操作方式,在工作中使用的更多一些,所以要达到熟练的程度
  • 打开终端,运行命令

    mysql -uroot -p

    回车后输入密码,当前设置的密码为mysql

  • 连接成功后如下图

  • 退出登录

    quitexit

  • 退出成功后如下图

  • 登录成功后,输入如下命令查看效果

    查看版本:select version();

    显示当前时间:select now();

  • 注意:在语句结尾要使用分号;

    远程连接

  • 一般在公司开发中,可能会将数据库统一搭建在一台服务器上,所有开发人员共用一个数据库,而不是在自己的电脑中配置一个数据库
  • 运行命令

    mysql -hip地址 -uroot -p

  • -h后面写要连接的主机ip地址
  • -u后面写连接的用户名
  • -p回车后写密码

    数据库操作

  • 创建数据库

    create database 数据库名 charset=utf8;

  • 删除数据库

    drop database 数据库名;

  • 切换数据库

    use 数据库名;

  • 查看当前选择的数据库

    select database();

    表操作

  • 查看当前数据库中所有表

    show tables;

  • 创建表
  • auto_increment表示自动增长
  • create table 表名(列及类型);
  • 如:
  • create table students(
  • id int auto_increment primary key,
  • sname varchar(10) not null
  • );
  • 修改表

    alter table 表名 add|change|drop 列名 类型;

    如:

    alter table students add birthday datetime;

  • 删除表

    drop table 表名;

  • 查看表结构

    desc 表名;

  • 更改表名称

    rename table 原表名 to 新表名;

  • 查看表的创建语句

    show create table \'表名\';

    数据操作

  • 查询

    select * from 表名

  • 增加

    全列插入:insert into 表名 values(...)

    缺省插入:insert into 表名(1,...) values(1,...)

    同时插入多条数据:insert into 表名 values(...),(...)...;

    insert into 表名(1,...) values(1,...),(1,...)...;

  • 主键列是自动增长,但是在全列插入时需要占位,通常使用0,插入成功后以实际数据为准
  • 修改

    update 表名 set 1=1,... where 条件

  • 删除

    delete from 表名 where 条件

  • 逻辑删除,本质就是修改操作update

    alter table students add isdelete bit default 0;

    如果需要删除则

    update students isdelete=1 where ...;

     

    备份与恢复

    数据备份

  • 进入超级管理员

    sudo -s
    

  • 进入mysql库目录

    cd /var/lib/mysql
    

  • 运行mysqldump命令

    mysqldump –uroot –p 数据库名 > ~/Desktop/备份文件.sql;
    

    按提示输入mysql的密码
    							

    数据恢复

  • 连接mysqk,创建数据库
  • 退出连接,执行如下命令

    mysql -uroot –p 数据库名 < ~/Desktop/备份文件.sql
    

    根据提示输入mysql密码
    							

     

    总结

  • 数据库解决的问题,E-R模型,三范式
  • 图形界面操作数据库、表、数据
  • 命令行操作数据库、表、数据

    查询

    条件

  • 使用where子句对表中的数据筛选,结果为true的行会出现在结果集中
  • 语法如下:

    select * from 表名 where 条件;

    比较运算符

  • 等于=
  • 大于>
  • 大于等于>=
  • 小于<
  • 小于等于<=
  • 不等于!=<>
  • 查询编号大于3的学生

    select * from students where id>3;
    

  • 查询编号不大于4的科目

    select * from subjects where id<=4;
    

  • 查询姓名不是"黄蓉"的学生

    select * from students where sname!=\'黄蓉\';
    

  • 查询没被删除的学生

    select * from students where isdelete=0;
    						

    逻辑运算符

  • and
  • or
  • not
  • 查询编号大于3的女同学

    select * from students where id>3 and gender=0;
    

  • 查询编号小于4或没被删除的学生

    select * from students where id<4 or isdelete=0;
    						

    模糊查询

  • like
  • %表示任意多个任意字符
  • _表示一个任意字符
  • 查询姓黄的学生

    select * from students where sname like \'%\';
    

  • 查询姓黄并且名字是一个字的学生

    select * from students where sname like \'_\';
    

  • 查询姓黄或叫靖的学生

    select * from students where sname like \'%\' or sname like \'%%\';
    							

    范围查询

  • in表示在一个非连续的范围内
  • 查询编号是138的学生

    select * from students where id in(1,3,8);
    

  • between ... and ...表示在一个连续的范围内
  • 查询学生是38的学生

    select * from students where id between 3 and 8;
    

  • 查询学生是38的男生

    select * from students where id between 3 and 8 and gender=1;
    						

     

    空判断

  • 注意:null\'\'是不同的
  • 判空is null
  • 查询没有填写地址的学生

    select * from students where hometown is null;
    

  • 判非空is not null
  • 查询填写了地址的学生

    select * from students where hometown is not null;
    

  • 查询填写了地址的女生

    select * from students where hometown is not null and gender=0;
    

    优先级

  • 小括号,not,比较运算符,逻辑运算符