selec查询、分页查询及优化

 1. select查询

select _column,_column from _table [where Clause] [limit N][offset M]

解析:LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。

/*  注意:mysql数据库中LIMIT分页查询时,索引是从0开始的(0,1,2,3....)  */

  •  select * : 返回所有记录
  •  limit N : 返回 N 条记录
  •  offset M : 跳过 M 条记录, 默认 M=0, 单独使用似乎不起作用
  •  limit N,M  =  limit M offset N ,  从第 N+1 条记录开始, 返回 M 条记录 

#检索记录行 6-15   

select * FROM table LIMIT 5,10

#为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1。 检索记录行 96-last.

SELECT * FROM table LIMIT 95,-1

LIMIT n 等价于 LIMIT 0,n

不同的查询语句:

/*websites  表名   NAME alexa url country  字段*/
SELECT * FROM websites;                      /* 查询表所有数据 */

SELECT NAME FROM websites;                   /* 查询表字段数据 */

SELECT * FROM websites where name = "广西";   /* 查询表字段下条件数据 */

SELECT * from websites where name like "_o%"; /* 模糊查询表下数据 */

SELECT * FROM websites where id BETWEEN "1" AND "5";    /* 查询表下字段范围数据 */

SELECT * FROM websites WHERE name in ("广西","百度");    /* 查询表字段下固定条件数据 */

SELECT DISTINCT country FROM Websites;                  /* 查询去重值 */

SELECT * FROM Websites WHERE country = "CN" AND alexa > 50;  /*查询表下范围条件数据*/

SELECT * FROM Websites WHERE country = "USA" OR country="sh"; /* 查询表下条件不同值 */

SELECT * FROM Websites ORDER BY alexa;                      /* 查询表下值排序结果 */

SELECT * FROM Websites ORDER BY alexa DESC;                 /* 查询表下排序结果降序 */

SELECT * FROM Websites LIMIT 2;      /* 查询表下范围数据 */

SELECT name as zzz from websites;    /*别名查询表下数据*/

 

 

 

2.实现分页:

select * from _table limit (page_number-1)*lines_perpage, lines_perpage

select * from _table limit lines_perpage offset (page_number-1)*lines_perpage

 

2.1 最基本的分页方式:

SELECT ... FROM ... WHERE ... ORDER BY ... LIMIT ...

在中小数据量的情况下,这样的 SQL 足够用了,唯一需要注意的问题就是确保使用了索引。

举例来说,如果实际 SQL 类似下面语句,那么在 category_id, id 两列上建立复合索引比较好。

SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 50, 10

2.2 子查询的分页方式

随着数据量的增加,页数会越来越多,查看后几页的 SQL 就可能类似:

SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 10000, 10    

一言以蔽之,就是越往后分页,LIMIT 语句的偏移量就会越大,速度也会明显变慢

此时,我们可以通过子查询的方式来提高分页效率,大致如下:

SELECT * FROM articles WHERE  id >=
 (SELECT id FROM articles  WHERE category_id = 123 ORDER BY id LIMIT 10000, 1) LIMIT 10     

 

另外,如果需要查询 id 不是连续的一段,最佳的方法就是先找出 id ,然后用 in 查询

SELECT * FROM table WHERE id >= (SELECT id FROM table LIMIT 1000000, 1) LIMIT 10  速度提升到0.x秒

2.3 继续优化

SELECT * FROM table WHERE id BETWEEN 1000000 AND 1000010   比上面那句,还要再快5至10倍

为什么会这样呢?因为子查询是在索引上完成的,而普通的查询时在数据文件上完成的,通常来说,索引文件要比数据文件小得多,所以操作起来也会更有效率。

实际可以利用类似策略模式的方式去处理分页,比如判断如果是一百页以内,就使用最基本的分页方式,大于一百页,则使用子查询的分页方式。

 

 

你可能感兴趣的:(数据库)