濮阳杆衣贸易有限公司

主頁 > 知識庫 > PostgreSQL 實現(xiàn)子查詢返回多行的案例

PostgreSQL 實現(xiàn)子查詢返回多行的案例

熱門標簽:移動外呼系統(tǒng)模擬題 400電話申請客服 電話機器人怎么換人工座席 電銷機器人能補救房產中介嗎 濟南外呼網絡電話線路 廣州電銷機器人公司招聘 江蘇400電話辦理官方 地圖標注要花多少錢 天津開發(fā)區(qū)地圖標注app

作為一個表達式使用的子查詢返回了多列:

在查詢中,我們需要以第2條查詢語句作為第一條查詢語句的條件,但是第一條根據(jù)這個條件查詢出來是多個數(shù)據(jù),這時候又需要保留多個數(shù)據(jù),運用子查詢就會報錯,

以下就為解決這種多對多關系查詢,且沒有關聯(lián)關系的表的解決方案:

select c.rain_value,c.ad_nm from 
(
select *, json::json->t2.lon_lat as rain_value from actual_time_model_json t1,
(SELECT DISTINCT lon || '_' || lat as lon_lat,ad_nm from grid_all_points_null)t2 where section='0' and t1.filename = 'Z_NWGD_C_BCCD_20180711022009_P_RFFC_SPCC-ER01_201807110800_02401.GRB2'
)c where c.rain_value is not null

補充:PostgreSQL 的子查詢 相關的知識 ,exists,any,all

Subquery

SELECT
 film_id,
 title,
 rental_rate
FROM
 film
WHERE
 rental_rate > (
  SELECT
   AVG (rental_rate)
  FROM
   film
 );

有了子查詢,在設定 需要查詢表才能得到 查詢條件時,就可以 直接 在一條語句中 寫,不用分開多條寫了,方便了許多。

子查詢返回多條時,可以在 where 子句中 用 IN,來匹配查詢條件。

SELECT
 film_id,
 title
FROM
 film
WHERE
 film_id IN (
  SELECT
   inventory.film_id
  FROM
   rental
  INNER JOIN inventory ON inventory.inventory_id = rental.inventory_id
  WHERE
   return_date BETWEEN '2005-05-29'
  AND '2005-05-30'
 );

EXISTS 操作符

在 where 子句的 查詢條件中,exists 操作符,會在子查詢有返回行時,返回true;不論返回幾行。

因此,子查詢中的查詢字段僅寫1就好;標準的寫法:EXISTS (SELECT 1 FROM tbl WHERE condition)

SELECT
 first_name,
 last_name
FROM
 customer
WHERE
 EXISTS (
  SELECT
   1
  FROM
   payment
  WHERE
   payment.customer_id = customer.customer_id
 );

NO EXISTS ,與之相反,當子查詢返回0行時,返回true

SELECT first_name,
  last_name
FROM customer c
WHERE NOT EXISTS
 (SELECT 1
  FROM payment p
  WHERE p.customer_id = c.customer_id
  AND amount > 11 )
ORDER BY first_name,
   last_name;

當子查詢返回 NULL,會返回true, 也就是返回所有行。

SELECT
 first_name,
 last_name
FROM
 customer
WHERE
 EXISTS( SELECT NULL )
ORDER BY
 first_name,
 last_name;

ANY

與任何子查詢返回的 值 匹配就 返回 true

expresion operator ANY(subquery)

表達式一般為 字段

操作符為 >,,=,>,>=,=

ANY 可以與 SOME 替換

子查詢 返回的 必須是 一列,

SELECT title
FROM film
WHERE length >= ANY(
 SELECT MAX( length )
 FROM film
 INNER JOIN film_category USING(film_id)
 GROUP BY category_id );

The = ANY is equivalent to IN operator.

Note that the > ANY operator is different from NOT IN. The following expression:

x > ANY (a,b,c) 

is equivalent to

x > a OR x > b OR x > c

ALL

所有子查詢返回的值 匹配 則 返回 true

也就是 大于最大,小于最小

SELECT
 film_id,
 title,
 length
FROM
 film
WHERE
 length > ALL (
   SELECT
    ROUND(AVG (length),2)
   FROM
    film
   GROUP BY
    rating
 )
ORDER BY
 length;

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • postgresql 查詢字符串中是否包含某字符的操作
  • PostgreSQL 慢查詢SQL跟蹤操作
  • Visual Studio Code(VS Code)查詢PostgreSQL拓展安裝教程圖解
  • PostgreSQL 實現(xiàn)給查詢列表增加序號操作
  • 基于postgresql查詢某個字段屬于哪個表的說明
  • 基于postgreSql 常用查詢小結

標簽:榆林 昭通 寶雞 海西 濮陽 溫州 杭州 辛集

巨人網絡通訊聲明:本文標題《PostgreSQL 實現(xiàn)子查詢返回多行的案例》,本文關鍵詞  PostgreSQL,實現(xiàn),子,查詢,返回,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL 實現(xiàn)子查詢返回多行的案例》相關的同類信息!
  • 本頁收集關于PostgreSQL 實現(xiàn)子查詢返回多行的案例的相關信息資訊供網民參考!
  • 推薦文章
    左云县| 芒康县| 石屏县| 德保县| 乐亭县| 页游| 通许县| 桃江县| 海阳市| 靖江市| 兴海县| 金塔县| 加查县| 大城县| 平塘县| 福州市| 清水县| 万源市| 萍乡市| 梁平县| 宝鸡市| 紫金县| 湛江市| 龙门县| 垫江县| 油尖旺区| 抚顺县| 宜都市| 赣榆县| 惠东县| 茂名市| 韶山市| 荃湾区| 札达县| 托克逊县| 三亚市| 维西| 西丰县| 大港区| 莆田市| 彭阳县|