PostgreSQL数据库去除重复数据和运算符的基本查询操作


Posted in PostgreSQL onApril 12, 2022

查询列

SELECT语句,用于从表中选取数据。
格式:

SELECT <列名>,...
FROM <表名>;

从Product表中,查询三列。

SELECT product_id, product_name, purchase_price
FROM Product;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

查询所有列,格式:

SELECT *FROM <表名>;

星号代表全部列。

SELECT *FROM Product;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

可以用AS关键字给列设定别名。

SELECT product_id     AS "商品编号",
       product_name   AS "商品名称",
       purchase_price AS "进货单价"
FROM Product;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

去除重复数据DISTINCT

SELECT DISTINCT product_type
FROM Product;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

这里的去除并不是真的就把重复的数据给删了,只是展示出来的数据是不重复的。

PostgreSQL数据库去除重复数据和运算符的基本查询操作

也可以在多列之前使用DISTINCT。

SELECT DISTINCT product_type, regist_date
FROM Product;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

WHERE子句

SELECT语句使用WHERE子句,查询出符合指定条件的数据。

格式:

SELECT <列名>,...
FROM <表名>
WHERE <条件表达式>;

例子:选取product_type = '衣服’的商品。

SELECT product_name, product_type
FROM Product
WHERE product_type = '衣服';

PostgreSQL数据库去除重复数据和运算符的基本查询操作

也可以按下面这个方式

SELECT product_name
FROM Product
WHERE product_type = '衣服';

PostgreSQL数据库去除重复数据和运算符的基本查询操作

注释

一行注释:

-- 本SELECT语句会从结果中删除重复行。
SELECT DISTINCT product_id, purchase_price
  FROM Product;

多行注释:

/* 本SELECT语句,
   会从结果中删除重复行。*/
SELECT DISTINCT product_id, purchase_price
  FROM Product;

算术运算符

算术运算符:+、-、*、/。

运算表达式中也可以用括号。

SELECT product_name, sale_price,
       sale_price * 2 AS “sale_price_x2"
  FROM Product;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

含有NULL的运算,结果都是NULL。

比较运算符

=表示等于、<>表示不等于、>=、<=、>、<。

SELECT product_name, product_type
  FROM Product
 WHERE sale_price = 500;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

SELECT product_name, product_type
  FROM Product
 WHERE sale_price <> 500;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

比较运算符,可以对几乎所有数据类型进行比较。

对字符串比较的时候,按照字典顺序比较。比如‘10’比‘2’小。

SELECT product_name, product_type, regist_date
  FROM Product
 WHERE regist_date < '2222-06-01';

PostgreSQL数据库去除重复数据和运算符的基本查询操作

WHERE子句的条件表达式中,可用计算表达式。

SELECT product_name, sale_price, purchase_price
  FROM Product
 WHERE sale_price - purchase_price >= 500;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

不能对NULL使用比较运算符。

如果选取NULL的记录,使用IS NULL运算符。

SELECT product_name, purchase_price
  FROM Product
 WHERE purchase_price IS NULL;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

选取不是NULL的记录,使用IS NOT NULL运算符。

SELECT product_name, purchase_price
  FROM Product
 WHERE purchase_price IS NOT NULL;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

逻辑运算符

NOT运算符:用于否定某一条件。

下面等价于WHERE sale_price < 1000;

SELECT product_name, product_type, sale_price
  FROM Product
 WHERE NOT sale_price >= 1000;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

AND运算符:

SELECT product_name, purchase_price
  FROM Product
 WHERE product_type = '厨房用具'
   AND sale_price >= 3000;

OR运算符:

SELECT product_name, purchase_price
  FROM Product
 WHERE product_type = '厨房用具'
    OR sale_price >= 3000;

PostgreSQL数据库去除重复数据和运算符的基本查询操作

AND运算符的优先级高于OR运算符,如果想要选出product_type = ‘办公用品’,而且登记日期为2222-02-22或2222-06-22,按照下面这个方式是不行的。

SELECT product_name, product_type, regist_date
  FROM Product
 WHERE regist_date = '2222-02-22' OR regist_date = '2222-06-22'
   AND product_type = '办公用品';

PostgreSQL数据库去除重复数据和运算符的基本查询操作

要优先执行OR运算符可以使用括号,如下所示。

SELECT product_name, product_type, regist_date
  FROM Product
 WHERE product_type = '办公用品'
   AND (   regist_date = '2222-02-22'
        OR regist_date = '2222-06-22');

PostgreSQL数据库去除重复数据和运算符的基本查询操作

比较运算符会把运算结果以真值形式返回,结果成立为真,不成立为假。

可以通过创建真值表,理解一些复杂的条件。

SELECT product_name, purchase_price
  FROM Product
 WHERE purchase_price = 2800;
SELECT product_name, purchase_price
  FROM Product
 WHERE NOT purchase_price = 2800;
SELECT product_name, purchase_price
  FROM Product

经观察发现,SQL中真值还有一种,叫UNKNOWN,既不真也不假,称之为不确定。

这是因为数据含有NULL。

因此,SQL中逻辑运算被称为三值逻辑。

PostgreSQL数据库去除重复数据和运算符的基本查询操作

以上就是PostgreSQL数据库的基本查询操作的详细内容

PostgreSQL 相关文章推荐
PostgreSQL通过oracle_fdw访问Oracle数据的实现步骤
May 21 PostgreSQL
postgresql使用filter进行多维度聚合的解决方法
Jul 16 PostgreSQL
基于PostgreSQL/openGauss 的分布式数据库解决方案
Dec 06 PostgreSQL
PostGIS的安装与入门使用指南
Jan 18 PostgreSQL
使用PostGIS完成两点间的河流轨迹及流经长度的计算(推荐)
Jan 18 PostgreSQL
Oracle配置dblink访问PostgreSQL的操作方法
Mar 21 PostgreSQL
PostgreSQL事务回卷实战案例详析
Mar 25 PostgreSQL
PostgreSQL并行计算算法及参数强制并行度设置方法
Apr 06 PostgreSQL
PostgreSQL 插入INSERT、删除DELETE、更新UPDATE、事务transaction
Apr 12 PostgreSQL
PostgreSQL出现死锁该如何解决
May 30 PostgreSQL
postgresql之greenplum字符串去重拼接方式
May 08 PostgreSQL
PostgreSQL聚合函数介绍以及分组和排序
PostgreSQL 插入INSERT、删除DELETE、更新UPDATE、事务transaction
PostgreSQL数据库创建并使用视图以及子查询
PostgreSQL并行计算算法及参数强制并行度设置方法
Apr 07 #PostgreSQL
PostgreSQL并行计算算法及参数强制并行度设置方法
Apr 06 #PostgreSQL
PostgreSQL事务回卷实战案例详析
Mar 25 #PostgreSQL
Oracle配置dblink访问PostgreSQL的操作方法
You might like
上传多个文件的PHP脚本
2006/11/26 PHP
PHP伪静态写法附代码
2008/06/20 PHP
php全局变量和类配合使用深刻理解
2013/06/05 PHP
PHP rsa加密解密使用方法
2015/04/27 PHP
PHP.ini安全配置检测工具pcc简单介绍
2015/07/02 PHP
Yii中实现处理前后台登录的新方法
2015/12/28 PHP
微信接口生成带参数的二维码
2017/07/31 PHP
PHP实现的各类hash算法长度及性能测试实例
2017/08/27 PHP
javascript 表格排序和表头浮动效果(扩展SortTable)
2009/04/07 Javascript
javascript实现的距离现在多长时间后的一个格式化的日期
2009/10/29 Javascript
jquery 简短右键菜单 多浏览器兼容
2010/01/01 Javascript
Javascript面向对象之四 继承
2011/02/08 Javascript
onkeypress字符按键兼容所有浏览器使用介绍
2013/04/24 Javascript
iframe里的页面禁止右键事件的方法
2014/06/10 Javascript
使用node.js 获取客户端信息代码分享
2014/11/26 Javascript
判断浏览器的内核及版本号方法汇总
2015/01/05 Javascript
javascript实现tab切换的两个实例
2015/11/05 Javascript
Zero Clipboard实现浏览器复制到剪贴板的方法(多个复制按钮)
2016/03/24 Javascript
AngularJS入门教程之控制器详解
2016/07/27 Javascript
详解Webpack + ES6 最新环境搭建与配置
2018/06/04 Javascript
layui type2 通过url给iframe子页面传值的例子
2019/09/06 Javascript
从源码角度来回答keep-alive组件的缓存原理
2021/01/18 Javascript
Python中用pycurl监控http响应时间脚本分享
2015/02/02 Python
Python面向对象之继承代码详解
2018/01/29 Python
Python中实现单例模式的n种方式和原理
2018/11/14 Python
django admin后台添加导出excel功能示例代码
2019/05/15 Python
通过实例简单了解Python中yield的作用
2019/12/11 Python
浅析python 字典嵌套
2020/09/29 Python
经典c++面试题二
2015/08/14 面试题
研究生导师推荐信
2014/09/06 职场文书
乡镇党委书记个人整改措施
2014/09/15 职场文书
2014年骨干教师工作总结
2014/12/19 职场文书
2016年党风廉政建设承诺书
2016/03/25 职场文书
学校就业保障协议书
2019/06/24 职场文书
Mysql数据库中datetime、bigint、timestamp来表示时间选择,谁来存储时间效率最高
2021/08/23 MySQL
Python实现滑雪小游戏
2021/09/25 Python