SQLyou基础用法讲解

news/2025/1/16 5:54:27/

文章目录

    • 1. 数据定义语言 (DDL)
    • 2. 数据操作语言 (DML)
      • 插入数据
      • 批量插入数据
      • 更新数据
      • 条件更新
      • 删除数据
      • 条件删除
    • 3. 数据查询语言 (DQL)
      • 查询数据
      • 查询所有数据
      • 使用排序
      • 使用聚合函数
      • 分组查询
      • 使用 HAVING 子句
    • 4. 事务
    • 5. 索引
      • 创建索引
      • 唯一索引
      • 删除索引
    • 6. 视图
    • 7. 存储过程
    • 总结


SQLyog__8">SQLyog 基础知识讲解

SQLyog 是一款强大的 MySQL 数据库管理工具,提供了直观的图形用户界面 (GUI),帮助用户简化数据库管理和操作。以下内容将详细讲解 SQLyog 中的基础知识,并对数据定义语言 (DDL)、数据操作语言 (DML)、数据查询语言 (DQL) 以及索引、事务、视图和存储过程等内容进行扩展和注释。


1. 数据定义语言 (DDL)

DDL 用于定义和管理数据库结构,如创建、修改和删除数据库和表。

创建数据库

sql">CREATE DATABASE my_database;
  • 解释: 创建一个名为 my_database 的新数据库,存放数据表及其数据。

创建表

sql">CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY,  -- 自动递增的整型主键,每条记录唯一username VARCHAR(50) NOT NULL,      -- 用户名,长度不超过50个字符,不能为空email VARCHAR(100) NOT NULL,        -- 邮箱,长度不超过100个字符,不能为空created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP  -- 创建时间,默认是当前时间
);
  • 解释: 创建一个名为 users 的表,包含 idusernameemailcreated_at 列,其中 id 列是主键,usernameemail 列不能为空,created_at 列自动记录插入数据的时间。

修改表

sql">ALTER TABLE users
ADD age INT;  -- 向 users 表中添加 age 列,用于记录用户的年龄
  • 解释: 使用 ALTER TABLE 命令修改表结构,向 users 表中添加一个名为 age 的整型字段,用于存储用户的年龄信息。

删除表

sql">DROP TABLE users;
  • 解释: 删除名为 users 的表,同时删除该表中的所有记录和结构。

2. 数据操作语言 (DML)

DML 用于操作数据表中的数据,主要包括插入、更新和删除操作。

插入数据

sql">INSERT INTO users (username, email) 
VALUES ('john_doe', 'john@example.com');  -- 插入一条新记录
  • 解释: 向 users 表中插入一条新记录,用户名为 john_doe,邮箱为 john@example.com

批量插入数据

sql">INSERT INTO users (username, email) 
VALUES 
('jane_doe', 'jane@example.com'),  -- 插入多个用户数据
('alice', 'alice@example.com');
  • 解释: 向 users 表中插入多条记录,一次插入多个用户信息,减少操作次数,提高效率。

更新数据

sql">UPDATE users
SET email = 'john_doe@example.com'
WHERE username = 'john_doe';  -- 更新 john_doe 的邮箱信息
  • 解释: 更新 users 表中用户名为 john_doe 的记录,将其邮箱更改为 john_doe@example.comWHERE 子句用于指定更新的条件。

条件更新

sql">UPDATE users
SET email = 'new_email@example.com'
WHERE age > 30;  -- 更新所有年龄大于 30 的用户的邮箱
  • 解释: 更新 users 表中所有年龄大于 30 的用户,将他们的邮箱设置为 new_email@example.com

删除数据

sql">DELETE FROM users
WHERE username = 'john_doe';  -- 删除用户名为 john_doe 的记录
  • 解释: 从 users 表中删除用户名为 john_doe 的记录。WHERE 子句确保只删除特定的记录。

条件删除

sql">DELETE FROM users
WHERE created_at < '2022-01-01';  -- 删除 2022 年之前创建的所有用户
  • 解释: 删除 users 表中所有创建时间早于 2022 年的记录。

3. 数据查询语言 (DQL)

DQL 用于查询数据库中的数据,主要通过 SELECT 语句来执行。

查询数据

sql">SELECT username, email 
FROM users 
WHERE age > 18;  -- 查询所有年龄大于 18 岁的用户的用户名和邮箱
  • 解释: 查询 users 表中所有年龄大于 18 岁的用户,返回他们的用户名和邮箱。

查询所有数据

sql">SELECT * FROM users;  -- 返回 users 表中的所有数据
  • 解释: 查询 users 表中的所有记录和所有列。

使用排序

sql">SELECT * FROM users
ORDER BY created_at DESC;  -- 按照创建时间降序排列结果
  • 解释: 查询 users 表中的所有数据,并按照 created_at 列降序排列结果。最新的记录会排在最前面。

使用聚合函数

sql">SELECT COUNT(*) AS total_users, AVG(age) AS average_age
FROM users;  -- 统计用户总数和平均年龄
  • 解释: 通过 COUNT 计算 users 表中的总用户数,通过 AVG 计算用户的平均年龄,分别命名为 total_usersaverage_age

分组查询

sql">SELECT age, COUNT(*) AS user_count
FROM users
GROUP BY age;  -- 按年龄分组,统计每个年龄的用户数量
  • 解释: 按 age 分组,统计每个年龄段的用户数量,并将结果命名为 user_count

使用 HAVING 子句

sql">SELECT age, COUNT(*) AS user_count
FROM users
GROUP BY age
HAVING user_count > 1;  -- 只显示用户数量大于 1 的年龄组
  • 解释: 使用 HAVING 子句进一步过滤分组结果,只显示用户数量大于 1 的年龄组。

4. 事务

事务是一个逻辑单元,其中的一组 SQL 操作要么全部成功,要么全部失败。事务用于确保数据库操作的一致性和完整性。

sql">START TRANSACTION;  -- 开始一个事务-- 插入数据
INSERT INTO users (username, email) VALUES ('jane_doe', 'jane@example.com');COMMIT;  -- 提交事务,保存更改-- 如果出现错误,使用 ROLLBACK 撤销更改
ROLLBACK;
  • 解释: 通过 START TRANSACTION 开始事务,如果所有操作都成功,使用 COMMIT 提交更改。如果遇到错误,可以使用 ROLLBACK 撤销所有操作,保证数据的一致性。

5. 索引

索引用于加速数据查询操作,尤其是在处理大量数据时。通过索引,可以显著提高查询的速度。

创建索引

sql">CREATE INDEX idx_username ON users (username);  -- 在 username 列上创建索引
  • 解释: 为 users 表中的 username 列创建索引,优化基于用户名的查询速度。

唯一索引

sql">CREATE UNIQUE INDEX idx_email ON users (email);  -- 创建唯一索引,确保邮箱唯一
  • 解释: 创建一个唯一索引,确保 email 列中的值是唯一的。此索引会阻止重复的邮箱插入。

删除索引

sql">DROP INDEX idx_username ON users;  -- 删除 username 列上的索引
  • 解释: 删除 users 表中 username 列上的索引。

6. 视图

视图是基于 SQL 查询创建的虚拟表,通常用于简化复杂查询或者为特定用户提供特定的数据视图。

sql">CREATE VIEW active_users AS
SELECT username, email
FROM users
WHERE active = 1;  -- 创建一个只包含活跃用户的视图
  • 解释: 创建一个名为 active_users 的视图,视图中的数据来自 users 表,只包含标记为活跃的用户。

7. 存储过程

存储过程是一组预编译的 SQL 语句,可以多次调用,通常用于封装复杂的业务逻辑或重复性操作。

sql">CREATE PROCEDURE GetUserCount()
BEGINSELECT COUNT(*) FROM users;  -- 返回用户总数
END;
  • 解释: 创建一个名为 GetUserCount 的存储过程,执行该过程时会返回 users 表中的用户总数。

总结

通过本篇基础知识讲解,涵盖了 SQLyog 中 DDL、DML 和 DQL 的基础语法和扩展功能,介绍了事务、索引、视图和存储过程的使用。掌握这些基本语法和扩展知识可以帮助你更有效地管理和操作 MySQL 数据库


http://www.ppmy.cn/news/1525687.html

相关文章

idea一键自动化部署项目

文章目录 前言一、 IDEA插件安装1. 首先下载 Alibaba Cloud Toolkit 插件2. 插件下载完成后重启IDEA 二、SpringBoot项目准备1. pom.xml 文件2. controller3. 启动类 三、SpringBoot项目jar包部署1. Alibaba Cloud Toolkit 插件服务器配置2. 主机 IP、用户名、密码 点击测试链接…

Java的发展史与前景

&#x1f308;个人主页&#xff1a;Yui_ &#x1f308;Linux专栏&#xff1a;Linux &#x1f308;C语言笔记专栏&#xff1a;C语言笔记 &#x1f308;数据结构专栏&#xff1a;数据结构 &#x1f308;C专栏&#xff1a;C 文章目录 0. Java语言的发展史1.概述1.1 什么是Java1.2 …

LSTM处理时序数据:深入解析与实战

大家好&#xff0c;我是你们的深度学习老群群。今天&#xff0c;我们来聊一聊LSTM&#xff08;长短期记忆网络&#xff09;是如何处理时序数据并得到预测结果的。LSTM作为循环神经网络&#xff08;RNN&#xff09;的一种变体&#xff0c;因其能够有效捕捉长期依赖关系&#xff…

Docker部署tenine实现后端应用的高可用与负载均衡

采用Docker方式的Tengine 和 keepalived 组合模式可以实现小应用场景的高可用负载均衡需求 目录 网络架构一、环境准备二、软件安装1. 下载Tenine镜像2. 下载Keepalived镜像3. 制作SpringBoot镜像 三、软件配置1. 创建应用容器2. 代理访问应用3. 创建Keepalived4. 测试高可用 网…

QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第三期]

QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第三期] 第三期介绍&#xff1a;频道模块之频道成员 目录 QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第三期]第三期介绍&#xff1a;频道模块之频道成员获取子频道在线成员数获取频道成员列表获取频道身份组成员列…

MySQL 查询过慢的优化方法

1. 优化查询语句 问题&#xff1a;使用 SELECT * 会导致查询获取不必要的数据。 SELECT * FROM users WHERE age > 30;优化建议&#xff1a; 指定需要的列&#xff0c;这样可以减少数据传输的负担&#xff0c;提升查询速度。 SELECT name, email FROM users WHERE age &g…

Windows与linux中docker的安装与使用

windos中安装使用docker 下载Docker_Desktop 安装包进入docker官网下载Docker_Desktop&#xff1a; https://www.docker.com/启用wsl 我们搜索“启用或关闭Windows功能”&#xff0c;打开后勾选适用于Linux的Windows 子系统 Docker_Desktop设置 出现Docker Engine stopp…

GC-分代收集器

GC收集器介绍 十款GC收集器 上图中共有十款GC收集器&#xff0c;它们可以根据回收时的属性分为分代和分区两种类型&#xff1a; 分代收集器&#xff1a;Serial、ParNew、Parallel Scavenge、CMS、Serial Old&#xff08;MSC&#xff09;、Parallel Old 分区收集器&#xff…