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',...)

  • 相关阅读:
    可变参数
    数组初始化方式和多维数组
    向下转型的意义
    向上转型和向下转型
    equals
    命名规范
    安装elasticsearch的坑
    IntelliJ IDEA中创建xml文件
    IDEA优化内存配置,可提高启动和运行速度
    log报错的原因解决
  • 原文地址:https://www.cnblogs.com/alianbog/p/5615163.html
Copyright © 2011-2022 走看看