单表查询练习

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)
);
为了演示如何使用SELECT语句,需要插入如下数据:
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.6),
(‘m2’,105,‘xbabay’, 2.6),
(‘t4’,107,‘xbababa’, 3.6),
(‘m3’,105,‘xxtt’, 11.6),
(‘b5’,107,‘xxxx’, 3.6);
使用SELECT语句查询f_id字段的数据。

【例1】从fruits表中检索所有字段的数据,SQL语句如下:

mysql> select * from fruits;

【例2】查询fruits表中f_name列所有水果名称,SQL语句如下:

mysql> select f_name from fruits;

【例3】例如,从fruits表中获取f_name和f_price两列,SQL语句如下:

mysql> select f_name,f_price from fruits;

【例4】查询价格为10.2元的水果的名称,SQL语句如下:

mysql> select f_name from fruits
    -> where f_price=10.2;

【例5】查找名称为“apple”的水果的价格,SQL语句如下:

mysql> select * from fruits
    -> where f_name='apple';

【例6】查询价格小于10的水果的名称,SQL语句如下:

mysql> select * from fruits
    -> where f_name='apple';

【例7】s_id为101和102的记录,SQL语句如下:

mysql> select * from fruits
    -> where s_id=101 or s_id=102;

【例8】查询所有s_id不等于101也不等于102的记录,SQL语句如下:

mysql> select * from fruits
    -> where s_id not in(101,102);

【例9】查询价格在2.00元到10.20元之间的水果名称和价格,SQL语句如下:

mysql> select f_name,f_price from fruits
    -> where f_price>=2.00 and f_price<=10.2;

【例10】查询价格在2.00元到10.20元之外的水果名称和价格,SQL语句如下:

mysql> select f_name,f_price from fruits
    -> where f_price>=2.00 and f_price<=10.2;

【例11】查找所有以’b’字母开头的水果,SQL语句如下:

mysql> select f_name from fruits
    -> where f_name like 'b%';

【例12】在fruits表中,查询f_name中包含字母’g’的记录,SQL语句如下:

mysql> select * from fruits
    -> where f_name like '%g%';

【例13】查询以’b’开头,并以’y’结尾的水果的名称,SQL语句如下:

mysql> select f_name from fruits
    -> where f_name like 'b%y';

【例14】在fruits表中,查询以字母’y’结尾,且’y’前面只有4个字母的记录,SQL语句如下:

mysql> select * from fruits
    -> where f_name like '____y';

下面,在数据库中创建数据表customers,该表中包含了本章中需要用到的数据。
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(10) NULL,
c_contact char(50) NULL,
c_email char(255) NULL,
PRIMARY KEY (c_id)
);
为了演示需要插入数据,请读者插入执行以下语句。
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’, ‘LMing@163.com’),
(10002, ‘Stars’, ‘333 Fromage Lane’,
‘Dalian’, ‘116000’, ‘Zhangbo’,‘Jerry@hotmail.com’),
(10003, ‘Netbhood’, ‘1 Sunny Place’, ‘Qingdao’, ‘266000’,
‘LuoCong’, NULL),
(10004, ‘JOTO’, ‘829 Riverside Drive’, ‘Haikou’,
‘570000’, ‘YangShan’, ‘sam@hotmail.com’);
SELECT COUNT(*) AS cust_num FROM customers;
【例15】查询customers表中c_email为空的记录的c_id、c_name和c_email字段值,SQL语句如下:

mysql> select c_id,c_name,c_email from customers
    -> where c_email is null;

【例16】查询customers表中c_email不为空的记录的c_id、c_name和c_email字段值,SQL语句如下:

mysql> select c_id,c_name,c_email from customers
    -> where c_email is not null;

【例17】在fruits表中查询s_id = 101,并且f_price大于等于5的水果价格和名称,SQL语句如下:

mysql> select f_price,f_name from fruits
    -> where s_id=101 and f_price>5;

【例18】在fruits表中查询s_id = 101或者102,且f_price大于5,并且f_name=‘apple’的水果价格和名称,SQL语句如下:

mysql> select f_price,f_name from fruits
    -> where (s_id=101 or s_id=102) and f_price>5 and f_name='apple';

【例19】查询s_id=101或者s_id=102的水果供应商的f_price和f_name,SQL语句如下:

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

【例20】查询s_id=101或者s_id=102的水果供应商的f_price和f_name,SQL语句如下:

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

【例21】查询fruits表中s_id字段的值,返回s_id字段值且不得重复,SQL语句如下:

mysql> select distinct s_id from fruits;

【例22】查询fruits表的f_name字段值,并对其进行排序,SQL语句如下:

mysql> select f_name from fruits
    -> order by f_name desc;

【例23】查询fruits表中的f_name和f_price字段,先按f_name排序,再按f_price排序,SQL语句如下:

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

【例24】查询fruits表中的f_name和f_price字段,对结果按f_price降序方式排序,SQL语句如下:

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

【例25】查询fruits表,先按f_price降序排序,再按f_name字段升序排序,SQL语句如下:

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

【例26】根据s_id对fruits表中的数据进行分组,SQL语句如下:

mysql> select s_id from fruits
    -> group by s_id;

【例27】根据s_id对fruits表中的数据进行分组,将每个供应商的水果名称显示出来,SQL语句如下:

mysql> select s_id,group_concat(f_name) from fruits group by s_id;-------使用GROUP_CONCAT函数将每个供应商的水果名称连接成一个逗号分隔的列表,并将其显示为fruits_list列

【例28】根据s_id对fruits表中的数据进行分组,并显示水果种类大于1的分组信息,SQL语句如下:

mysql> SELECT s_id, COUNT(f_name) AS fruit_count, GROUP_CONCAT(DISTINCT f_name) AS fruits_list
    -> FROM fruits
    -> GROUP BY s_id
    -> HAVING COUNT(f_name) > 1;

【例29】根据s_id对fruits表中的数据进行分组,并显示记录数量,SQL语句如下:

mysql> SELECT s_id, COUNT(f_name) AS fruit_count, GROUP_CONCAT(f_name) AS fruits
_list
    -> FROM fruits
    -> GROUP BY s_id;

【例30】根据s_id和f_name字段对fruits表中的数据进行分组, SQL语句如下,

mysql> select s_id,f_name from fruits
    -> group by s_id,f_name;
  • 11
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值