• Web基础配置篇(四): Mysql的配置及使用
    date_range 2019-07-08 10:44:35
    folder Web基础
    person 陈付菲 公开
    thumb_up 点赞3
    remove_red_eye 围观527

    Web基础配置篇(四): Mysql的配置及使用

    一、概述

    MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。

    关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织

    优点:

    • 1、易于维护:都是使用表结构,格式一致;
    • 2、使用方便:SQL语言通用,可用于复杂查询;
    • 3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。

    缺点:

    • 1、读写性能比较差,尤其是海量数据的高效率读写;
    • 2、固定的表结构,灵活度稍欠;
    • 3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。

    非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。

    优点:

    • 1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。
    • 2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;
    • 3、高扩展性;
    • 4、成本低:nosql数据库部署简单,基本都是开源软件。

    缺点:

    • 1、不提供sql支持,学习和使用成本较高;
    • 2、无事务处理;
    • 3、数据结构相对复杂,复杂查询方面稍欠。

    Mysql属于关系型数据库。Oracle已经收购了Mysql,然后Mysql不免费了,当然社区版还是免费的。

    如果大家正在寻找一个java的学习环境,或者在开发中遇到困难,可以 加入我们的java学习圈,点击即可加入 ,共同学习,节约学习时间,减少很多在学习中遇到的难题。

    二、Mysql安装

    需要到Mysql官方网站下载:https://dev.mysql.com/downloads/mysql/.

    选择需要的版本下载

    2.1 windows下载启动

    直接下载安装版吧,毕竟mysql一般都是安装在linux的,windows上一般自己用的:https://dev.mysql.com/downloads/windows/installer/8.0.html

    在这里插入图片描述

    跟着提示一路走下去,会让你填端口、用户名密码这些。安装完成后,用navicat(可以下载Navicat for MySQL)测试下就行了。

    在这里插入图片描述

      1. 可以使用navicat添加数据库。
      1. 可以使用navicat添加表和数据

    2.2 Linux下载启动

    这里只说yum安装。

    2.2.1 安装

    yum install -y mysql-server mysql mysql-devel

    2.2.2 启动

    service mysqld start

    2.2.3 设置root

    mysqladmin -u root password '123456'

    2.2.4 登录

    mysql -u root -p

    2.2.5 添加数据库

    create database if not exists cff default character set utf8;

    2.2.6 添加用户并授权
    create user  cff  IDENTIFIED by '123456';
    GRANT ALL ON imdb.* to cff;

    三、Mysql常用命令

    尽量不要在命令行写sql语句,没其他意思,除非你时间多,眼神好。

    所以一般将sql写好贴过去,或者用客户端工具去执行sql。比如navicat。如果自己想写一个,那也是分分钟的,比如java,只要用jdbc就可以了。

    3.1 非常规命令

    显示数据库列表:show databases;

    切换到数据库cff:USE cff;

    显示表列表:show tables;

    显示当前数据库:select database();

    删除数据库cff:drop database cff;

    显示数据库版本:select version();

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

    3.2 表相关

    创建表t_user_info:

    create table t_user_info(
     id int(4) not null primary key auto_increment,
     name char(20) not null,
     type int(4) not null default '0');

    删除表t_user_info:drop table t_user_info;

    修改表名t_user_info 为t_pomit_info:rename table t_user_info to t_pomit_info;

    表t_user_info中添加了一个字段flag,类型为int(4),默认值为0:alter table t_user_info add flag int(4) default '0'

    删除表t_user_info 的flag字段:MySQL ALTER TABLE t_user_info DROP flag;

    3.2 常规的CRUD

    新增数据:

    insert into t_user_info values(1,'cff',100),(2,'test',101);

    查询数据:

    select * from t_user_info;
    
    select * from t_user_info where type = 100;
    
    select name from t_user_info where type = 100 limit 0,2;
    
    select * from t_user_info where type = 100 order by id asc limit 0,2;
    
    select * from t_user_info group by type;

    更新数据:

    update t_user_info set name='gg' where id=1;

    删除数据:

    delete from t_user_info where id=1;

    四、索引相关

    增加普通索引:

    alter table t_user_info add index inx_name(name);

    增加唯一索引:

    alter table t_user_info add unique inx_name(name);

    删除索引:

    alter table t_user_info drop index inx_name;

    索引的一些使用规则,数据库SQL优化总结:

    https://www.pomit.cn/p/168709297418496

    五、数据库备份

    导出数据库cff,用户为root,密码为123456,输出文件为outfile_name.sql:

    mysqldump -u root -p123456 cff > outfile_name.sql

    导出数据库cff的表t_user_info,用户为root,密码为123456,输出文件为outfile_name.sql:

    mysqldump -u root -p123456 cff t_user_info > outfile_name.sql

    导出数据库cff,用户为root,密码为123456,输出文件为outfile_name.sql,不带数据,只有结构:

    mysqldump -u root -p123456 -d cff > outfile_name.sql

    导出数据库cff,用户为root,密码为123456,输出文件为outfile_name.sql,设置编码集:

    mysqldump -u root -p123456 –default-character-set=latin1 –set-charset=gbk –skip-opt cff > outfile_name.sql

    Mysql数据库简单的定时备份:https://www.pomit.cn/p/173960842723584

评论列表
mode_edit