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存储过程实用脚本(二):创建函数入门
Apr 05 PostgreSQL
PostgreSQL将数据加载到buffer cache中操作方法
Apr 16 PostgreSQL
通过Qt连接OpenGauss数据库的详细教程
Jun 23 PostgreSQL
PostgreSQL解析URL的方法
Aug 02 PostgreSQL
关于PostgreSQL JSONB的匹配和交集问题
Sep 14 PostgreSQL
Rust 连接 PostgreSQL 数据库的详细过程
Jan 22 PostgreSQL
PostgreSQL并行计算算法及参数强制并行度设置方法
Apr 07 PostgreSQL
PostgreSQL数据库创建并使用视图以及子查询
Apr 11 PostgreSQL
PostgreSQL数据库去除重复数据和运算符的基本查询操作
Apr 12 PostgreSQL
PostgreSQL怎么创建分区表详解
Jun 25 PostgreSQL
PostgreSQL之连接失败的问题及解决
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四舍五入精确小数位及取整
2014/01/14 PHP
CMSPRESS 10行代码搞定 PHP无限级分类2
2018/03/30 PHP
如何用js控制css中的float的代码
2007/08/16 Javascript
ExtJS 工具栏 分页事件参数
2010/03/05 Javascript
对xmlHttp对象的理解
2011/01/17 Javascript
namespace.js Javascript的命名空间库
2011/10/11 Javascript
js实现的切换面板实例代码
2013/06/17 Javascript
js设置document.domain实现跨域的注意点分析
2015/05/21 Javascript
jQuery实现form表单基于ajax无刷新提交方法详解
2015/12/08 Javascript
深入浅析JSON.parse()、JSON.stringify()和eval()的作用详解
2016/04/03 Javascript
jquery validate表单验证插件
2016/09/06 Javascript
详解Vuejs2.0 如何利用proxyTable实现跨域请求
2017/08/03 Javascript
限时抢购-倒计时的完整实例(分享)
2017/09/17 Javascript
vue router下的html5 history在iis服务器上的设置方法
2017/10/18 Javascript
原生javascript实现文件异步上传的实例讲解
2017/10/26 Javascript
Vue中Quill富文本编辑器的使用教程
2018/09/21 Javascript
Vue中多个元素、组件的过渡及列表过渡的方法示例
2019/02/13 Javascript
在node环境下parse Smarty模板的使用示例代码
2019/11/15 Javascript
微信小程序 this.triggerEvent()的具体使用
2019/12/10 Javascript
uni-app使用微信小程序云函数的步骤示例
2020/05/22 Javascript
python网络编程实例简析
2014/09/26 Python
Python中使用PIPE操作Linux管道
2015/02/04 Python
Python中的rfind()方法使用详解
2015/05/19 Python
解决python3爬虫无法显示中文的问题
2018/04/12 Python
python+pandas分析nginx日志的实例
2018/04/28 Python
python三大神器之fabric使用教程
2019/06/10 Python
解决webdriver.Chrome()报错:Message:'chromedriver' executable needs to be in Path
2019/06/12 Python
python实现网站用户名密码自动登录功能
2019/08/09 Python
Scrapy框架实现的登录网站操作示例
2020/02/06 Python
Python代码覆盖率统计工具coverage.py用法详解
2020/11/25 Python
一款利用html5和css3动画排列人物头像的实例演示
2014/12/05 HTML / CSS
莱德杯高尔夫欧洲官方商店:Ryder Cup Shop
2019/08/14 全球购物
Jacques Lemans德国:奥地利钟表品牌
2019/12/26 全球购物
简述安装Slackware Linux系统的过程
2012/01/12 面试题
幼教个人求职信范文
2013/12/02 职场文书
大学生党员个人总结
2015/02/13 职场文书