忘记不再是问题: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

相关文章

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

MySQL错误代码2058和2059的解决办法

《MySQL错误代码2058和2059的解决办法》:本文主要介绍MySQL错误代码2058和2059的解决办法,2058和2059的错误码核心都是你用的客户端工具和mysql版本的密码插件不匹配,... 目录1. 前置理解2.报错现象3.解决办法(敲重点!!!)1. php前置理解2058和2059的错误