MySQL数据库SQL简介

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

  好程序员大数据培训分享之MySQL数据库SQL简介、语法格式:一、SQL的简介,结构化查询语言(Structured Query Language),简称SQL。它是专门用来访问数据库的标准编程语言。它可以用于存储数据,查询数据,更新数据以及管理关系型数据库等操作。同时,数据库脚本文件的扩展名也是sql。
  SQL是高级的非过程化编程语言,允许用户在高层数据结构上工作。同时,SQL语句可以嵌套,因此拥有极大的灵活性和强大的功能。但是,数据库厂商都对SQL标准语言做了某些改编和扩充,因此,不同的数据库的SQL语言,用法、格式等不完全一致。
  SQL语言可以分成五个部分,分别为DDL,DML,TCL,DCL,DQL。
1、数据定义语言(Data Definition Language ),简称DDL。
用于建立,删除,修改数据库对象的语言。包含如下关键字
create:用于创建表或者其他对象的结构
drop:用于删除表或者其他对象的结构
alter:用于修改表或者其他对象的结构
truncate:用于清空表数据,保留表结构
2、数据操纵语言(Data Manipulation Language),简称DML。
用于改变数据表的数据。通常与事务控制语言一起使用,要经过事务控制语言的提交操作,才会真正的将数据持久到数据库中。包含如下关键字:
insert:将数据插入到数据表中。
update:更新数据表中已存在的数据。
delete:删除数据表中的数据。
3、数据查询语言(Data Query Language),简称DQL。
用于查询数据表中的数据。或者用于科学计算。关键字如下:
select:选择要显示的数据。
4、事务控制语言(Transaction Control Language),简称TCL。
用于保证数据的完整性和一致性。只有数据表正在进行DML操作时,才会涉及到事务。关键字如下:
commit:提交,确任。将已经进行的DML操作的数据持久化。
rollback:回滚,回退。用于取消已经进行的DML操作。
savepoint:保存点。可以将当前的DML操作回退到指定的保存点,便于取消部分改变。
5、数据控制语言(Data Control Language),简称DCL。
用于执行关于权限的授予和撤销操作。关键字如下:
grant:授权。用于给用户或者角色授予权限.
revoke:撤销。用于回收用户或者角色的权限。
create user:创建用户。
drop user :删除用户。
二、MySql的常用SQL语法
市场上流通的数据库虽然都遵守了SQL语言的标准规范,但是用法也不完全相同。下面我将MySQL数据库的各个部分的使用语法整理一下,方便大家记忆。PS:下面会用到"[]"中括号,表示可选。
1、关于数据库的创建,删除等操作语法
在实际开发中,任何一个项目的数据存储与管理都对应一个数据库(数据存储空间),避免与其他项目的数据混在同一个数据库中,因此,会涉及到数据库的创建等操作。
(1)创建数据库:create database [if not exists] dbName [default character set utf8] [collate utf8_general_ci | utf8_general_cs];

解析> 此语句指定数据库的字符集为utf8。utf8_general_ci表示字母大小写不敏感;utf8_general_cs表示大小写敏感

(2)查看数据库:show databases;

(3)选择数据库:use dbName;

(4)删除数据库:drop database dbName;

(5)查看数据库字符集:show variables like "%character%";

(6)修改数据库字符集:alter database dbName character set cName;

(7)修改命令提示符界面显示字符集(当前窗口有效):set name cName;
2、DDL语言的操作语法
(1)创建表结构:
create table tName (colName1 type1,...,colNameN typeN) engine=innodb[collate utf8_general_ci]
(2)显示表结构:desc tName 或者 show columns from tName;

(3)添加表字段:alter table tName add colName Type;

(4)删除表字段:alter table tName drop colName;

(5)修改表字段类型/表字段名称
alter table tName modify colName newType;
alter table tName change colName newColName newType;

(6)修改表名:alter table oldName rename newName;

(7)清空表数据,保留表结构:truncate table tName;

(8)删除表结构:drop table tName;

(9)复制表结构:create table newName like oldName;
3、DML语言的操作语法
(1)插入数据到表中:
方法1: insert into tName (colName1,....,colNameN)values (value1,.....,valueN);
方法2: insert into tName values ( value1,.....,valueN); /按照建表字段顺序赋值/

(2)修改表中数据:
update tName set colName1=value1,.....colNameN=valueN [ where 条件 ];

(3)删除表中数据:delete from tName [ where 条件 ];
4、DQL语言的操作语法
select colName1,......,colNameN from tName [where 子句] [ group by 子句] [ having 子句] [order by子句]select有选择的意思,即选择哪些字段进行查询,显示。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
关系型数据库 MySQL 数据库连接
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
104 82
|
5天前
|
SQL Oracle 关系型数据库
【YashanDB知识库】如何将mysql含有group by的SQL转换成崖山支持的SQL
本文探讨了在YashanDB(崖山数据库)中执行某些SQL语句时出现的报错问题,对比了MySQL的成功执行结果。问题源于SQL-92标准对非聚合列的严格限制,要求这些列必须出现在GROUP BY子句中,而SQL:1999及更高版本允许非聚合列直接出现在选择列中。YashanDB和Oracle遵循SQL-92标准,因此会报错。文章提供了两种解决方法:使用聚合函数处理非聚合列,或将GROUP BY与ORDER BY拆分为两层查询。最后总结指出,SQL-92标准更为严谨合理,建议开发者遵循此规范以避免潜在问题。
|
6天前
|
消息中间件 缓存 NoSQL
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
|
11天前
|
SQL 关系型数据库 MySQL
MySQL生产环境迁移至YashanDB数据库深度体验
这篇文章是作者将 MySQL 生产环境迁移至 YashanDB 数据库的深度体验。介绍了 YashanDB 迁移平台 YMP 的产品相关信息、安装步骤、迁移中遇到的各种兼容问题及解决方案,最后总结了迁移体验,包括工具部署和操作特点,也指出功能有优化空间及暂不支持的部分,期待其不断优化。
|
23天前
|
SQL 关系型数据库 MySQL
基于SQL Server / MySQL进行百万条数据过滤优化方案
对百万级别数据进行高效过滤查询,需要综合使用索引、查询优化、表分区、统计信息和视图等技术手段。通过合理的数据库设计和查询优化,可以显著提升查询性能,确保系统的高效稳定运行。
46 9
|
23天前
|
SQL 存储 缓存
MySQL的架构与SQL语句执行过程
MySQL架构分为Server层和存储引擎层,具有高度灵活性和可扩展性。Server层包括连接器、查询缓存(MySQL 8.0已移除)、分析器、优化器和执行器,负责处理SQL语句;存储引擎层负责数据的存储和读取,常见引擎有InnoDB、MyISAM和Memory。SQL执行过程涉及连接、解析、优化、执行和结果返回等步骤,本文详细讲解了一条SQL语句的完整执行过程。
44 3
|
23天前
|
监控 关系型数据库 MySQL
云数据库:从零到一,构建高可用MySQL集群
在互联网时代,数据成为企业核心资产,传统单机数据库难以满足高并发、高可用需求。云数据库通过弹性扩展、分布式架构等优势解决了这些问题,但也面临数据安全和性能优化挑战。本文介绍了如何从零开始构建高可用MySQL集群,涵盖选择云服务提供商、创建实例、配置高可用架构、数据备份恢复及性能优化等内容,并通过电商平台案例展示了具体应用。
|
1天前
|
存储 SQL 关系型数据库
从 MySQL 到时序数据库 TDengine:Zendure 如何实现高效储能数据管理?
TDengine 助力广州疆海科技有限公司高效完成储能业务的数据分析任务,轻松应对海量功率、电能及输入输出数据的实时统计与分析,并以接近 1 : 20 的数据文件压缩率大幅降低存储成本。此外,taosX 强大的 transform 功能帮助用户完成原始数据的清洗和结构优化,而其零代码迁移能力更实现了历史数据从 TDengine OSS 与 MySQL 到 TDengine 企业版的平滑迁移,全面提升了企业的数据管理效率。本文将详细解读这一实践案例。
13 0
|
1月前
|
SQL 关系型数据库 MySQL
数据库数据恢复——MySQL简介和数据恢复案例
MySQL数据库数据恢复环境&故障: 本地服务器,安装的windows server操作系统。 操作系统上部署MySQL单实例,引擎类型为innodb,表空间类型为独立表空间。该MySQL数据库没有备份,未开启binlog。 人为误操作,在用Delete命令删除数据时未添加where子句进行筛选导致全表数据被删除,删除后未对该表进行任何操作。
|
1月前
|
SQL Oracle 关系型数据库
【YashanDB 知识库】如何将 mysql 含有 group by 的 SQL 转换成崖山支持的 SQL
在崖山数据库中执行某些 SQL 语句时出现报错(YAS-04316 not a single-group group function),而这些语句在 MySQL 中能成功执行。原因是崖山遵循 SQL-92 标准,不允许选择列表中包含未在 GROUP BY 子句中指定的非聚合列,而 MySQL 默认允许这种操作。解决办法包括:使用聚合函数处理非聚合列或拆分查询为两层,先进行 GROUP BY 再排序。总结来说,SQL-92 更严格,确保数据一致性,MySQL 在 5.7 及以上版本也默认遵循此标准。