当前位置:   article > 正文

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

2021年常用的数据库

前言

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

今天就来看看 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 安装,因为删除麻烦,且会进注册表,尽可能使用压缩包安装

压缩包安装步骤

  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

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

修改 root 密码

mysql 5.7

  1. update mysql.user set password=PASSWORD('123456')where User='root';
  2. flush privileges;

mysql 8.0

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

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

SQLyog

SQLyog 验证码

SQLyog/Navicat

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

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

Mysql 定义结构

创建数据库

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

创建表

连接数据库

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

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

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

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

基本数据库连接操作

 

  1. -- 5.7.29-log 查看mysql版本
  2. SELECT VERSION();
  3. -- 创建数据库
  4. CREATE DATABASE `my_test` CHARACTER SET utf8 COLLATE utf8_general_ci;
  5. -- 第二种
  6. CREATE DATABASE `my_test` CHARSET= utf8 COLLATE utf8_general_ci;
  7. -- 展示所有的数据库
  8. SHOW DATABASES;
  9. -- 切换数据库
  10. USE school;
  11. -- 创建表sql 我们一般通过navicat等定义创建表,上生产时再执行创建表的sql语句
  12. CREATE TABLE `t_student` (
  13. `id` bigint(10) NOT NULL AUTO_INCREMENT COMMENT 'id',
  14. `name` varchar(30) NOT NULL COMMENT '学生姓名',
  15. `age` int(3) NOT NULL COMMENT '学生年龄',
  16. `create_user` varchar(30) DEFAULT NULL COMMENT '创建人',
  17. `crreate_tim` datetime DEFAULT NULL COMMENT '创建时间',
  18. `update_user` varchar(30) DEFAULT NULL COMMENT '修改人',
  19. `update_time` datetime DEFAULT NULL COMMENT '修改时间',
  20. `delete_flag` tinyint(1) DEFAULT NULL COMMENT '是否删除 0-否 1-是',
  21. PRIMARY KEY (`id`)
  22. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='学生表';
  23. -- 修改用户密码
  24. USE mysql;
  25. UPDATE user SET password=PASSWORD('123456') WHERE user='root';
  26. -- 刷新权限
  27. FLUSH PRIVILEGES;
  28. show variables like "%char%";
  29. -- 查看数据库所有的表
  30. SHOW TABLES;
  31. -- 查看数据库中指定表的表结构信息
  32. DESCRIBE t_student;
  33. -- 退出数据库连接
  34. exit;
  35. -- 单行注释
  36. /*
  37. 多行
  38. 注释
  39. */

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 。

CREATEALTERDROP,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)

数据库事务的控制语言。

  1. COMMIT,SAVEPOINT,ROLLBACK,SET TRANSACTION

操作数据库

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

数据库操作示例

 

  1. - 创建数据库 IF NOT EXISTS 表示不存在则创建,存在则跳过
  2. CREATE DATABASE IF NOT EXISTS `my_test` CHARACTER SET utf8 COLLATE utf8_general_ci;
  3. -- 删除数据库
  4. DROP DATABASE IF EXISTS `my_test`;
  5. -- 使用数据库
  6. USE school;
  7. -- 查看数据库
  8. SHOW DATABASES;

数据库中表的列类型

数值类型

注:在金融等金额计算时,一般使用 decimal 来表示金额大小,因为使用 double 会有精度问题,而使用字符串形式的浮点数则可以完整得表示出金额的大小。

字符串

日期时间

注:yyyy-MM-dd HH:mm:ss 表示年月日时分秒。月:用 MM 大写表示是与时间单位的 mm 作为区别,而时:HH 用大写表示 24 小时制,用小写 hh 则是 12 小时制。

VARCHAR 和 TEXT 长度问题

VARCHAR :varchar 在 mysql 中满足最大行限制,也就是 65535(16k)字节,在 mysql 中使用 uft-8(mysql 中的 utf-8 和我们正 常的编码 utf-8 不同)字符集一个字符占用三个字节。

①使用 utf-8 字符编码集  varchar 最大长度是   (65535-1)/3=21844  个字符(由于会有 1 字节的额外占用空间开销, 所以减 1)。②使用 utf-8mb4 字符集(mysql 中 utf-8mb4 字符集也就是我们通常使用的 utf-8 字符集),mysql 中使用 utf8mb4 字符集一个字符占用 4 个字节,所以 varchar 最大长度是(65535-1)/4=16383 个字符(由于 1 字节额外占用空间开销,所以减 1)。

TEXT :最大限制是 64k, 采用 utf-8 字符集,(262144-1)/3=87381 个字符。采用 utf-8mb4 字符集,(262144-1)/4=

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/444817
推荐阅读
相关标签
  

闽ICP备14008679号