2021最热门的20个数据库学习总结,你会用哪几个?

前言

数据库有多重要就不用我说了吧,懂的都懂!

今天就来看看2021最热门的数据库有哪些,该怎么学怎么用,文章开始之前先来看看这张图

从图中数据可以看到,稳居前三的 Oracle、MySQL 和 Microsoft SQL Server 分数出现了较大幅度的下跌,分别减少 46.82、34.14 和 7.33 分。

其中 SQL Server 分数已经连续下跌了两个月。若与去年同期的数据相比,三者下跌的分数平均已达到 64 分。

后起之秀 PostgreSQL 和 MongoDB 依旧保持着稳步上升的趋势,分数与上个月相比有小幅度增加,与去年同期相比也平均增加了 40 分左右。

这个系列主要讲一讲常年混迹前列的三大数据库——即Oracle、MySQL 和 Microsoft SQL Server该怎么学习,学习资料也给大伙整理好了,需要的可以直接点击领取。

篇幅所限,本文就先讲一下MySQL,有时间再发文讲讲其他的数据库,大伙感兴趣的话可以关注一波我

好了,话不多说,坐稳扶好,发车喽!

MySQL

概述

为什么要学数据库

  • 大数据时代,所有最后落地最普遍的便是数据库
  • 数据库是所有软件体系中最核心的存在

什么是数据库

数据库——DataBase——DB,数据仓库,用于存储和管理数据。

数据库分类

关系型数据库——SQL
  • MySQL,Oracle,Sql Server,DB2,SQLlite
  • 通过表和表、行与列之间的关系进行数据存储
非关系型数据库——NoSQL
  • Redis,MongoDB
  • 存储的是键值对。

DBMS——数据库管理系统——Database Management System

  • 数据库管理软件
  • MySQL是数据库管理系统

MySQL简介

稳定版本:5.7 ,8.0

体积小、速度快,成本底、招人成本底

安装建议:尽量不使用exe安装,因为删除麻烦,且会进注册表,尽可能使用压缩包安装

压缩包安装步骤

MySQL 8.0 压缩包版安装方法

  1. 解压
  2. 在环境变量path上配置解压后bin所在的目录地址
  3. 在mysql解压后目录下新建my.ini文件——配置文件
  4. 管理员模式运行cmd,用于注册注册表
  5. 初始化MySQL数据库 mysqld --initialize-insecure
  6. 安装MySQL服务 mysqld install
  7. 启动MySQL服务 net start mysql
  8. 跳过登录密码验证注释掉 #skip-grant-tables
  9. 停止MySQL服务 net stop mysql

配置文件如下:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
# 设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=D:\Program Files (x86)\mysql\mysql-8.0.19-winx64  
# 设置mysql数据库的数据的存放目录,数据库会自动生成,不需要我们创建文件夹
datadir= D:\Program Files (x86)\mysql\mysql-8.0.19-winx64\data
# 允许最大连接数
max_connections=20
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 跳过登录密码验证 在修改完密码后要把这句注释掉
#skip-grant-tables
skip-grant-tables

修改root密码
mysql 5.7
update mysql.user set password=PASSWORD('123456')where User='root';
flush privileges;

mysql 8.0
alter user 'root'@'localhost' identified by '123456'; 

#注意-p后不能加空格直接输入密码
mysql -u root -p123456
mysql -u root -p
#再输入密码

SQLyog
SQLyog验证码

sqlyog验证码.png

SQLyog/Navicat

可以查看历史执行记录,包括创建表,数据库等记录,比navicat详细。

sc delete mysql 清空服务,即删除mysql

Mysql定义结构

创建数据库

默认创建数据库字符集编码和排序规则如下

创建数据库.png

创建表

创建表.png

连接数据库

当执行命令行连接数据库报错'mysql' 不是内部或外部命令,也不是可运行的程序时,是因为我们没有配置好mysql的环境变量,这时候就需要我们往path上添加mysql的安装地址到bin文件夹路径到path上。

-- 在客户端查看mysql安装目录的语句
show variables like "%char%";

mysql配置环境变量.png

#有以下两种命令行连接数据库的方法,第一种需要我们回车后输入密码
mysql -u root -p
mysql -u root -p123456

命令行执行sql语句注意事项

命令行注意事项.png

基本数据库连接操作
-- 5.7.29-log 查看mysql版本
SELECT VERSION();

-- 创建数据库
CREATE DATABASE `my_test` CHARACTER SET utf8 COLLATE utf8_general_ci;
-- 第二种
CREATE DATABASE `my_test` CHARSET= utf8 COLLATE utf8_general_ci;

-- 展示所有的数据库
SHOW DATABASES;

-- 切换数据库
USE school;

-- 创建表sql 我们一般通过navicat等定义创建表,上生产时再执行创建表的sql语句
CREATE TABLE `t_student` (
  `id` bigint(10) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `name` varchar(30) NOT NULL COMMENT '学生姓名',
  `age` int(3) NOT NULL COMMENT '学生年龄',
  `create_user` varchar(30) DEFAULT NULL COMMENT '创建人',
  `crreate_tim` datetime DEFAULT NULL COMMENT '创建时间',
  `update_user` varchar(30) DEFAULT NULL COMMENT '修改人',
  `update_time` datetime DEFAULT NULL COMMENT '修改时间',
  `delete_flag` tinyint(1) DEFAULT NULL COMMENT '是否删除 0-否 1-是',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='学生表';

-- 修改用户密码
USE mysql;
UPDATE user SET password=PASSWORD('123456') WHERE user='root';
-- 刷新权限
FLUSH PRIVILEGES;

show variables like "%char%";

-- 查看数据库所有的表
SHOW TABLES;

-- 查看数据库中指定表的表结构信息
DESCRIBE t_student;

-- 退出数据库连接
exit;

-- 单行注释

/*
多行
注释
*/

utf8和utf8mb4的区别

utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。 为了节省空间,一般情况下使用utf8也就够了。 但是为了获取更好的兼容性,应该总是使用 utf8mb4 而非 utf8. 对于 CHAR 类型数据,utf8mb4 会多消耗一些空间,根据 Mysql 官方建议,使用 VARCHAR 替代 CHAR。

参考

Mysql中的排序规则utf8_unicode_ci、utf8_general_ci的区别总结

首先,ci是 case insensitive, 即 “大小写不敏感”, a 和 A 会在字符判断中会被当做一样的; bin 是二进制, a 和 A 会别区别对待。所以我们在用sql进行匹配查找的时候,如果是ci,则无论大小写都可以匹配出来,而如果是utf8_bin中的bin是二进制,则会区分大小写,这时候就只能唯一匹配到精确的那个值。

参考

SQL语言分类

参考

DDL—— 数据定义语言DDL,(data definition language)

用来创建数据库中的各种对象-----表、视图,DDL操作是隐性提交的!不能rollback 。

CREATE,ALTER,DROP,TRUNCATE,COMMENT ,RENAME

DML—— 数据操纵语言(DML:Data Manipulation Language)

数据的增删改。

INSERT,UPDATE,DELETE,EXPLAIN, PLAN

DQL——数据查询语言(DQL: Data Query Language)

数据的查询

SELECT

DCL—— 数据库控制语言(Database Control Language)

用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句 。

GRANT,REVOKE

TCL——存储过程控制预言(Transaction Control Language)

数据库事务的控制语言。

COMMIT,SAVEPOINT,ROLLBACK,SET TRANSACTION

操作数据库

操作数据库> 操作数据库中的表> 操作数据库中的表的数据

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北游学Java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值