postgresql----SELECT

示例1.简单查询

使用*查询表所有的字段,也可以指定字段名查询

test=# select * from tbl_insert;
 a | b  
---+----
 3 | sd
 4 | ff
(2 rows)

test=# select a from tbl_insert;
 a 
---
 3
 4
(2 rows)

 

示例2.聚合函数

聚合函数是使用多行数据,经过计算得到一个结果,如count,max,min,avg,sum等。聚合函数不能与具体字段出现在SELECT子句中,关系型数据库的表本就是每一列行数是相等的,聚合函数结果固定只有一行,而具体字段行数是不固定的。

test=# select * from tbl_insert;
  a   | b  
------+----
    3 | sd
    4 | ff
 NULL | sd
(3 rows)

test=# select sum(a),count(*),count(a),count(1),avg(a),max(a),min(a) from tbl_insert;
 sum | count | count | count |        avg         | max | min 
-----+-------+-------+-------+--------------------+-----+-----
   7 |     3 |     2 |     3 | 3.5000000000000000 |   4 |   3
(1 row)

从结果中看到sum(a)=7,count(*)=3,count(a)=2,count(1)=3,avg(a)=3.5,指定字段使用count(a)和avg(a)跳过a是NULL的行。

示例4.WHERE条件查询

 WHERE后面可以跟多种逻辑判断,如某个字段>,>=,<,<=,=,!=,between A and B(即>=A and <=B),in,not in,exists,not exists,like,ilike等,逻辑与使用AND,逻辑或使用OR,不等于使用!=或<>,但是我经常记不住逻辑符的优先级,尤其是where条件比较复杂时脑袋就大了,所以我习惯在多个逻辑符使用小括号()。

test=# create table tbl_insert(a int,b varchar(32));
CREATE TABLE
test=# insert into tbl_insert(a,b) values (1,'a'),(2,'b'),(3,'c'),(4,'d'),(5,'e');
--查询a等于1的行 test=# select * from tbl_insert where a = 1; a | b ---+--- 1 | a (1 row) --查询a不等于2的行 test=# select * from tbl_insert where a != 2; a | b ---+--- 1 | a 3 | c 4 | d 5 | e (4 rows) test=# select * from tbl_insert where a <> 2; a | b ---+--- 1 | a 3 | c 4 | d 5 | e (4 rows) --查询a大于等于3的行 test=# select * from tbl_insert where a >= 3; a | b ---+--- 3 | c 4 | d 5 | e (3 rows) --查询a大于等于1且小于等于3的行 test=# select * from tbl_insert where a >= 1 and a <= 3; a | b ---+--- 1 | a 2 | b 3 | c (3 rows) test=# select * from tbl_insert where a between 1 and 3; a | b ---+--- 1 | a 2 | b 3 | c (3 rows) --查询a大于3且b是'd'或'e'的行 test=# select * from tbl_insert where a > 3 and (b='d' or b = 'e'); a | b ---+--- 4 | d 5 | e (2 rows) test=# select * from tbl_insert where a > 3 and b in ('d','e'); a | b ---+--- 4 | d 5 | e (2 rows) --查询a大于3或b是'd'或b是'e'的行 test=# select * from tbl_insert where a > 3 or (b='d' or b = 'e'); a | b ---+--- 4 | d 5 | e (2 rows) test=# select * from tbl_insert where a > 3 or b in('d','e'); a | b ---+--- 4 | d 5 | e (2 rows)

 

不建议使用如下方式查询,当表中数据量较大,or条件中数量太多,会有明显的性能影响。

b='d' or b = 'e' or b = or b = or b = ...

 

建议使用in解决此问题,即

b in ('d','e',...)

 

posted @ 2016-06-25 22:03  alianblog  阅读(2770)  评论(0编辑  收藏  举报