MySQL基本查询示例

1、创建所需表及插入数据

<!--创建表-->
mysql> create table fruits ( f_id char(10) not null, s_id int not null, f_name char(255) not null, f_price decimal(8,2) not null, primary key(f_id) );
<!--插入数据-->
mysql> insert into fruits(f_id,s_id,f_name,f_price)
    -> values(‘a1‘,101,‘apple‘,‘5.2‘),
    -> (‘b1‘,101,‘blackberry‘,‘10.2‘),
    -> (‘bs1‘,102,‘orange‘,‘11.2‘),
    -> (‘bs2‘,105,‘melon‘,‘8.2‘),
    -> (‘t1‘,102,‘banana‘,‘10.3‘),
    -> (‘t2‘,102,‘grape‘,‘5.3‘),
    -> (‘o2‘,103,‘coconut‘,‘9.2‘),
    -> (‘c0‘,101,‘cherry‘,‘3.2‘),
    -> (‘a2‘,103,‘apricot‘,‘2.2‘),
    -> (‘l2‘,104,‘lemon‘,‘6.4‘),
    -> (‘b2‘,104,‘berry‘,‘7.6‘),
    -> (‘m1‘,106,‘mango‘,‘15.7‘),
    -> (‘m2‘,105,‘xbabay‘,‘2.6‘),
    -> (‘t4‘,107,‘xbababa‘,‘2.6‘),
    -> (‘m3‘,105,‘xxtt‘,‘11.6‘),
    -> (‘b5‘,107,‘xxxx‘,‘3.6‘);
Query OK, 16 rows affected (0.01 sec)
Records: 16  Duplicates: 0  Warnings: 0
<!--创建第二个表-->
mysql> create table customers
    -> (
    -> c_id int not null auto_increment,
    -> c_name char(50) not null,
    -> c_address char(50) null,
    -> c_city char(50) null,
    -> c_zip char(50) null,
    -> c_contact char(50) null,
    -> c_email char(50) null,
    -> primary key(c_id)
    -> );
Query OK, 0 rows affected (0.00 sec)
<!--向第二张表插入数据-->
mysql> insert into customers(c_id,c_name,c_address,c_city,c_zip,c_contact,c_email)
    -> values(10001,‘RedHook‘,‘200 Street‘,‘Tianjin‘,‘300000‘,‘LiMing‘,‘[email protected]‘),
    -> (1002,‘Stars‘,‘333 Fromage Lane‘,‘Dalian‘,‘116000‘,‘Zhangbo‘,‘[email protected]‘),
    -> (10003,‘Netbhood‘,‘1 Sunny Place‘,‘Qingdao‘,‘266000‘,‘LuoCong‘,NULL),
    -> (1004,‘JOTO‘,‘829 Riverside Drive‘,‘Haikou‘,‘570000‘,‘YangShan‘,‘[email protected]‘);
Query OK, 4 rows affected (0.00 sec)
Records: 4  Duplicates: 0  Warnings: 0

2、查看两个表的所有数据

3、查询fruits表中f_name列的数据

mysql> select f_name from fruits;

查询结果:

4、查询fruits表中f_name和f_price两列的数据

mysql> select f_name,f_price from fruits;

返回结果如下:

5、查询fruits表中f_name和f_price的列,并且f_price的数值等于5.2

mysql> select f_name,f_price from fruits where f_price=5.2;

返回的结果如下:

6、查询fruits表中f_name和f_price的列,并且f_price的数值大于或等于10

mysql> select f_name,f_price from fruits where f_price >= 10;

返回的结果如下:

7、查询fruits表中f_name和f_price的列,并且f_price的数值在2到8之间

mysql> select f_name,f_price from fruits where f_price between 2 and 8;

返回的结果如下:

8、查询fruits表中的f_name和s_id列,并且s_id的值为101或者103

查询方法1:

mysql> select f_name,s_id from fruits
    -> where s_id = 101 or s_id = 103;

查询方法2:

mysql> select f_name,s_id from fruits
    -> where s_id in(101,103);

上述两种查询语句,返回的结果都一样,如下:

9、查询fruits表中的f_name和s_id列,并且s_id的值不为101或者103

查询方法1:

mysql> select f_name,s_id from fruits
    -> where s_id != 101 and s_id != 103;

查询方法2:

mysql> select f_name,s_id from fruits
    -> where s_id not in(101,103);

返回的结果如下:

10、模糊查询“%”和“_”的使用

<!--查询fruits表中的f_name列,并且值以“b”开头-->
mysql> select f_name from fruits where f_name like ‘b%‘;

返回的结果如下:

<!--查询fruits表中的f_name列,并且值以“b”开头,以“y”结尾-->
mysql> select f_name from fruits where f_name like ‘b%y‘;

返回的结果如下:

<!--查询fruits表中的f_name列,值以“b”开头,以“y”结尾,并且b和y之间有三个字符-->
mysql> select f_name from fruits where f_name like ‘b___y‘;

11、查询fruits表中s_id的值为101并且f_price的值大于2.0的行

mysql> select * from fruits
    -> where s_id = 101 and f_price > ‘2.0‘ ;

返回的结果如下:

12、查询fruits表中s_id的值为101或103并且f_price列的值大于5

mysql> select * from fruits where
    -> s_id in(101,103) and f_price > 5;

13、查询fruits表中的s_id列,并去除重复值

mysql> select distinct s_id from fruits;

返回结果如下:

14、查询fruits表中的s_id和f_name列,并以s_id对结果进行排序

mysql> select s_id,f_name from fruits order by s_id;

返回的结果如下:

15、查询fruits表中的f_name及f_price列,并以f_name和f_price列进行排序

mysql> select f_name,f_price from fruits
    -> order by f_name,f_price;

返回的结果如下:

注:多字段排序,如果第一个排序的字段一致,会依靠第二个字段排序,依次类推,如果第一个字段不一样,则直接以第一段来进行排序。

16、查询fruits表中的f_price列,并对结果以降序进行排序

<!--默认是asc升序排序,可以通过关键字DESC更改为降序-->
mysql> select f_price from fruits order by f_price desc;

17、查询fruits中s_id列不同值出现的次数,并对其进行分组显示

<!--调用count(*)函数统计次数,并通过as来对其设置别名,group by来进行分组-->
mysql> select s_id,count(*) as total from fruits group by s_id;

返回结果如下:

18、查询fruits表中每个相同的s_id对应的f_name列的所有值,f_name的值以一行显示,并且其值在1个以上

mysql> select s_id,group_concat(f_name) as name from fruits group by s_id having count(f_name) > 1;

返回的结果如下:

19、查询customers表中c_email列为空值的行

mysql> select * from customers where c_email is null;

查询结果如下:

———————— 本文至此结束,感谢阅读 ————————

原文地址:https://blog.51cto.com/14154700/2456603

时间: 2024-08-30 17:41:18

MySQL基本查询示例的相关文章

MySQL基本查询示例(2)

注:本博文基于上一篇博文中的表进行查询,上篇博文:MySQL基本查询示例(1). 1.查询fruits表中每个s_id对应的所有f_name值 <!--以组来进行紧凑--> mysql> select s_id,group_concat(f_name) as name from fruits group by s_id having count(f_name) > 1; 返回结果如下: 2.统计相同s_id值的行有多少? mysql> select s_id,count(*)

mysql高级排序&amp;高级匹配查询示例

在大多数应用场景下,我们使用mysql进行查询时只会用到'=', '>' , '<' , in, like 等常用的方法,看起来,大多数情况下,已经足以应付我们的小型应用了.不过,在一些特殊场景,则需要特殊的查询方式了. 1. 根据状态来排序的查询 假设现在一个记录有四种状态,未处理(0).正在处理(2).处理成功(1).处理失败(4),之所以他们的值是这个样子,是因为我们一般情况下是不会用它去排序,所以自然的就想到这样的一些值赋予意义.但是,在排序的时候怎么处理呢? 假如要求的先后顺序是这样

Mysql——子查询

子查询的位置: select 中.from 后.where 中.group by 和order by 中无实用意义. 子查询分为如下几类: 1,标量子查询:返回单一值的标量,最简单的形式. 2,列子查询:返回的结果集是 N 行一列. 3,行子查询:返回的结果集是一行 N 列. 4,表子查询:返回的结果集是 N 行 N 列. 可以使用的操作符:= > < >= <= <> ANY IN SOME ALL EXISTS 标量子查询:是指子查询返回的是单一值的标量,如一个数字

MySQL慢查询日志相关的配置和使用。

MySQL慢查询日志提供了超过指定时间阈值的查询信息,为性能优化提供了主要的参考依据,是一个非常实用的功能,MySQL慢查询日志的开启和配置非常简单,可以指定记录的文件(或者表),超过的时间阈值等就可以记录到慢sql了,实话讲,相比较sqlserver的trace或者扩展事件(虽然此二者的作用并非仅仅如此),MySQL的配置总是给人一种非常清爽的感觉. 1,慢查询日志的打开 正常情况下,只需要在配置文件中增加slow_query_log = 1配置,即打开慢查询日志,未指定slow_query_

MySQL慢查询(二) - pt-query-digest详解慢查询日志

一.简介 pt-query-digest是用于分析mysql慢查询的一个工具,它可以分析binlog.General log.slowlog,也可以通过SHOWPROCESSLIST或者通过tcpdump抓取的MySQL协议数据来进行分析.可以把分析结果输出到文件中,分析过程是先对查询语句的条件进行参数化,然后对参数化以后的查询进行分组统计,统计出各查询的执行时间.次数.占比等,可以借助分析结果找出问题进行优化. 二.安装pt-query-digest 1.下载页面:https://www.pe

[django/mysql] 使用distinct在mysql中查询多条不重复记录值的解决办法

前言:不废话.,直接进入正文 正文: 如何使用distinct在mysql中查询多条不重复记录值? 首先,我们必须知道在django中模型执行查询有两种方法: 第一种,使用django给出的api,例如filter value distinct order_by等模型查询api; 代码:LOrder.objects.values('finish_time').distinct() 这里应注意,原官方文档中写到: 示例(第一个之后的示例都只能在PostgreSQL 上工作): >>> Au

MySQL模糊查询:LIKE模式和REGEXP模式

MySQL模糊查询提供了两种模式:LIKE模式和REGEXP模式. LIKE模式 LIKE模式是使用的LIKE 或 NOT LIKE 比较运算符进行模糊查询. SELECT 字段 FROM 表 WHERE 字段 LIKE[NOT LIKE] '条件' 针对条件,有以下几种通配符: 通配符 含义 % 表示任意一个或多个字符,可匹配任意类型和长度的字符 _ 表示任意单个字符,匹配单个任意字符 ESCAPE 关键字定义转义符.在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符. 示例: #

Oracle和MySQL分组查询GROUP BY

Oracle和MySQL分组查询GROUP BY 真题1.Oracle和MySQL中的分组(GROUP BY)有什么区别? 答案:Oracle对于GROUP BY是严格的,所有要SELECT出来的字段必须在GROUP BY后边出现,否则会报错:“ORA-00979: not a GROUP BY expression”.而MySQL则不同,如果SELECT出来的字段在GROUP BY后面没有出现,那么会随机取出一个值,而这样查询出来的数据不准确,语义也不明确.所以,作者建议在写SQL语句的时候,

mysql慢查询功能详解

有人的地方就有江湖,数据库也是,sql优化这个问题,任重道远,我们总是禁不住有烂sql.怎么办呢,还好各大数据库都有相关烂sql的收集功能,而mysql的慢查询收集也是异曲同工,配合分析sql的执行计划,这个优化就有了搞头了. 开启mysql慢查询日志1.查看当前慢查询设置情况 #查看慢查询时间,默认10s,建议降到1s或以下, mysql> show variables like "long_query_time"; +-----------------+----------+