忘记不再是问题:MySQL关键知识点速查

2024-04-30 01:04

本文主要是介绍忘记不再是问题:MySQL关键知识点速查,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • MySQL备忘录
  • 内容
    • 连接MYSQL
    • 创建和展示数据库
    • 创建表
    • 修改表
    • 查询
    • 聚合与分组
    • 插入数据
    • 更新数据
    • 删除数据
    • 类型强制转换
  • 更多内容


MySQL备忘录

做项目时,可能需要快速获取MySQL的使用方法,比如语法规则和函数用法。这正是备忘单的用途。

这里总结了一份两页纸的MySQL备忘单(点击下载),效果如下:
在这里插入图片描述
在这里插入图片描述
这份MySQL备忘单具有以下特点:

  • 整理提炼了最常用的语句和函数用法,并配有典型例子
  • 通过颜色突出关键字和函数,重点一目了然
  • 做了分类,通过标题可以快速查找内容
  • 按照A4纸排版,方便打印

以下是MySQL备忘录内容摘要。


内容

连接MYSQL

使用 MySQL 命令行客户端连接 MySQL server

MySQL会提示输入密码: mysql -u [username] -p

连接 MySQL server 时指定数据库:

mysql -u [username] -p [database]

使用 mysqldump工具导出数据:

mysqldump -u [username] -p
database] > data_backup.sql

退出客户端:

quit or exit

打印命令完整清单

help

创建和展示数据库

创建一个数据库:

CREATE DATABASE zoo;

展示所有数据库:

SHOW DATABASES;

使用指定数据库:

USE zoo;

删除指定数据库:

DROP DATABASE zoo;

展示数据库中的所有表:

SHOW TABLES;

展示指定表的详细信息

DESCRIBE animal; -- 输出内容包含 column names, data types, default values等等.

创建表

创建一张表:

CREATE TABLE habitat (
id INT,
name VARCHAR(64)
);

id作为AUTO_INCREMENT自增列。自增列必须是主键或唯一键:

CREATE TABLE habitat (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(64)
);

创建一张拥有外键的表:

CREATE TABLE animal (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(64),
species VARCHAR(64),
age INT,
habitat_id INT,
FOREIGN KEY (habitat_id)
REFERENCES habitat(id)
);

修改表

修改表名:

ALTER TABLE animal RENAME pet;

表增加一列:

ALTER TABLE animal
ADD COLUMN name VARCHAR(64);

修改列名:

ALTER TABLE animal
RENAME COLUMN id TO identifier;

修改列的数据类型:

ALTER TABLE animal
MODIFY COLUMN name VARCHAR(128);

删除列:

ALTER TABLE animal
DROP COLUMN name;

删除表:

DROP TABLE animal;

查询

单表查询例子:

SELECT species, AVG(age) AS average_age
FROM animal
WHERE id != 3
GROUP BY species
HAVING AVG(age) > 3
ORDER BY AVG(age) DESC;

多表查询例子:

SELECT city.name, country.name
FROM city
[INNER | LEFT | RIGHT] JOIN country
ON city.country_id = country.id;

使用 +, -, *, / 进行数学计算。
例如,计算一周有多少秒:

SELECT 60 * 60 * 24 * 7; -- result: 604800

聚合与分组

  • AVG(expr) − 组内expr的平均值
  • COUNT(expr) − 组内expr值的数量
  • MAX(expr) − 组内expr的最大值
  • MIN(expr) − 组内expr的最小值
  • SUM(expr) − 组内expr值的累加和

计算表的行数:

SELECT COUNT(*)
FROM animal;

计算列的非NULL值数量:

SELECT COUNT(name)
FROM animal;

计算列的唯一值数量:

SELECT COUNT(DISTINCT name)
FROM animal;

分组

按 species 分组计算 animals 的数量:

SELECT species, COUNT(id)
FROM animal
GROUP BY species;

分组计算 animal 的平均、最小和最大年龄:

SELECT habitat_id, AVG(age),
MIN(age), MAX(age)
FROM animal
GROUP BY habitat_id;

插入数据

使用INSERT语句向表中插入数据:

INSERT INTO habitat VALUES
(1, 'River '),
(2, 'Forest ');

向指定列插入数据,未指定的列使用默认值或NULL填充:

INSERT INTO habitat (name) VALUES
( 'Savanna ');

更新数据

使用UPDATE语句更新表的数据:

UPDATE animal
SET
species = 'Duck ',
name = 'Quack '
WHERE id = 2;

删除数据

使用DELETE语句删除表的数据:

DELETE FROM animal
WHERE id = 1;

这样会删除所有命中的行,使用TRUNCATE语句删除所有行:

TRUNCATE TABLE animal;

类型强制转换

使用CAST()函数实现数据类型转换。

MySQL中,可以转换以下数据类型:

CHAR NCHAR BINARY DATE DATETIME
DECIMAL DOUBLE FLOAT REAL SIGNED
UNSIGNED TIME YEAR JSON spatial_type

将 number 转换为 signed integer:

SELECT CAST(1234.567 AS signed);
-- result: 1235

将列转换为double:

SELECT CAST(column AS double);

更多内容

剩余内容这里就不一一列举了,大家可以下载后查看。


如果喜欢这篇文章,请不要忘记关注、点赞和收藏哦!
您的鼓励将是我创作的最大动力!

这篇关于忘记不再是问题:MySQL关键知识点速查的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/947598

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID