| PostgreSQL 8.0.0 中文文件(轉譯自 PostgreSQL 中國 製作的簡體中文版本) | ||||
|---|---|---|---|---|
| Prev | Fast Backward | Chapter 9. 函數和操作符 | Fast Forward | Next |
Table 9-31 顯示了可以用於 cidr 和 inet 的操作符。 操作符 <<,<<= >>,和 >>= 用於計算子網包含:它們只考慮兩個地址的網絡部分,忽略任何主機部分, 然後判斷其中一個網絡部分是等於另外一個還是另外一個的子網。
Table 9-31. cidr 和 inet 操作符
| 操作符 | 描述 | 例子 |
|---|---|---|
| < | 小於嗎 | inet '192.168.1.5' < inet '192.168.1.6' |
| <= | 小於或等於 | inet '192.168.1.5' <= inet '192.168.1.5' |
| = | 等於 | inet '192.168.1.5' = inet '192.168.1.5' |
| >= | 大於或等於 | inet '192.168.1.5' >= inet '192.168.1.5' |
| > | 大於 | inet '192.168.1.5' > inet '192.168.1.4' |
| <> | 不等於 | inet '192.168.1.5' <> inet '192.168.1.4' |
| << | 包含於 | inet '192.168.1.5' << inet '192.168.1/24' |
| <<= | 包含於或等於 | inet '192.168.1/24' <<= inet '192.168.1/24' |
| >> | 包含 | inet '192.168.1/24' >> inet '192.168.1.5' |
| >>= | 包含或等於 | inet '192.168.1/24' >>= inet '192.168.1/24' |
Table 9-32 顯示了所有可以用於 cidr 和 inet 的函數。 函數 host,text 和 abbrev 主要是為了提供可選的顯示格式用的。 您可以用普通的類型轉換語法︰ inet(expression) 或者 colname::inet 把一個文本數域轉換成inet。
Table 9-32. cidr 和 inet 函數
| 函數 | 返回類型 | 描述 | 例子 | 結果 |
|---|---|---|---|---|
| broadcast(inet) | inet | 網絡廣播地址 | broadcast('192.168.1.5/24') | 192.168.1.255/24 |
| host(inet) | text | 將主機地址類型抽出為文本 | host('192.168.1.5/24') | 192.168.1.5 |
| masklen(inet) | integer | 抽取網絡掩碼長度 | masklen('192.168.1.5/24') | 24 |
| set_masklen(inet,integer) | inet | 為inet數值設置網絡掩碼長度 | set_masklen('192.168.1.5/24',16) | 192.168.1.5/16 |
| netmask(inet) | inet | 為網絡構造網絡掩碼 | netmask('192.168.1.5/24') | 255.255.255.0 |
| hostmask(inet) | inet | 為網絡構造主機掩碼 | hostmask('192.168.23.20/30') | 0.0.0.3 |
| network(inet) | cidr | 抽取地址的網絡部分 | network('192.168.1.5/24') | 192.168.1.0/24 |
| text(inet) | text | 把 IP 地址和掩碼長度抽取為文本 | text(inet '192.168.1.5') | 192.168.1.5/32 |
| abbrev(inet) | text | 抽取縮寫顯示為文本 | abbrev(cidr '10.1.0.0/16') | 10.1/16 |
| family(inet) | integer | 抽取地址族 4 for IPv4, 6 for IPv6 | family('::1') | 6 |
Table 9-33 顯示了可以用於 macaddr 類型的函數。 函數 trunc(macaddr) 返回一個 MAC 地址,該地址的最後三個字元設置為零。 這樣可以把剩下的前綴與一個製造商相關聯。 源程序目錄 contrib/mac 裡有一些用於建立和維護這樣的 關聯資料表的工具。
Table 9-33. macaddr 函數
| 函數 | 返回類型 | 描述 | 例子 | 結果 |
|---|---|---|---|---|
| trunc(macaddr) | macaddr | 把後三個字元置為零 | trunc(macaddr '12:34:56:78:90:ab') | 12:34:56:00:00:00 |
macaddr 類型還支援標準關係操作符 (>,<=,等) 用於詞法排序。