91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么理解PostgreSQL12 COPY和bulkloading有什么特性

發布時間:2021-11-09 11:21:38 來源:億速云 閱讀:118 作者:iii 欄目:關系型數據庫

本篇內容主要講解“怎么理解PostgreSQL12 COPY和bulkloading有什么特性”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么理解PostgreSQL12 COPY和bulkloading有什么特性”吧!

業務是否依賴COPY命令加載數據?PostgreSQL12提供了一個新特性,大大加快了加載速度。

COPY:Loading and unloading data as fast as possible

細看PostgreSQL12的COPY語法,發現有兩處變動:

1)\h 會有手冊文檔鏈接

2)COPY支持WHERE條件

下面是完整語法:

db12=# \h COPY
Command:     COPY
Description: copy data between a file and a table
Syntax:
COPY table_name [ ( column_name [, ...] ) ]
    FROM { 'filename' | PROGRAM 'command' | STDIN }
    [ [ WITH ] ( option [, ...] ) ]
    [ WHERE condition ]
COPY { table_name [ ( column_name [, ...] ) ] | ( query ) }
    TO { 'filename' | PROGRAM 'command' | STDOUT }
    [ [ WITH ] ( option [, ...] ) ]
where option can be one of:
    FORMAT format_name
    FREEZE [ boolean ]
    DELIMITER 'delimiter_character'
    NULL 'null_string'
    HEADER [ boolean ]
    QUOTE 'quote_character'
    ESCAPE 'escape_character'
    FORCE_QUOTE { ( column_name [, ...] ) | * }
    FORCE_NOT_NULL ( column_name [, ...] )
    FORCE_NULL ( column_name [, ...] )
    ENCODING 'encoding_name'
URL: https://www.postgresql.org/docs/12/sql-copy.html

雖然添加文檔鏈接功能帶來便利,但是WHERE過濾功能更加有用。這個功能的目的是什么?當前,COPY只能導入整個文件。但是某些場景下會有問題:很多場景下,人們只想加載數據的一個子集,并且在導出前必須編寫大量代碼進行過濾。

COPY...WHERE: 導入時過濾

PostgreSQL通過該條件可以輕松地進行過濾。下面講述一個簡單的例子:

db12=# CREATE TABLE t_demo AS
        SELECT * FROM generate_series(1, 1000) AS id;
SELECT 1000

首先先插入1000行數據,然后導出到一個文件:

db12=# COPY t_demo TO '/tmp/file.txt';
COPY 1000

最后,再重新導入數據:

db12=# CREATE TABLE t_import (x int);
CREATE TABLE
db12=# COPY t_import FROM '/tmp/file.txt' WHERE x < 5;
COPY 4
db12=# SELECT * FROM t_import;
 x
---
 1
 2
 3
 4
(4 rows)

如上說是,過濾數據非常簡單直接。需要注意,導出列是“id”,導入列是“x”。文件文件不知道導入表的表結構---需要確保過濾導入表的列名。

其他特性

COPY可以將數據發送到UNIX pipe,還可以從pipe中讀取數據。如下所示:

db12=# COPY t_demo TO PROGRAM 'gzip -c > /tmp/file.txt.gz';
COPY 1000
db12=# COPY t_import FROM PROGRAM 'gunzip -c /tmp/file.txt.gz'
    WHERE x BETWEEN 100 AND 103;
COPY 4
db12=# SELECT * FROM t_import WHERE x >= 100;
  x  
-----
 100
 101
 102
 103
(4 rows)

某些場景下,不止想將數據導出。上面場景,我們想導出數據時將數據壓縮;導入時將數據解壓并過濾。如上所示,這種方法非常簡單。

到此,相信大家對“怎么理解PostgreSQL12 COPY和bulkloading有什么特性”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阿克| 房山区| 临汾市| 黎平县| 东宁县| 濮阳市| 信阳市| 铅山县| 左云县| 三台县| 乌拉特前旗| 阳西县| 开鲁县| 义马市| 汽车| 茂名市| 七台河市| 年辖:市辖区| 方城县| 都兰县| 印江| 鄂尔多斯市| 阆中市| 广安市| 定西市| 丰原市| 广平县| 富川| 体育| 高陵县| 甘德县| 沁源县| 绥德县| 高要市| 民权县| 象山县| 南开区| 南召县| 巴林左旗| 耿马| 衡山县|