mysql user表_Web基础配置篇(四): Mysql的配置及使用

b76655e98d582a9b1cc2bd8bce22a574.png

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不免费了,当然社区版还是免费的。

首发地址: 品茗IT-首发

如果大家正在寻找一个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

ec72e57bbbb7c374c66f3e9cf925f88f.png

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

996e4d3462b323fff96a36ad2b534bbc.png
  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

快速构建项目

Spring组件化构建

SpringBoot组件化构建

SpringCloud服务化构建

一键快速构建Spring项目工具

一键快速构建SpringBoot项目工具

一键快速构建SpringCloud项目工具

一站式Springboot项目生成

Mysql一键生成Mybatis注解Mapper

喜欢这篇文章么,喜欢就加入我们一起讨论Java Web吧!

3c34e484a5c964295970869f3f38e5cb.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值