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的学习环境,或者在开发中遇到困难,可以<a
href="https://jq.qq.com/?_wv=1027&k=52sgH1J"
target="_blank">
加入我们的java学习圈,点击即可加入
</a>
,共同学习,节约学习时间,减少很多在学习中遇到的难题。**
二、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)测试下就行了。
在这里插入图片描述
-
- 可以使用navicat添加数据库。
-
- 可以使用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;
代码语言:javascript复制### 三、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');
代码语言:javascript复制删除表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);```
代码语言:txt复制查询数据:
```javascript
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;
代码语言:txt复制
更新数据:
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://cloud.tencent.com/developer/article/1505152五、数据库备份导出数据库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://cloud.tencent.com/developer/article/1505144