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

postgresql----SELECT的更多相关文章

  1. PostgreSQL SELECT INTO和INSERT INTO SELECT 两种表复制语句

    SELECT INTO和INSERT INTO SELECT两种表复制语句都可以用来复制表与表之间的数据,但是它们之间也有区别. 建表语句: bas_custom_rel表 CREATE TABLE ...

  2. UbuntuでPostgreSQLをインストールからリモートアクセスまでの手順

    PostgreSQLサーバの立ち上げに少しハマりましたので.メモしておきます. OS: Ubuntu14.04 LTS インストール 最初はPostgreSQLをインストールします.普通にapt-ge ...

  3. postgresql存储二进制大数据文件

    如果想把整个文件或图片存储在数据表的一个字段内,该字段可以选择二进制类型,然后将文件按二进制存储起来,文本文件也可以存在text字段内. 示例如下: 二进制类型bytea的操作(在最大值内,有内存限制 ...

  4. postgresql copy命令介绍

    COPY 命令可以快速的导入数据到postgresql数据库中,文件格式类似TXT.CVS之类.适合批量导入数据,速度比较快.注意COPY只能用于表,不能用于视图. COPY 命令里面的文件必须是由服 ...

  5. Postgresql与Oralce常用用法区别总结

    日期操作 1. 操作当前日期和时间 oracle Select SYSDATE FROM dual; PostgreSQL Select CURRENT_DATE; Select NOW();返回日期 ...

  6. Jmeter直连postgresql数据库进行压测

    关于Jmeter直连数据库进行压测,网上有好多教程了,pg数据库的相对少一些,今天自己测试了下,还是挺简单的,有个别需要注意的地方.相较于Loadrunner这么全面庞大的压测工具,Jmeter在数据 ...

  7. 关于PostgreSQL的SQL注入必知必会

    一.postgresql简介 postgresql是一款关系型数据库,广泛应用在web编程当中,由于其语法与MySQL不尽相同,所以其SQL注入又自成一派. 二.postgresql的SQL注入:(注 ...

  8. postgresql学习笔记--基础篇 - copy

    1. psql 导入/导出数据 psql支持文件数据导入到数据库,也支持数据库表数据导出到文件中. COPY命令和\copy 命令都支持这两类操作,但两者有如下区别: COPY 命令是SQL命令,\c ...

  9. SQLServer数据实时同步PostgreSQL

    SQLServer数据实时同步至PostgreSQL 前言: 为迎合工作需求有时候传送的数据保存在SQLServer中但由于工作需要需要保存到PostgreSQL中进行处理,本文主要通过在SQLSer ...

  10. Citus 分布式 PostgreSQL 集群 - SQL Reference(查询分布式表 SQL)

    如前几节所述,Citus 是一个扩展,它扩展了最新的 PostgreSQL 以进行分布式执行.这意味着您可以在 Citus 协调器上使用标准 PostgreSQL SELECT 查询进行查询. Cit ...

随机推荐

  1. 【转】MFC 字体LOGFONT

    Windows的字体LOGFONT LOGFONT是Windows内部字体的逻辑结构,主要用于设置字体格式,其定义如下:typedef struct tagLOGFONTA{    LONG      ...

  2. windows 开启端口

    场景: 解决方法: 选中入站规则,右键选择新建入站规则: 然后 选择“允许连接”,点“下一步”. 效果: 连接成功.

  3. Swing组件都采用MVC设计模式

    Swing组件都采用MVC(Model-View-Controller,既模型-视图-控制器)设计模式,从而可以实现GUI组件的显示逻辑和数据逻辑的分离,允许程序员自定义Render来改变GUI组件的 ...

  4. linux源代码编译安装OpenCV

    为了尽可能保证OpenCV的特性,使用OpenCV源代码编译安装在linux上.先从安装其依赖项開始,以ubuntu 14.04.X为例解说在Linux上源代码编译安装OpenCV,其它linux版本 ...

  5. 【Java面试题】7 构造器Constructor是否可被override?

    构造器Constructor不能被继承,因此不能重写Override,但可以被重载Overload. Constructor不能被继承,所以Constructor也就不能被override.每一个类必 ...

  6. 详解ASP.NET Core Docker部署

    前言 在前面文章中,介绍了 ASP.NET Core在 macOS,Linux 上基于Nginx和Jexus的发布和部署,本篇文章主要是如何在Docker容器中运行ASP.NET Core应用程序. ...

  7. openal 基础知识4

    二函数 1. buffer函数 void alGenBuffers(ALsizei n /* buffer数*/, ALuint * buffers /* buffer ID数组*/); void a ...

  8. Spring-DispatcherServlet说明

    使用spring MVC,配置DispatcherServlet是第一步. DispatcherServlet是一个Servlet,所以可以配置多个DispatcherServlet. Dispatc ...

  9. .net cs后台刷新aspx页面的四种方式

    一:Response.Redirect(Request.Url.ToString()); 二:Response.Write("<script language=javascript&g ...

  10. vs2013配置opencv3.2.0

    工具/原料 l VS2013 l OpenCV3.20http://jaist.dl.sourceforge.net/project/opencvlibrary/opencv-win/3.2.0/op ...