一文详解mysql基础查询语句(附使用示例)
来源:SegmentFault
2023-02-24 10:56:12
0浏览
收藏
在数据库实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《一文详解mysql基础查询语句(附使用示例)》,聊聊MySQL,希望可以帮助到正在努力赚钱的你。
第一章:DDL和DML语言
1.DDL:
DDL:DDL是一种数据定义数据结构和修改的语言,也就是说查询表结构,他的全称为Data Definition Language
2.DDL-数据库操作
1.DDL查询
-- 查询所有数据库 SHOW DATABASES -- 查询当前数据库的所有表 SHOW DATABASES 数据库名 -- 例: SHOW DATABASES jzlg
2 .DDL创建
-- 创建数据库 CREATE DATABASE 数据库 -- 例: CREATE DATABASE KJZZ
3.DDL删除
删除数据库 DAOP DATA 数据库名; -- 例 DAOP DATA hhhh;
4.DDL 使用数据库
-- 使用之前创建的数据库 use 数据库
3.DDL-表操作-查询(查询表结构)
1.DDL查询
-- 查询当前数据库的表 SHOW TABLES; -- 例: show tables jzlg
2..DDL查询表结构
-- 查询表结构 DESC 表名 -- 例 DESC user
3.查询指定表的建表语句
-- 查询指定表的建表语句 SHOW CREATE TABLE 表名 -- 例 SHOW CREATE TABLE user
4.DDL-表操作- 创建
1.DDL表创建
CREATE TABLE 表名( 子段1 数据类型(COMMENT 字段1 注释), 字段2 数据类型(COMMENT 字段2 注释), 字段3 数据类型(COMMENT 字段3 注释) 字段4 数据类型(COMMENT 字段4 注释) .... )(COMMENT 表注释) -- 例 CREATE TABLE user( id int(COMMENT 用户id), name varchar(10)(COMMENT 用户名字), gender varchar(10)(COMMENT 用户性别) avg data(COMMENT 年龄) .... )(COMMENT 用户表)
5.DDL-表操作-修改
1.DDL添加字段
-- 添加字段 ALTER TABLE 表名 字段名 数据类型(长度) comment 注释 -- 案例 为user表添加一个新的昵称为nickname和数据类型为varchar(20) ALTER TABLE USER nickname varchar(20)
2.DDL修改字段
-- 修改数据类型 ALTER TABLE 表名 字段名 新数据类型(长度) comment 注释 -- 例: ALTER TABLE user nickname char(10) -- 修改字段名和字段类型 ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度) comment 注释 -- 例 ALTER TABLE user CHANGE nickname name varchar(20)
3.DDL删除字段
-- 删除字段 ALTER TABLE 表名 DROP 字段名 -- 例 ALTER TABLE user DROP name
4.DDL修改表名
-- 修改表名 ALTER TABLE 表名 RENAME TO 新表名 -- 例 ALTER TABLE user RENAME TO user1
5.DDL删除表
-- 删除表 DROP TABLE [IF EXISTS] 表名 例 DRIP TABLE [IF EXISTS] user -- 删除指定表, 并重新创建表 TRUNCATE TABLE user`
2.DML:
DML:是用来对数据库中的表中的数据进行增删改查的,全称是“Data Manipulation Language"
1.DML-数据操作
1添加数据
-- 给指定字段添加数据 INSERT INTO 表名(字段名1,字段名2,...) VALUES(值1,值2); -- 例 insert into user(id,name) VALUES(1,'陈礼浩') -- 给全部字段添加数据 insert into 表名 values(值1,值2) -- 例 insert into user(2,'陈礼浩') -- 批量添加数据 insert into 表名 (字段1,字段2) values(值1,值2), (值1,值2) -- 例 insert into user values(3,'哈哈哈') (4,'牛牛牛') insert into 表名 values(值1,值2), (值1,值2) -- 例 insert into user values(5,'qqq') (6,'666') 注意:1.插入数据时,指定的字段要和值一一对应 2.字符串和日期数据应该包含在引号中 3.插入的数据大小,应该在字段的规定的范围中 4.插入多条数据要用逗号分隔
2修改数据
-- 修改数据 UPDATE 表名 SET 字段1=值1,wher (条件) -- 例1:修改id为1的数据,将name改为666 UPDATE user SET name=666 where id=1 -- 例2: 修改id为1的数据,将name的值修改为哈哈哈,gender修改为女 UPDATE user set name=哈哈哈,gender=女 where id=1 -- 例3: 将所有的员工的入职日期都改为2008-1-1 UPDATE user set entrydate=2008-1-1 -- 因为他的说是将所有的员工改,所以没有条件
3删除数据
-- 删除数据 DELETE from 表名 where 条件 -- 例 将id为1的数据删除 DELETE from user where id=1 -- 删除某一字段的值 UPDATE user set name=null 注意: 1.DELETE 语句的条件可以有,也可以没有,如果没有条件,则整张表的数据都会被删除 2.DELETE 语句不能删除某一字段的值(可以使用 update)
第二章:DQL和DCL语言
1.DQL
1.1DQL介绍:
DQL是数据查询语言,用于查询数据库中的数据,全称是:Data QueryLanguage
1.2DQL的语法:
select 字段名 from where 条件 GROUP BY 分组字段 HAVING 分组后条件 ORDER BY 排序字段 LIKE 分页参数
1.3基础查询
-- 1.查询整个表的字段 select * from 表名 -- 例 select * from user -- 2.查询多个字段 select 字段1,字段2 from 表名 -- 例 select id,name from user -- 3.设置别名 select 字段1 AS 别名,字段2 AS 别名 from 表名 -- 例 select id as a,name AS b from user -- 4.去出重复记录 select 字段 from 表名 -- 例 select DISTINCT name from user
1.3.1练习
-- 1查询指定字段name,workno,age select name,workno,age from emp -- 2查询所有字段 select * from emp -- 3查询所有员工的工作地址,起别名 select workaddress as '工作地址' from emp -- 4查询公司员工的上班的地址 select DISTINCT workaddress from emp
1.4条件查询
-- 1.条件查询的语法 select 字段 from 表名 where 条件 -- 2条件 比较运算符 功能 > 大于 >= 大于或等于 或!= 不等于 BETWEEN ...AND... 在多少到多少之间 IN(...) 在in括号里面的多个值,多者选一 LIKE 占位符 模糊查询(_代替一个字符,%代替多个字符) IS NULL 是null 逻辑运算符 功能 and 或 && 并且 or或|| 或者 not或! 非,不是
1.4.1练习
-- 1.查询年龄等于88的员工 select * from emp where age=88 -- 2查询年龄小于22的员工信息 select * from emp where agee <h4>1.5聚合函数</h4><p></p><p></p><pre class="brush:go;">-- 1聚合函数介绍: 将一例数据看做为整体,进行计算 -- 2函数分类 max()求最大的值 min()求最小的值 avg()求平均值 sun()求总合 count()求个数 -- 3语法 select 聚合函数(字段名) from 表名
1.5.1练习
-- 1 统计该企业的员工数量 select count(workaddress) from emp -- 2统计该企业员工的年龄的平均年龄 select sun(age) from emp -- 3 统计该企业员工的最大年龄 select max(age) from emp -- 4 统计该企业员工的最小年龄 select min(age) from emp -- 5 统计西安地区员工的年龄的和 select sun() from where name='西安' 注意:所有的null值不参与聚合函数计算
1.6分组查询
-- 1.语法 select * from 表名 where 条件 GROUP BY 分组字段名 having 分组条件 -- 例 select * from emp where id=1 group by id having id=1 -- -- 注意:分组之后,查询的字段为聚合函数和分组字段,查询其他字段无任何意义
1.6.1练习
-- 查询男同学和女同学各自的数学平均分 select avg(math) from su group by sex -- 查询男同学和女同学各自的数学平均分,以及各自人数 select avg(math) ,count(sex) from sc group by sex -- 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组 select avg(math), count(sex) from sc where math <h4>1.7分页查询</h4><p></p><p></p><pre class="brush:go;">-- 1.语法 select * from 表名 limit 起是索引,查询的页数 -- 例 select * from sc limit 0,0 -- 2怎么求索引呢? 起始索引 = (当前页码 - 1) * 每页显示的条数
1.7.1练习
-- 从0开始查询,查询3条数据 select * from sc limit 0,3 -- 每页显示3条数据,查询第一页数据 select * from sc limit 0,3 -- 每页显示3条数据,查询第二页数据 select * from sc limit 3,3 -- 每页显示3条数据,查询第三页数据 select * from sc limit 6,3
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。
版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- 你知道柏睿数据加入了PolarDB开源数据库社区吗?

- 下一篇
- MySQL用户权限配置示例
查看更多
最新文章
-
- 数据库 · MySQL | 1小时前 |
- 主键与唯一键区别,如何选主键?
- 166浏览 收藏
-
- 数据库 · MySQL | 3小时前 |
- MySQL多表连接优化技巧与实战策略
- 221浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL排序优化与性能提升技巧
- 153浏览 收藏
-
- 数据库 · MySQL | 17小时前 |
- MySQL中WHERE与HAVING的区别详解
- 340浏览 收藏
-
- 数据库 · MySQL | 22小时前 |
- MySQL排序优化与性能提升技巧
- 368浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL连接池配置与优化方法
- 297浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLGROUPBY使用技巧与常见问题
- 306浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存优化技巧分享
- 392浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL安装到D盘教程及路径设置详解
- 279浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存设置及查询作用解析
- 470浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLcount优化技巧及性能提升方法
- 371浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 96次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 107次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 98次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 98次使用
查看更多
相关文章
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览