MySQL知识点总结

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL知识点总结

1、初始MySQL

JavaEE:企业级开发 web

前端(页面:展示,数据!)

后台(连接点:连接数据库JDBC,连接前端(控制,控制试图跳转,和给前端传递数据))

数据库(存数据,TXT,Excel,Word)

只会写代码,学好数据库,基本混饭吃;

操作系统,数据结构与算法,当一个不错的程序猿!

离散数学,数字电路,体系结构,编译原理,实战经验,优秀程序猿

1.1、为什么学习数据库

1、岗位需求
2、现在的世界,大数据时代~,得数据者得天下
3、被迫需求:存数据
4、数据库是所有软件体系中最核心的存在 DBA

1.2、什么是数据库

数据库(DB DataBase)

概念:数据仓库,软件,安装在操作系统(windows,linux,mac.....)之上,SQL,可以存储大量数据。500万以内。

作用:存储数据,管理数据

1.3、数据库分类

关系型数据库:(SQL)

  • MySQL、Oracle、SQL Server,DB2、SQLlite
  • 通过表和表之间,行和列之间的关系进行数据的存储。学员表,考勤表..

非关系型数据库:(NoSQL)Not only SQL

  • Redis,MongoDB
  • 非关系型数据库,对象存储,通过对象的自身属性来决定。

    DBMS(数据库管理系统)

  • 数据库的管理软件,科学有效的管理我们的数据。维护和获取数据
  • MySQL,数据库管理系统!

1.4、MySQL

MySQL是一个关系型数据库管理系统

前世:瑞典MySQL AB公司

今生:属于Oracle旗下产品

MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一

开源的数据库软件~

体积小,速度快,总体应用成本低,招人成本比较低,所有人必须会

中小型网站、或者大型网站,集群

官网:https://www.mysql.com

5.7 稳
8.0 用的还不是很多

安装建议:
1、尽量不要使用exe,注册表
2、尽可能使用压缩包

1.5、安装MySQL

详细过程点这里
1.解压
2.把这个包放到自己的电脑环境目录下
3.配置环境变量
4.新建MySQL配置文件 ini结尾

[mysqld]
#目录一定要换成自己的
basedir=D:\MySQL5.7\mysql-5.7.19-winx64\
datadir=D:\MySQL5.7\mysql-5.7.19-winx64\data\
port=3307
skip-grant-tables

5.启动管理员模式下的cmd,运行所有的命令
6.安装MySQL服务
7.初始化数据库文件
8.启动MySQL,进去修改密码
9.进入MySQL通过命令行(-p后面不要加空格),修改密码(sql语句后面一定要加分号)

问题:

1、缺少组件 .dll
2、命令输出

sc delete mysql

1.6、安装SQLyog

1.无脑安装
2.注册
3.打开连接数据库
4.新建一个数据库 school
每一个sqlyog的执行操作,本质就是对应了一个sql,可以在软件的历史记录中查看
5.新建一张表 student

字段:id,name,age

在这里插入图片描述
6.查看表
7.自己尝试添加多条记录

1.7、连接数据库

命令行连接

mysql -u root -p123456 --连接数据库
update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost'; --修改用户密码
flush privileges; --刷新权限
------------------------------------------------
--所有的语句都使用分号结尾
show databases; --查看所有的数据库
mysql> use school;  --切换数据库
Database changed
show tables; --查看数据库中所有的表
describe student; --显示数据库中所有的表的信息
create database westos; --创建一个数据库
exit; --退出链接
--单行注释
/*(sql的多行注释)
hello
world
mysql
*/

数据库 xxx 语言 CRUD 增删改查! CV 程序猿 API程序猿 CRUD程序猿(业务)
DDL 定义
DML 操作
DQL 查询
DCL 控制

2、操作数据库 (了解)

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

MySQL语句不区分大小写

2.1、操作数据库

1、创建数据库

CREATE DATABASE (IF NOT EXISTS) westos;

2、删除数据库

DROP DATABASE (IF EXISTS) hello;

3、使用数据库

--tab键的上面,如果你的表名或者字段名是一个特殊字符,就需要带
USE `westos`

4、查看数据库

 SHOW DATABASES --查看所有的数据库

对比:sqlyog的可视化操作

2.2、数据库的列类型

数值
  • tinyint 十分小的数据 1个字节
  • smallint 较小的数据 2个字节
  • mediumint 中等大小的数据 3个字节
  • int 标准的整数 4个字节 常用的
  • bigint 较大的数据 8个字节
  • float 单精度浮点数 4个字节
  • double 双精度浮点数 8个字节
  • decimal 字符串形式的浮点数 金融计算的时候,一般使用
字符串
  • char 字符串固定大小的 0-255
  • varchar 可变字符串 0-65535
  • tinytext 微型文本 2^8-1
  • text 文本串 2^16-1
事件日期

java.util.Date

  • date YYYY-MM-DD,日期
  • time HH:mm:ss 时间格式
  • datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式
  • timestamp 时间戳 1970.1.1到现在的毫秒数!也较为常用
  • year 年份标识
null
  • 没有值,未知
  • ==注意,不要使用null进行运算,结果为null==

2.3、数据库的字段属性(重点)

Unsigned:

  • 无符号的整数
  • 声明了该列不能为负数

zerofill:

  • 0填充的
  • 不足的位数,使用0来填充,in(3),5,005

自增:

  • 通常理解为自增,自动在上一条记录的基础上+1(默认)
  • 通常用来设计唯一的住建~index,必须是整数类型
  • 可以自定义设置主键自增的起始值和步长

非空:

NUll 和 not null

  • 假设设置为not null,如果不给他赋值,就会报错
  • NUll,如果不填写值,默认就是null

默认:

  • 设置默认值
  • sex,默认值为男,如果不指定该列的值,则会有默认的值!

扩展:目前看看就行

/*每一个表都必须存在以下五个字段
id 主键
`version` 乐观锁
is_delete 伪删除
gmt_create 创建时间
gmt_update 修改时间
*/

2.4、创建数据库表

-- 目标:创建一个school数据库
-- 创建学生表(列,字段) 使用SQL创建
-- 学号int 登录密码varchar(20) 姓名,性别varchar(2),出生日期()
-- 注意点,使用英文(),表的名称 和 字段 尽量使用``括起来
-- AUTO_INCREMENT 自增
-- 字符串使用单引号括起来
-- 所有的语句后面加逗号 英文的 最后一个不用加
-- PRIMARY KEY 主键 一般一个表只有一个
CREATE DATABASE school
CREATE TABLE IF NOT EXISTS `student` (
    `id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
    `name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
    `pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
    `sex` VARCHAR(2) NOT NULL DEFAULT '女' COMMENT '性别',
    `birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
    `address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
    `email` VARCHAR(50) DEFAULT  NULL COMMENT '邮箱',
    PRIMARY KEY(id)
)ENGINE=INNODB DEFAULT CHARSET=utf8

格式:

create table[if not exists] `表名`(
`字段名` 列类型 [属性][索引][注释],
`字段名` 列类型 [属性][索引][注释],
.......
`字段名` 列类型 [属性][索引][注释],
)[表类型][字符集][注释]

常用命令

SHOW CREATE DATABASE school -- 查看创建数据库的语句
SHOW CREATE TABLE student -- 查看student数据表的定义语句
DESC student -- 显示表的结构

2.5、数据库表的类型

INNODB 默认使用
MYISAM 早些年使用

MYISAM INNODN
事务支持 不支持 支持
数据行锁定 不支持 支持
外键约束 不支持 支持
全文索引 支持 不支持
表空间大小 较小 较大,约为2倍

常规使用操作:

  • MYISAM 节约空间,速度较快
  • INNODB 安全性高,事务的处理,多表多用户操作
在物理空间存在的位置

所有的数据库文件都存在data目录下,一个文件夹就对应一个数据库
本质还是文件的存储
MySQL引擎在物理文件上的区别

  • INNODB在数据库表中只有一个*.frm文件,以及上级目录下的ipdata1文件
  • MYISAM对应文件

         ○*.frm     表结构定义文件
         ○*.MYD 数据文件(data)
         ○*.MYI   索引文件(index)
    
设置数据库表的字符集编码
charset=utf8

不设置的话,会是MySQL默认的字符集编码(不支持中文)

MySQL的默认编码是Latin1,不支持中文

在my.ini中配置默认的编码

character-set-server=utf8

2.6、修改和删除

修改
删除
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
关系型数据库 MySQL
【MySQL】——Select查询语句知识点练习(其一)
【MySQL】——Select查询语句知识点练习(其一)
|
6月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL LIKE 子句
总结 vue3 的一些知识点:MySQL LIKE 子句
|
6月前
|
安全 关系型数据库 MySQL
总结MySQL 的一些知识点:MySQL 排序(上)
总结MySQL 的一些知识点:MySQL 排序
|
6月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL NULL 值处理
总结 vue3 的一些知识点:MySQL NULL 值处理
|
6月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL 连接的使用
总结 vue3 的一些知识点:MySQL 连接的使用
|
关系型数据库 MySQL 数据库
关于mysql涉及到的知识点,C语言如何操作mysql
关于mysql涉及到的知识点,C语言如何操作mysql
|
存储 关系型数据库 MySQL
MySQL,其他部分知识点补充
MySQL,其他部分知识点补充
|
16天前
|
存储 Oracle 关系型数据库
[MySQL]知识点
本文详细介绍了MySQL中int族和char族数据类型的特点、存储范围及使用建议,以及text、blob类型和内置字符处理函数。文章强调了数据类型选择的重要性,并提供了多个实例帮助理解。
31 0
[MySQL]知识点
|
3月前
|
存储 关系型数据库 MySQL
mysql锁的知识点简述
了解和合理应用MySQL中的锁机制,对于设计高并发、高可用的数据库应用至关重要。在系统设计初期就要考量锁策略,根据实际使用场景灵活调整,以最小化锁竞争,提高事务处理速度。
57 0
|
5月前
|
SQL 关系型数据库 MySQL
Mysql从入门到精通——Mysql知识点总结(基础篇)
Mysql从入门到精通——Mysql知识点总结(基础篇)