【MySQL】常用语句
目录
- 1. 数据库操作
- 2. 表操作
- 3. 数据操作(CRUD)
- 4. 高级查询
- 5. 索引管理
- 6. 用户与权限
- 7. 数据导入导出
- 8. 事务控制
- 9. 其他实用语句
- 注意事项
- 如果这篇文章对你有所帮助,渴望获得你的一个点赞!
1. 数据库操作
-
创建数据库
CREATE DATABASE dbname; CREATE DATABASE dbname CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; -- 指定字符集
-
查看数据库
SHOW DATABASES; -- 列出所有数据库 SHOW CREATE DATABASE dbname; -- 查看创建语句
-
使用数据库
USE dbname; -- 切换当前数据库
-
删除数据库
DROP DATABASE dbname; -- 谨慎操作!
2. 表操作
-
创建表
CREATE TABLE users (id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(50) NOT NULL,email VARCHAR(100) UNIQUE,age INT DEFAULT 18,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
-
查看表结构
DESC users; -- 查看表结构 SHOW CREATE TABLE users; -- 查看建表语句
-
修改表
ALTER TABLE users ADD COLUMN gender VARCHAR(10); -- 添加列 ALTER TABLE users MODIFY COLUMN name VARCHAR(100); -- 修改列类型 ALTER TABLE users DROP COLUMN age; -- 删除列 ALTER TABLE users RENAME TO members; -- 重命名表
-
删除表
DROP TABLE users; -- 删除表(谨慎!)
3. 数据操作(CRUD)
-
插入数据
INSERT INTO users (name, email) VALUES ('Alice', 'alice@example.com'); INSERT INTO users (name, email) VALUES ('Bob', 'bob@example.com'),('Charlie', 'charlie@example.com'); -- 插入多行
-
查询数据
SELECT * FROM users; -- 查询所有数据 SELECT name, email FROM users WHERE age > 20; -- 条件筛选 SELECT DISTINCT name FROM users; -- 去重 SELECT * FROM users ORDER BY created_at DESC; -- 排序 SELECT * FROM users LIMIT 10 OFFSET 5; -- 分页(第2页,每页10条)
-
更新数据
UPDATE users SET age = 25 WHERE id = 1; -- 更新单条 UPDATE users SET status = 'active' WHERE last_login > '2023-01-01'; -- 批量更新
-
删除数据
DELETE FROM users WHERE id = 1; -- 删除单条 DELETE FROM users WHERE status = 'inactive'; -- 条件删除 TRUNCATE TABLE users; -- 清空表(不可回滚,速度比DELETE快)
4. 高级查询
-
连接查询(JOIN)
-- 内连接 SELECT users.name, orders.amount FROM users INNER JOIN orders ON users.id = orders.user_id;-- 左连接 SELECT users.name, orders.amount FROM users LEFT JOIN orders ON users.id = orders.user_id;
-
聚合函数
SELECT COUNT(*) FROM users; -- 统计行数 SELECT AVG(age) AS avg_age FROM users; -- 平均值 SELECT MAX(created_at) AS latest FROM users; -- 最大值 SELECT city, COUNT(*) FROM users GROUP BY city; -- 分组统计 SELECT city, COUNT(*) FROM users GROUP BY city HAVING COUNT(*) > 100; -- 分组后筛选
-
子查询
SELECT name FROM users WHERE id IN (SELECT user_id FROM orders WHERE amount > 100);
5. 索引管理
-
创建索引
CREATE INDEX idx_name ON users(name); -- 普通索引 CREATE UNIQUE INDEX idx_email ON users(email); -- 唯一索引
-
删除索引
DROP INDEX idx_name ON users;
6. 用户与权限
-
创建用户
CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';
-
授予权限
GRANT SELECT, INSERT ON dbname.* TO 'username'@'localhost'; GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' WITH GRANT OPTION; -- 谨慎使用
-
撤销权限
REVOKE INSERT ON dbname.* FROM 'username'@'localhost';
-
删除用户
DROP USER 'username'@'localhost';
-
刷新权限
FLUSH PRIVILEGES;
7. 数据导入导出
-
导出数据
SELECT * INTO OUTFILE '/tmp/users.csv' FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' FROM users;
-
导入数据
LOAD DATA INFILE '/tmp/users.csv' INTO TABLE users FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
8. 事务控制
-
开启事务
START TRANSACTION; -- 执行操作(如INSERT/UPDATE/DELETE) COMMIT; -- 提交事务 ROLLBACK; -- 回滚事务
-
设置自动提交
SET autocommit = 0; -- 关闭自动提交 SET autocommit = 1; -- 开启自动提交(默认)
9. 其他实用语句
-
条件判断
SELECT name, CASE WHEN age < 18 THEN 'Minor'ELSE 'Adult' END AS age_group FROM users;
-
日期函数
SELECT NOW(); -- 当前时间 SELECT DATE_FORMAT(created_at, '%Y-%m-%d') FROM users; -- 格式化日期
-
字符串函数
SELECT CONCAT(name, ' (', email, ')') AS info FROM users; SELECT SUBSTRING(email, 1, 5) FROM users; -- 截取字符串
注意事项
- 数据安全:执行
DELETE
或UPDATE
时务必检查WHERE
条件,避免误操作。 - 备份:重要操作前使用
mysqldump
备份数据。 - 性能优化:合理使用索引,避免全表扫描。
掌握这些语句后,可覆盖MySQL日常开发与管理的90%场景。进阶学习可探索存储过程、触发器、视图等高级功能。
如果这篇文章对你有所帮助,渴望获得你的一个点赞!
相关文章:
【MySQL】常用语句
目录 1. 数据库操作2. 表操作3. 数据操作(CRUD)4. 高级查询5. 索引管理6. 用户与权限7. 数据导入导出8. 事务控制9. 其他实用语句注意事项 如果这篇文章对你有所帮助,渴望获得你的一个点赞! 1. 数据库操作 创建数据库 CREATE DATA…...
二维数组 C++ 蓝桥杯
1.稀疏矩阵 #include<iostream> using namespace std;const int N 1e4 10; int a[N][N];int main() {int n, m; cin >> n >> m;for (int i 1; i < n; i) {for (int j 1; j < m; j) {cin >> a[i][j];}}for (int j m; j > 1; j--) {for (i…...
SAP HCM 回溯分析
最近总有人问回溯问题,今天把12年总结的笔记在这共享下: 12年开这个图的时候总是不明白是什么原理,教程看N次,网上资料找一大堆,就是不明白原理,后来为搞明白逻辑,按照教材的数据一样做…...
MySQl的日期时间加
MySQL日期相关_mysql 日期加减-CSDN博客MySQL日期相关_mysql 日期加减-CSDN博客 raise notice 查询目标 site:% model:% date:% target:%,t_shipment_date.site,t_shipment_date.model,t_shipment_date.plant_date,v_date_shipment_qty_target;...
前部分知识复习03
一、光照模型 经验型: 1.Lambert光照模型 2.Phong光照模型 3.Blinn-Phong光照模型 物理型: 4.PBR光照模型 二、渲染路径 渲染路径:是为进行光照计算而设置的渲染方式 前向渲染路径顶点照明渲染路径延迟渲染路径 顶点照明渲染路径中的灯光…...
Windows图形界面(GUI)-QT-C/C++ - QT MDI Area
公开视频 -> 链接点击跳转公开课程博客首页 -> 链接点击跳转博客主页 目录 一、概述 二、使用场景 1. 多文档编辑器 2. 多窗口应用程序 3. 多视图应用程序 三、常见样式 1. 子窗口管理 2. 布局管理 四、属性设置 1. 添加子窗口 2. 移除子窗口 3. 设置…...
基于微信小程序的私家车位共享系统设计与实现(LW+源码+讲解)
专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…...
用deepseek制作我的第一个长视频---使用AI解决尝试新领域没有经验拖延的问题!
(由于技术原因,联网搜索暂不可用) 制作一个高质量的Vlog或生活记录长视频,即使零基础也能通过系统规划实现!以下是为你定制的「从零到成品」全流程指南,结合叙事逻辑、剪辑技巧和效率工具,帮你…...
零基础学习电磁兼容(EMC)06--时域和频域
大部分工程师很熟悉示波器,并使用它读取信号的频率和电压值,然而,在EMC领域,绝大多数的数据都是从频谱分析仪、测量接收机等基于频率测量的设备中读取的,因此,了解这些频率参数的含义以及与时域信号的关系,是非常重要的。 时域和频域的本质:傅里叶变换及其逆过程 如下…...
解决在使用自己的数据集在 Ultralytics 上运行 RT - DETR 模型时显存爆满的问题
在使用自己的数据集在 Ultralytics 上运行 RT - DETR 模型时,显存爆满是一个常见问题。以下是一系列可以采取的步骤和方法,帮助你解决这个问题,同时使用 Ultralytics 的官方源码。 1. 环境准备 确保你已经安装了 Ultralytics 库,…...
Android学习19 -- 手搓App
1 前言 之前工作中,很多时候要搞一个简单的app去验证底层功能,Android studio又过于重型,之前用gradle,被版本匹配和下载外网包折腾的堪称噩梦。所以搞app都只有找应用的同事帮忙。一直想知道一些简单的app怎么能手搓一下&#x…...
鼠标拖尾特效
文章目录 鼠标拖尾特效一、引言二、实现原理1、监听鼠标移动事件2、生成拖尾元素3、控制元素生命周期 三、代码实现四、使用示例五、总结 鼠标拖尾特效 一、引言 鼠标拖尾特效是一种非常酷炫的前端交互效果,能够为网页增添独特的视觉体验。它通常通过JavaScript和C…...
【CSS】什么是响应式设计?响应式设计的基本原理,怎么做
在当今多设备、多屏幕尺寸的时代,网页设计面临着前所未有的挑战。传统的固定布局已无法满足用户在不同设备上浏览网页的需求,响应式设计(Responsive Web Design)应运而生,成为网页设计的趋势和标准。本文将深入探讨响应…...
单机性能调优中的程序优化
目录 一、系统框架的选择 二、程序优化 表单压缩 局部刷新 仅取所需 逻辑清晰 谨慎继承 程序算法优化 批处理 延迟加载 防止内存泄漏 减少大对象引用 防止争用死锁 存储过程 内存分配 并行 异步 缓存 单机优化顾名思义就是我们要在单机上对系统的性能进行调优…...
2.4学习总结
洛谷1305代码 #include<stdio.h> #include<stdlib.h> struct treenode {char val;struct treenode* left;struct treenode* right; }; struct treenode* createnode(char val) {struct treenode* node (struct treenode*)malloc(sizeof(struct treenode));node-&…...
小程序-视图与逻辑
前言 1. 声明式导航 open-type"switchTab"如果没有写这个,因为是tabBar所以写这个,就无法跳转。路径开始也必须为斜线 open-type"navigate"这个可以不写 现在开始实现后退的效果 现在我们就在list页面里面实现后退 2.编程式导航…...
突破封闭集限制:OvSGTR引领开放词汇场景图生成新纪元
场景图生成(Scene Graph Generation, SGG),这个领域,旨在通过解析图像来构建描述性的结构化图表,不仅能够识别图片中的物体,还能捕捉它们之间的相互关系。 这种能力对于诸如图像字幕、视觉问答以及图像生成…...
C语言基础之【程序流程结构】
C语言基础之【程序流程结构】 概述选择结构if语句if…else语句小练习:“三只小猪体重比较” if…else if…else语句小练习:“三只小猪体重比较” 三目运算符小练习:“三只小猪体重比较” switch语句小练习:**“成绩等级判断器”**…...
代码随想录35 动态规划
目录 leetcode 746.使用最小花费爬楼梯 leetcode 62.不同路径 思路: leetcode 63.不同路径|| leetcode 746.使用最小花费爬楼梯 给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选…...
【游戏设计原理】98 - 时间膨胀
从上文中,我们可以得到以下几个启示: 游戏设计的核心目标是让玩家感到“时间飞逝” 游戏的成功与否,往往取决于玩家的沉浸感。如果玩家能够完全投入游戏并感受到时间飞逝,说明游戏设计在玩法、挑战、叙事等方面达到了吸引人的平衡…...
51单片机 06 定时器
51 单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 作用:1、用于计时;2、替代长时间的Delay,提高CPU 运行效率和处理速度。 定时器个数:3个(T0、T1、T2)…...
4 前端前置技术(中):node.js环境
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 前言...
【Leetcode刷题记录】1456. 定长子串中元音的最大数目---定长滑动窗口即解题思路总结
1456. 定长子串中元音的最大数目 给你字符串 s 和整数 k 。请返回字符串 s 中长度为 k 的单个子字符串中可能包含的最大元音字母数。 英文中的 元音字母 为(a, e, i, o, u)。 这道题的暴力求解的思路是通过遍历字符串 s 的每一个长度为 k 的子串…...
C++效率掌握之STL库:string函数全解
文章目录 1.为什么要学习string?什么是string?2.string类对象的常见构造3.string类对象的容量操作4.string类对象的迭代器5.string类对象的元素访问6.string类对象的元素修改7.string类对象的查找、提取、对比8.string类的非成员函数及npos希望读者们多多…...
Linux命令运行原理及权限管理
目录 1.引言 2.shell命令以及运行原理 3.Linux权限 3.1Linux下的用户类型 3.2Linux权限管理 3.2.1文件访问者的分类(人) 3.2.2文件类型和访问权限(事物属性) 3.2.3文件权限值的表示方法 3.2.4文件访问权限的相关设置方法…...
linux内核源代码中__init的作用?
在 Linux 内核源代码中,__init是一个特殊的宏,用于标记在内核初始化阶段使用的变量或函数。这个宏的作用是告诉内核编译器和链接器,被标记的变量或函数只在内核的初始化阶段使用,在系统启动完成后就不再需要了。因此,这…...
系统学习算法:专题九 穷举vs暴搜vs深搜vs回溯vs剪枝
其中标题的深搜,回溯,剪枝我们之前专题都已经有过学习和了解,这里多了两个穷举和暴搜,其实意思都差不多,穷举就是穷尽力气将所有情况都列举出来,暴搜就是暴力地去一个一个情况搜索,所以就是全部…...
《深度洞察ICA:人工智能信号处理降维的独特利器》
在人工智能技术飞速发展的今天,信号处理作为关键环节,面临着数据维度不断攀升的挑战。高维信号数据虽蕴含丰富信息,但也给处理和分析带来诸多难题,如计算资源消耗大、分析复杂度高、模型易过拟合等。独立成分分析(ICA&…...
FASTA 和 FASTQ 格式详解|SRA转fastq
FASTA 格式 FASTA 格式是一种用于存储序列信息的简单格式,广泛应用于核酸(DNA/RNA)和蛋白质序列的存储。它主要由两个部分组成: 描述行:以“>”符号开头,包含序列的描述信息,如名称、来源等…...
Docker使用指南(一)——镜像相关操作详解(实战案例教学,适合小白跟学)
目录 1.镜像名的组成 2.镜像操作相关命令 镜像常用命令总结: 1. docker images 2. docker rmi 3. docker pull 4. docker push 5. docker save 6. docker load 7. docker tag 8. docker build 9. docker history 10. docker inspect 11. docker prune…...
为何在Kubernetes容器中以root身份运行存在风险?
作者:马辛瓦西奥内克(Marcin Wasiucionek) 引言 在Kubernetes安全领域,一个常见的建议是让容器以非root用户身份运行。但是,在容器中以root身份运行,实际会带来哪些安全隐患呢?在Docker镜像和…...
【人工智能】多模态学习在Python中的应用:结合图像与文本数据的深度探索
《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 多模态学习是人工智能领域的一个重要研究方向,旨在通过结合多种类型的数据(如图像、文本、音频等)来提高模型的性能。本文将深入探讨多模…...
以AI为翼:技术能力进阶的新路径
一、引言 1.1 研究背景与意义 在当今数字化时代,人工智能(AI)已成为推动各领域发展的核心驱动力。从最初简单的算法模型到如今复杂的深度学习架构,AI 技术取得了令人瞩目的进步。自 20 世纪 50 年代人工智能概念提出以来&#x…...
使用 HTTP::Server::Simple 实现轻量级 HTTP 服务器
在Perl中,HTTP::Server::Simple 模块提供了一种轻量级的方式来实现HTTP服务器。该模块简单易用,适合快速开发和测试HTTP服务。本文将详细介绍如何使用 HTTP::Server::Simple 模块创建和配置一个轻量级HTTP服务器。 安装 HTTP::Server::Simple 首先&…...
Jenkins 触发构建的几种常见方式
为了实现自动化构建,Jenkins 提供了多种触发构建的方式。这些触发方式可以根据开发团队的需求来选择,使得构建过程更加灵活和高效。 1. 手动触发构建 手动触发构建是最简单的一种方式,通常用于开发人员或管理员手动启动构建任务。 步骤: 登录 Jenkins 后,进入某个项目(…...
算法基础--二分查找
模板 #include <iostream> #include <cstring> #include <algorithm> #include <unordered_map> /** 二分查找(Binary Search)是一种高效的查找算法,其时间复杂度为 o(logn) */ using namespace std;const int N …...
Vue 3 30天精进之旅:Day 14 - 项目实践
在前面的学习中,我们已经掌握了Vue 3的基础知识,包括其核心概念、Vue Router、Vuex,以及异步操作等。今天是一个重要的里程碑:我们将把这些知识整合到一个实际的项目中。通过项目实践,你将能够深入理解所学知识&#x…...
【Java基础-42.4】Java中的包装类对象默认值:深入解析与注意事项
在Java编程中,包装类(Wrapper Classes)是将基本数据类型(如int、char等)封装为对象的类。它们提供了更多的功能和灵活性,例如允许基本数据类型参与面向对象的操作(如存储在集合中)。…...
Linux进程概念
目录 一.进程 二.进程状态 三.环境变量 四.程序地址空间 五.Linux2.6内核进程调度队列 一.进程 基本概念 课本概念:程序的一个执行实例,正在执行的程序等内核观点:担当分配系统资源(CPU时间,内存)的…...
Linux的简单使用和部署4asszaaa0
一.部署 1 环境搭建方式主要有四种: 1. 直接安装在物理机上.但是Linux桌面使用起来非常不友好.所以不建议.[不推荐]. 2. 使用虚拟机软件,将Linux搭建在虚拟机上.但是由于当前的虚拟机软件(如VMWare之类的)存在⼀些bug,会导致环境上出现各种莫名其妙的问题比较折腾.[非常不推荐…...
人工智能专业术语详解(A)
人工智能不仅是指寻求如何替代人类的机器人或人类寻求自我挑战的游戏,更是指运用复杂的程序化数学,其结果与高质量的训练数据相结合,推动了我们在日常生活中所看到的技术进步。从无人驾驶汽车到寻找癌症的治疗方法,人工智能正在逐…...
深度学习 Pytorch 基础网络手动搭建与快速实现
为了方便后续练习的展开,我们尝试自己创建一个数据生成器,用于自主生成一些符合某些条件、具备某些特性的数据集。 导入相关的包 # 随机模块 import random# 绘图模块 import matplotlib as mpl import matplotlib.pyplot as plt# 导入numpy import nu…...
deepseek的对话风格
概述 deepseek的对话风格,比一般的模型的回答多了思考过程,这是它比较可爱的地方,模型的回答有了思考过程,对用户而言大模型的回答不完全是一个黑盒。 deepseek的对话风格 train_prompt_style """Below is an…...
Spring Security(maven项目) 3.0.2.9版本 --- 改
前言: 通过实践而发现真理,又通过实践而证实真理和发展真理。从感性认识而能动地发展到理性认识,又从理性认识而能动地指导革命实践,改造主观世界和客观世界。实践、认识、再实践、再认识,这种形式,循环往…...
OpenAI新商标申请曝光:AI硬件、机器人、量子计算全线布局?
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
TVM调度原语完全指南:从入门到微架构级优化
调度原语 在TVM的抽象体系中,调度(Schedule)是对计算过程的时空重塑。每一个原语都是改变计算次序、数据流向或并行策略的手术刀。其核心作用可归纳为: 优化目标 max ( 计算密度 内存延迟 指令开销 ) \text{优化目标} \max…...
AlexNet网络学习笔记(NIPS 2012)
题目:ImageNet Classification with Deep Convolutional Neural Networks 发文机构:多伦多大学 作者:Alex Krizhevsky,Ilya Sutskever,Geoffrey E. Hinton(人工智能教父,AI三巨头——杰弗里.辛顿(Geoffrey Hinton),约书亚.本吉奥(Yoshua Bengio)和扬.勒丘恩(Yan…...
Starrocks 对比 Clickhouse
极速查询的单表查询 StarRocks 在极速查询方面上做了很多,下面着重介绍四点: 1)向量化执行:StarRocks 实现了从存储层到查询层的全面向量化执行,这是 StarRocks 速度优势的基础。向量化执行充分发挥了 CPU 的处理能力…...
C++实现一款功能丰富的通讯录管理系统
在学习编程的过程中,如何设计一个实用的项目是许多同学头疼的问题。如果你是一位正在学习C的同学,想通过实际项目巩固知识,那么这个通讯录管理系统绝对是一个理想的练手项目。在本文中,我将详细拆解代码逻辑,帮助你理解…...
动态规划之背包问题
文章目录 0-1 背包问题1. 二维动态规划实现(0-1 背包):2. 一维动态规划实现(0-1 背包): 完全背包问题1. 二维动态规划实现(完全背包):2. 一维动态规划实现(完…...