设为首页 加入收藏

TOP

MySQL优化之――查询(一)
2015-07-24 10:41:54 来源: 作者: 【 】 浏览:1
Tags:MySQL 优化 查询

MySQL中select的基本语法形式

?

select 属性列表
from 表名和视图列表
[where 条件表达式]
[group by 属性名[having 条件表达式]]
[order by 属性名[asc|desc]]
[limit 
  
   ,row count]
  

?

说明:

where子句:按照“条件表达式”指定的条件进行查询。

group by子句:按照“属性名”指定的字段进行分组。

having子句:有group by才能having子句,只有满足“条件表达式”中指定的条件的才能够输出。

group by子句通常和count()、sum()等聚合函数一起使用。

order by子句:按照“属性名”指定的字段进行排序。排序方式由“asc”和“desc”两个参数指出,默认是按照“asc”来排序,即升序。

?


建立测试表

创建测试表

?

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)
)

?

插入测试数据

?

INSERT INTO fruits(f_id,s_id,f_name,f_price)
VALUES('a1',101,'apple',5.2),
('b1',102,'blackberry',5.2),
('bs1',105,'orange',5.2),
('bs2',103,'melon',5.2),
('t1',106,'banana',5.2);

?

使用select语句查询f_id字段的数据

 
 
SELECT f_id,f_name FROM fruits

\

注意:MYSQL中SQL语句是不区分大小写的,因此select和SELECT作用是相同的

常用查询

?

SELECT * FROM fruits

SELECT f_id,f_name FROM fruits WHERE f_price >5.1

SELECT f_id,f_name FROM fruits WHERE s_id IN(101,102)

SELECT f_id,f_name FROM fruits WHERE s_id NOT IN(101,102)

SELECT f_id,f_name FROM fruits WHERE f_price BETWEEN 2 AND 10

SELECT f_id,f_name FROM fruits WHERE f_price NOT  BETWEEN 2 AND 10

?


带like的字符匹配查询

1、百分号通配符“%”,匹配任意长度的字符,甚至包括零字符

 
 
SELECT f_id,f_name FROM fruits WHERE f_name LIKE 'b%y'

\

2、下划线通配符“_”,一次只能匹配任意一个字符

下面语句有四个下划线

?

SELECT f_id,f_name FROM fruits WHERE f_name LIKE '____n'

?

\



查询空值

CREATE TABLE customers
(
  c_id INT  NOT NULL AUTO_INCREMENT,
  c_name CHAR(25) NOT NULL,
  c_city  CHAR(50)   NULL,
  PRIMARY KEY(c_id)
)

INSERT INTO customers(c_name,c_city)
VALUES('liming','china'),
('hongfang',NULL)

SELECT * FROM customers WHERE c_city IS NULL

\

 
 
SELECT * FROM customers WHERE c_city IS NOT NULL

\

?

AND、OR、DISTINCT关键字

SELECT f_id,f_name FROM fruits WHERE f_name LIKE '____n' AND f_id='bs2'

SELECT f_id,f_name FROM fruits WHERE f_name LIKE '____n' OR f_id='bs2'

SELECT DISTINCT s_id FROM fruits 

GROUP BY

 
 
SELECT s_id ,COUNT(1) AS total FROM fruits GROUP BY s_id

\

再插入两条记录

 
 
INSERT INTO fruits(f_id,s_id,f_name,f_price) VALUES('a6',101,'cherry',6), ('a8',102,'coconut',7) 

如果要查看每个供应商提供的水果的种类的名称,MYSQL中可以在GROUP BY中使用GROUP_CONCAT()函数,

将每个分组中各个字段的值显示出来

?

SELECT s_id,GROUP_CONCAT(f_name) AS NAMES FROM fruits GROUP BY s_id

?

\

SQLSERVER是没有GROUP_CONCAT()函数的,SQLSERVER要达到同样效果需要使用xml函数,MYSQL这方面做得非常好

having:过滤分组

根据s_id对fruits表中的数据进行分组,并显示水果种类大于1的分组信息

 
 
SELECT s_id ,GROUP_CONCAT(f_name) AS NAMES FROM fruits GROUP BY s_id HAVING COUNT(f_name)>1

\

在group by中使用with rollup

 
 
SELECT s_id ,COUNT(1) AS total FROM fruits GROUP BY s_id WITH ROLLUP

\

增加了最后一行,7表示total列的所有值的总和

注意:当使用ROLLUP时,不能同时使用ORDER BY子句进行结果排序,即ROLLUP和ORDER BY是互相排斥的!

?


limit限制查询结果的数量

在SQLSERVER中是使用TOP关键字,而在MYSQL中是使用LIMIT关键字

LIMIT[位置偏移量],行数

第一个“位置偏移量”参数指示MYSQL从哪一行开始显示,是一个可选参数,如果不指定“位置偏移量”

将会从表中第一条记录开始(第一条记录的位置偏移量是0,第二天记录的位置偏移量是1......以此类推)

第二个参数“行数”指示返回的记录条数

?

SELECT * FROM fruits

?

\

SELECT * FROM fruits LIMIT 4,3

\

上面结果返回从第5条记录行(因为从0开始数)开始之后的3条记录

注意:在MYSQL5.6中可以使用 LIMIT 4 OFFSET 3 ,意思是获取从第5行记录开始的3条记录,和 LIMIT4,3 返回的结果是一样的


子查询

子查询这个特性从MYSQL4.1开始引入。

插入测试数据

 
 
CREATE TABLE tbl1(num1 INT NOT NULL); CREATE TABLE tbl2(num2 INT NOT NULL) INSERT INTO tbl1 VALUES(1),(4),(13),(27); INSERT INTO tbl2 VALUES(6),(14),(11),
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MySQL详解(14)----------事务处.. 下一篇收藏23个MySQL常用查询语句

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Bash 脚本教程——Li (2025-12-26 07:53:35)
·实战篇!Linux shell (2025-12-26 07:53:32)
·整理了250个shell脚 (2025-12-26 07:53:29)
·HyperText Transfer (2025-12-26 07:20:48)
·半小时搞懂 HTTP、HT (2025-12-26 07:20:42)