婷婷久久综合九色综合,欧美成色婷婷在线观看视频,偷窥视频一区,欧美日本一道道一区二区

<tt id="bu9ss"></tt>
  • <span id="bu9ss"></span>
  • <pre id="bu9ss"><tt id="bu9ss"></tt></pre>
    <label id="bu9ss"></label>

    當(dāng)前位置:首頁 >  站長 >  數(shù)據(jù)庫 >  正文

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

     2021-06-01 16:50  來源: 腳本之家   我來投稿 撤稿糾錯

      阿里云優(yōu)惠券 先領(lǐng)券再下單

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

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

    以下就為解決這種多對多關(guān)系查詢,且沒有關(guān)聯(lián)關(guā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

     

    補(bǔ)充:PostgreSQL 的子查詢 相關(guān)的知識 ,exists,any,all

    Subquery

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

     

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

    子查詢返回多條時,可以在 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就好;標(biāo)準(zhǔn)的寫法: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 ,與之相反,當(dāng)子查詢返回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;

     

    當(dāng)子查詢返回 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)

    表達(dá)式一般為 字段

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

    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:

    1x <> ANY (a,b,c)

    is equivalent to

    1x <> 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;

    文章來源:腳本之家

    來源地址:https://www.jb51.net/article/204611.htm

    申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

    相關(guān)文章

    熱門排行

    信息推薦