zoukankan      html  css  js  c++  java
  • 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',...)

  • 相关阅读:
    Python中的sorted函数以及operator.itemgetter函数
    a=a+(a++);b=b+(++b);计算顺序,反汇编
    带基虚类的构造函数执行顺序
    开源系统管理资源大合辑
    linux的LNMP架构介绍、MySQL安装、PHP安装
    lamp下mysql安全加固
    ITSS相关的名词解释
    从苦逼到牛逼,详解Linux运维工程师的打怪升级之路
    Linux 文件系统概览
    Exchange2010批量删除邮件
  • 原文地址:https://www.cnblogs.com/alianbog/p/5615163.html
Copyright © 2011-2022 走看看