잠시만 기다려 주세요


 
HOME   |  여기는?   |  바다물때표   |  여러가지 팁 (809)  |  추천 및 재미 (78)  |  자료실 (17)  |  끄적거림 (467)  |  시나리오 (760)  |  드라마 대본 (248)  |  

2019년 11월 12일
바닥 바닥이 답이다. 바닥에서는 더이상 나를 내세울 필요가 없다. - 바다아이
 




    DATABASE

DATABASE - postgresql 엑셀 CSV 화일로 테이블 export/import 하기
이 름 : 바다아이   |   조회수 : 1248         짧은 주소 : https://www.bada-ie.com/su/?311533882509
테이블 데이터를 텍스트화일로 export 해보겠습니다.
 
[postgres@olmaster:~/oradba/csv]$ alias scott
alias scott='psql -d scottdb -U scott -W'
 
[postgres@olmaster:~/oradba/csv]$ scott
Password for user scott: 
Null display is "NULL".
Timing is on.
Pager is always used.
psql (9.2.1)
Type "help" for help.
 
scott@[local]:5432 scottdb#SQL> \copy emp to '~/oradba/csv/emp1.csv';
Time: 1.570 ms
scott@[local]:5432 scottdb#SQL> \! cat ~/oradba/csv/emp1.csv
7369    SMITH   CLERK   7902    1980-12-17      800     \N      20
7499    ALLEN   SALESMAN        7698    1981-02-20      1600    300     30
7521    WARD    SALESMAN        7698    1981-02-22      1250    500     30
7566    JONES   MANAGER 7839    1981-04-02      2975    \N      20
7654    MARTIN  SALESMAN        7698    1981-09-28      1250    1400    30
7698    BLAKE   MANAGER 7839    1981-05-01      2850    \N      30
7782    CLARK   MANAGER 7839    1981-06-09      2450    \N      10
7788    SCOTT   ANALYST 7566    1982-12-09      3000    \N      20
7839    KING    PRESIDENT       \N      1981-11-17      5000    \N      10
7844    TURNER  SALESMAN        7698    1981-09-08      1500    0       30
7876    ADAMS   CLERK   7788    1983-01-12      1100    \N      20
7900    JAMES   CLERK   7698    1981-12-03      950     \N      30
7902    FORD    ANALYST 7566    1981-12-03      3000    \N      20
7934    MILLER  CLERK   7782    1982-01-23      1300    \N      10
scott@[local]:5432 scottdb#SQL> \copy emp(empno,ename) to '~/oradba/csv/emp2.csv';
Time: 0.480 ms
scott@[local]:5432 scottdb#SQL> \! cat ~/oradba/csv/emp2.csv
7369    SMITH
7499    ALLEN
7521    WARD
7566    JONES
7654    MARTIN
7698    BLAKE
7782    CLARK
7788    SCOTT
7839    KING
7844    TURNER
7876    ADAMS
7900    JAMES
7902    FORD
7934    MILLER
scott@[local]:5432 scottdb#SQL> \copy emp(empno,ename) to '~/oradba/csv/emp3.csv' with delimiter ',' csv header
Time: 0.357 ms
scott@[local]:5432 scottdb#SQL> \! cat ~/oradba/csv/emp3.csv
empno,ename
7369,SMITH
7499,ALLEN
7521,WARD
7566,JONES
7654,MARTIN
7698,BLAKE
7782,CLARK
7788,SCOTT
7839,KING
7844,TURNER
7876,ADAMS
7900,JAMES
7902,FORD
7934,MILLER
scott@[local]:5432 scottdb#SQL> 
 
이제 새 테이블을 생성후에, emp3.csv 화일을  import 해보겠습니다.
 
[postgres@olmaster:~/oradba/csv]$ cat emp3.csv 
empno,ename
7369,SMITH
7499,ALLEN
7521,WARD
7566,JONES
7654,MARTIN
7698,BLAKE
7782,CLARK
7788,SCOTT
7839,KING
7844,TURNER
7876,ADAMS
7900,JAMES
7902,FORD
7934,MILLER
[postgres@olmaster:~/oradba/csv]$ scott
Password for user scott: 
Null display is "NULL".
Timing is on.
Pager is always used.
psql (9.2.1)
Type "help" for help.
 
scott@[local]:5432 scottdb#SQL> create table customer(no integer, name varchar(32));
CREATE TABLE
Time: 101.081 ms
scott@[local]:5432 scottdb#SQL> \copy customer(no,name) from '~/oradba/csv/emp3.csv' with delimiter ',' csv header
Time: 1.632 ms
scott@[local]:5432 scottdb#SQL> select * from customer;
  no  |  name  
------+--------
 7369 | SMITH
 7499 | ALLEN
 7521 | WARD
 7566 | JONES
 7654 | MARTIN
 7698 | BLAKE
 7782 | CLARK
 7788 | SCOTT
 7839 | KING
 7844 | TURNER
 7876 | ADAMS
 7900 | JAMES
 7902 | FORD
 7934 | MILLER
(14 rows)
 
Time: 0.481 ms
scott@[local]:5432 scottdb#SQL> 
 
오라클에 비하면, PostgreSQL 의 이런 기능은 너무 좋네요.
 
 
-----------------2013.07.12 추가 ------------------
 
필드값 내에 "," 가 들어가 있다면 다음과 같이 하면 됩니다.
[enterprisscottdb@dpcpdb03 oradba]$ cat a.csv
1,2,"super,man","spider","man"
 
[enterprisscottdb@dpcpdb03 oradba]$ psql
psql (9.2.4.8)
Type "help" for help.
 
scottdb=# create table ccc(a varchar(10), b varchar(10), c varchar(10), d varchar(10), e varchar(10));
CREATE TABLE
scottdb=# \copy ccc(a,b,c,d,e) from '~/oradba/a.csv' with csv  quote '"'
scottdb=# select * from ccc;
 a | b |     c     |   d    |  e  
---+---+-----------+--------+-----
 1 | 2 | super,man | spider | man
(1 row)
 
scottdb=# 
 
cf. 컬럼변환이 필요하면
 \copy ( SELECT CUST_NO ,TO_CHAR(REG_DTTM,'YYYY-MM-DD HH24:MI:SS') FROM ZZZ) to '/archive/dw.dat' with delimiter '|'
 
cf. export
copy (select * from from sql_trace
where snap_dt >= '$DATE2'
and snap_dt < '$DATE3'
order by snap_dt)
to '/Postgres/9.2/oradba/sql_move.csv' CSV QUOTE '"'



출처 : http://www.postgresdba.com/bbs/board.php?bo_table=B13&wr_id=4
 
| |


      1 page / 3 page
번 호 카테고리 제 목 이름 조회수
72 DATABASE db .. dbeaver, db admin tool 바다아이 1081
71 DATABASE postgresql SEQUENCE reset .... 바다아이 950
70 DATABASE mysql, mariadb , , , , left, substring, right, concat 바다아이 1294
69 DATABASE [PostgreSql] WITH , , Operator 바다아이 1043
68 DATABASE postgresql for, foreach , 바다아이 1084
67 DATABASE postgresql , , into ... 바다아이 993
66 DATABASE postgresql PL/pgSQL - SQL Procedural Language, , 바다아이 3193
65 DATABASE postgresql ... .. 바다아이 1255
현재글 DATABASE postgresql CSV export/import 바다아이 1249
63 DATABASE postgresql tablespace , .... 바다아이 1505
62 DATABASE postgresql 10 partitioning, ... , ... 바다아이 1242
61 DATABASE Using PostgreSQL Arrays, ... ... 바다아이 1293
60 DATABASE PostgreSQL (TRIGGER) (function) 바다아이 1213
59 DATABASE mysql, mariadb DISTINCT GROUP BY 바다아이 1145
58 DATABASE Optimize and Improve PostgreSQL Performance with VACUUM, ANALYZE, and REINDEX 바다아이 1927
57 DATABASE postgresql tuple . vacuumdb .. , . 바다아이 1265
56 DATABASE RDBMS SQL MONGODB ... 바다아이 1138
55 DATABASE mysql 5.x my.cnf 바다아이 1363
54 DATABASE postgresql , .. 바다아이 1448
53 DATABASE postgresql , size, 바다아이 1968
52 DATABASE postgresql , , .... 바다아이 1265
51 DATABASE PostgreSQL Replication, , , master, slave 바다아이 1634
50 DATABASE postgresql case 바다아이 1364
49 DATABASE postgresql with 바다아이 1343
48 DATABASE postgresql , , string 바다아이 1566
47 DATABASE / SELECT , 바다아이 1427
46 DATABASE Postgresql partitioning table , , , 바다아이 1589
45 DATABASE PostgreSQL 바다아이 1675
44 DATABASE postgresql vacuumdb, psql, pg_dump password crontab 바다아이 1819
43 DATABASE postgresql sequence 퀀 auto_increment . 바다아이 2249
| |




Copyright ⓒ 2001.12. bada-ie.com. All rights reserved.
이 사이트는 리눅스에서 firefox 기준으로 작성되었습니다. 기타 브라우저에서는 다르게 보일 수 있습니다.
[ FreeBSD + GoLang + PostgreSQL ]
서버위치 : 서울 Amazon Lightsail  실행시간 : 0.20369
to webmaster... gogo sea. gogo sea.