本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
WHERE 子句
WHERE 子句包含聯結資料表或套用述詞至資料表中資料欄的條件。資料表可以藉由在 WHERE 子句或 FROM 子句中使用適當的語法進行內部聯結。外部連結條件必須在 FROM 子句中指定。
語法
[ WHERE condition ]
條件
任何產生布林值結果的搜尋條件,例如,資料表資料欄的聯結條件或述詞。以下範例為有效的聯結條件:
sales.listid=listing.listid sales.listid<>listing.listid
以下範例對於資料表中的資料欄是有效的條件:
catgroup like 'S%' venueseats between 20000 and 50000 eventname in('Jersey Boys','Spamalot') year=2008 length(catdesc)>25 date_part(month, caldate)=6
條件可分成簡單和複雜;若是複雜條件,您可以使用括號來隔離邏輯單位。在下列範例中,聯結條件會以括號包圍。
where (category.catid=event.catid) and category.catid in(6,7,8)
使用須知
您無法在 WHERE 子句中使用別名來參考選取清單表達式。
您無法限制 WHERE 子句中彙整函數的結果;請使用 HAVING 子句達成此目的。
WHERE 子句中限制的資料欄必須衍生自 FROM 子句中的資料表參考。
範例
以下查詢使用不同 WHERE 子句限制的組合,包括 SALES 和 EVENT 資料表的聯結條件、EVENTNAME 資料欄上的述詞,以及 STARTTIME 資料欄上的兩個述詞。
select eventname, starttime, pricepaid/qtysold as costperticket, qtysold from sales, event where sales.eventid = event.eventid and eventname='Hannah Montana' and date_part(quarter, starttime) in(1,2) and date_part(year, starttime) = 2008 order by 3 desc, 4, 2, 1 limit 10; eventname | starttime | costperticket | qtysold ----------------+---------------------+-------------------+--------- Hannah Montana | 2008-06-07 14:00:00 | 1706.00000000 | 2 Hannah Montana | 2008-05-01 19:00:00 | 1658.00000000 | 2 Hannah Montana | 2008-06-07 14:00:00 | 1479.00000000 | 1 Hannah Montana | 2008-06-07 14:00:00 | 1479.00000000 | 3 Hannah Montana | 2008-06-07 14:00:00 | 1163.00000000 | 1 Hannah Montana | 2008-06-07 14:00:00 | 1163.00000000 | 2 Hannah Montana | 2008-06-07 14:00:00 | 1163.00000000 | 4 Hannah Montana | 2008-05-01 19:00:00 | 497.00000000 | 1 Hannah Montana | 2008-05-01 19:00:00 | 497.00000000 | 2 Hannah Montana | 2008-05-01 19:00:00 | 497.00000000 | 4 (10 rows)