mysql中基本查询语句

mysql基本查询

1.查询语法
select [distinct]

  • | 列名,列名
    from 表
    where 条件

2.简单查询
#查询所有的商品.
select * from product;
#查询商品名和商品价格.
select pname,price from product;
#别名查询.使用的关键字是as(as可以省略的).表别名:
select * from product as p;
#别名查询.使用的关键字是as(as可以省略的).列别名:
select pname as pn from product;
#去掉重复值.
select distinct price from product;
#查询结果是表达式(运算查询):将所有商品的价格+10元进行显示.
select pname,price+10 from product;

3.条件查询
在这里插入图片描述
#查询商品名称为“花花公子”的商品所有信息:
SELECT * FROM product WHERE pname = ‘花花公子’
#查询价格为800商品
SELECT * FROM product WHERE price = 800
#查询价格不是800的所有商品
SELECT * FROM product WHERE price != 800
SELECT * FROM product WHERE price <> 800
SELECT * FROM product WHERE NOT(price = 800)
#查询商品价格大于60元的所有商品信息
SELECT * FROM product WHERE price > 60;
#查询商品价格在200到1000之间所有商品
SELECT * FROM product WHERE price >= 200 AND price <=1000;
SELECT * FROM product WHERE price BETWEEN 200 AND 1000;
#查询商品价格是200或800的所有商品
SELECT * FROM product WHERE price = 200 OR price = 800;
SELECT * FROM product WHERE price IN (200,800);
#查询含有’霸’字的所有商品
SELECT * FROM product WHERE pname LIKE ‘%霸%’;
#查询以’香’开头的所有商品
SELECT * FROM product WHERE pname LIKE ‘香%’;
#查询第二个字为’想’的所有商品
SELECT * FROM product WHERE pname LIKE ‘_想%’;
#商品没有分类的商品
SELECT * FROM product WHERE category_id IS NULL
#查询有分类的商品
SELECT * FROM product WHERE category_id IS NOT NULL

4.排序查询
通过order by语句,可以将查询出的结果进行排序。暂时放置在select语句的最后。
格式:

SELECT * FROM 表名 ORDER BY 排序字段 ASC|DESC;
#ASC 升序 (默认)
#DESC 降序

#查询id 为1 3 5 7的商品 并按价格降序排列
#使用价格排序(降序)
SELECT * FROM product ORDER BY price DESC;
#在价格排序(降序)的基础上,以分类排序(降序)
SELECT * FROM product ORDER BY price DESC,category_id DESC;
#显示商品的价格(去重复),并排序(降序)
SELECT DISTINCT price FROM product ORDER BY price DESC;

5.聚合函数
之前我们做的查询都是横向查询,它们都是根据条件一行一行的进行判断,而使用聚合函数查询是纵向查询,它是对一列的值进行计算,然后返回一个单一的值;另外聚合函数会忽略空值。

今天我们学习如下五个聚合函数:
count:统计指定列不为NULL的记录行数;
sum:计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
max:计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
min:计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
avg:计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

#查询商品的总条数
SELECT COUNT() FROM product;
#查询商品的价格和
select sum(price) as ‘totalprice’ FROM product;
#查询价格大于200商品的总条数
SELECT COUNT(
) FROM product WHERE price > 200;
#查询分类为’c001’的所有商品的总和
SELECT SUM(price) FROM product WHERE category_id = ‘c001’;
#查询分类为’c002’所有商品的平均价格
SELECT AVG(price) FROM product WHERE category_id = ‘c002’;
#查询商品的最大价格和最小价格
SELECT MAX(price),MIN(price) FROM product;
#查询pid为1 3 7 商品价格的平均值
#查询pid为1 3 7 14 商品价格的平均值

6.sql语句书写和执行的顺序
where后面不能写聚合函数,having后面可以使用聚合函数
sql语句书写顺序:
select…from…where…group by…having…order by…
sql语句执行顺序:
from…where…group by…having…select…order by…

where后面不能使用select中定义的别名

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值