MySQL基础查询_005

五、DQL语言

5.4.查询时注意的细节

  • 要查询某个库里的字段,先进入该库

    use test

  • 使用ESC下面的着重号标识字段,避免机器将字段误认为关键字

    SELECT `name` FROM employees;
    #在客户端中,若是name这个字段不适用
    #着重号,客户端会将其误认为是关键字name
    
  • 要将什么命令进行格式化,要先将命令选中,然后按F12

  • 要运行什么就选中什么,再去运行达到精确运行目的,类似java中,在代码中右击运行可靠性比直接点击运行按钮强,否则,容易出现运行的还是历史代码

5.5.查询常量、字符串、表达式、函数

5.5.1.查询常量

select 100;

image-20220228215931445

查询常量不需要使用from,因为不需要指定特定的某个表,单纯地找出常量

5.5.2.查询字符串

在SQL中,不区分字符和字符串,二者一视同仁,用英文输入法单引号括起来

select 'yanyu666'select 'john';
#查询字符串‘yanyu666’

image-20220228220423824

5.5.3.查询表达式

在select后面输入一个表达式

select 450+9;
select 10%3;

image-20220228220719254

image-20220228220736670

5.5.4.查询函数

select+函数

select version();
#查询版本

image-20220228221222298

5.5.5.起别名

  • 对于重名的字段可以使用别名进行区分
  • 起别名,便于记忆和表达

方式1:select+对象+别名

方式2:使用空格代替as

select 100*12 as 乘法结果;
#先进入myemployees库
use myemlpoyees;
select last_name as,first_name asfrom employees;

image-20220228222733962

image-20220228223120348

特例:

  • 别名带有空格或者其它会产生歧义的字符时,使用双引号或者单引号在MySQL中建议使用双引号
select salary as "put into table" from employees;

image-20220228223841427

5.5.6.去重名

select distinct 字段 from 表

select distinct department_id from employees;
  • 去重前,大量数据冗余,占用存储空间
  • 去重后
  • image-20220228225139754

5.5.7.加号的作用

背景:在java中加号的作用,可以是字符串连接符、运算符、自增

问题:如哈在MySQL将两个字符串连接起来呢?

使用concat(元素1,元素。。。。)

注意:当参与拼接的字段中有null参与时,结果必定为null

  • 在MySQL中加号只有运算符作用

  • MySQL作用分类:

  • 整型+整型------加法运算

  • 字符串+整型

    • 自动将字符串转换为整型成功了的话,继续加法运算
    • 自动将字符串转换为整型失败了的话,等于0+整型并计算出结果
  • null参与下,只要两个数中又有个是null结果必定为null

SELECT 'yanyu'+23;
SELECT NULL+23;
SELECT '12'+12;

image-20220228230542046

  • 转换失败,等于0+23

image-20220228230638721

  • null参与结果为null
  • image-20220228230722111
    转换成功
  • 将”姓“和”名“连接起来
select concat(last_name,first_name) as 名字 from employees;
desc departments;
#显示departments这个表的结构

image-20220228231324358

image-20220228231840280

5.5.8.判断某一项是否为NULL

  • ifnull(对象,返回值) as 别名

  • 奖金率commission_pct 可能为NULL

select ifnull(commission_pct,0) as 奖金率,commission_pct from employees;
/*
如果commission_pct为NULL,则返回值为0
*/

image-20220228233540351

SELECT CONCAT(`last_name`,`first_name`,`email`,IFNULL(`commission_pct`,0)) AS "put into" FROM employees;

image-20220228234206005

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@yanyu666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值