当前位置:首页 > 文章列表 > 数据库 > MySQL > MySql的基础知识之select

MySql的基础知识之select

来源:SegmentFault 2023-02-24 20:10:08 0浏览 收藏

对于一个数据库开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《MySql的基础知识之select》,主要介绍了MySQL,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

一、select语法

1、 简单查询语句

select 字段 from 表名|视图 where 条件 order by 字段 desc|asc (|表示或,desc降序,asc升序,不写默认升序)
例如 :

select * from user where name='张三' order by id; (*表示所有字段)
另:select  id, name,sex,phone from user where name='张三' order by id;

2、 查询不重复的数据

select distinct 字段[,字段,字段...] from 表名; 一个字段就判断一个字段的重复值,多个就会组合判断,多个都重复才会认为重复;
例如:

select  distinct name from user;  查出所有用户的名字;

3、 显示指定条数的数据

sql最后加 limit 起始偏移量,行数。第一个表示从第多少条开始,第二个表示取出来多少条,如取根据用户的创建时间,取最新的10条数据

select * from user order by createTime desc limit 1,10;

二、select 常见示例

1、控制流程

我们经常会遇见需要对字段的显示进行处理的情况,如性别字段值1显示男,值2显示女。

(1)case;

语法为 case 字段 when 值 then '' when 值 then '' ...... else '' end as 别名 (else 可不用)
例如:

select  name ,case sex  when 1 then '男'   when 2 then '女'  end  as s    from user ;     

还有另一种情况,简单的值判断无法满足需求,如年龄18以下显示未成年,18-50显示青年,50以上显示老年,这时候需要表达式来进行判断;
语法为case when 表达式 then '' when 表达式 then ''...... else '' end as 别名
例如:

select name ,
       case when age50 then '老年' end a 
from user; 

表达式可以是一个也可以是多个,如未满18的女性显示美少女,就是when age

(2)IF;

IF (expr1,expr2,expr3) 如果 expr1 是TRUE (expr1 0 and expr1 NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定

 SELECT IF(1>2,2,3);返回3
 SELECT IF(1

(3)STRCMP;

Strcmp(str1,str2):如果str1>str2返回1,str1=str2反回0,str1如果字符串相同,STRCMP()返回0,如果第一参数根据当前的排序次序小于第二个,返回-1,否则返回1。

 select STRCMP('text', 'text2'); 返回-1
 select STRCMP('text2', 'text'); 返回1
 select STRCMP('text', 'text');返回0

2、函数

这里只说明一下常用的函数,如下:

(1)IFNULL

判断是否为空,如果有值返回该字段的值,为空则返回指定值,语法为IFNULL(字段,'')
例如:

select name,ifnull(age,'该用户未填写年龄') from user 

(2)CONCAT

字符串连接,数据库中不能用+号连接字符串,语法为CONCAT(str1,str2,...)
例如:

select CONCAT(name,'是一个',age,'的',case sex when 1 then '男' when 2 then '女' end ,'生') 
from user;

但是有一点需要特别说明,如果其中一个字段为Null,则返回为null,因此,假如有某列数据可能会空的,字段用ifnull(age,'')

(3)FORMAT

对字段进行格式化,FORMAT(x,n)函数可以将数字x进行格式化,将x保留到小数点后n位。这个过程需要进行四舍五入。例如FORMAT(2.356,2)返回的结果将会是2.36;FORMAT(2.353,2)返回的结果将会是2.35。

(4) INET_ATON

INET_ATON(IP)函数可以将IP地址转换为数字表示,数字比字符串存储空间少,查询效率高,这算是一种mysql的优化;INET_NTOA(n)函数可以将数字n转换成IP的形式。其中,INET_ATON(IP)函数中IP值需要加上引号。这两个函数互为反函数。


数据库中对字符串、日期、数字的函数比较多,会单独写文章说明。

本章结束,如有不对欢迎指正,不完善的欢迎补充

今天带大家了解了MySQL的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
优化:mysql查询最近一条记录未指定标题的文章优化:mysql查询最近一条记录未指定标题的文章
上一篇
优化:mysql查询最近一条记录未指定标题的文章
Django ORM层日志的两种实现方式
下一篇
Django ORM层日志的两种实现方式
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    24次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    38次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    37次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    48次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    41次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码