How to import CSV file data into a PostgreSQL table?

前端 未结 19 2343
再見小時候
再見小時候 2020-11-22 02:14

How can I write a stored procedure that imports data from a CSV file and populates the table?

相关标签:
19条回答
  • 2020-11-22 03:05

    DBeaver Community Edition (dbeaver.io) makes it trivial to connect to a database, then import a CSV file for upload to a PostgreSQL database. It also makes it easy to issue queries, retrieve data, and download result sets to CSV, JSON, SQL, or other common data formats.

    It is a FOSS multi-platform database tool for SQL programmers, DBAs and analysts that supports all popular databases: MySQL, PostgreSQL, SQLite, Oracle, DB2, SQL Server, Sybase, MS Access, Teradata, Firebird, Hive, Presto, etc. It's a viable FOSS competitor to TOAD for Postgres, TOAD for SQL Server, or Toad for Oracle.

    I have no affiliation with DBeaver. I love the price (FREE!) and full functionality, but I wish they would open up this DBeaver/Eclipse application more and make it easy to add analytics widgets to DBeaver / Eclipse, rather than requiring users to pay for the $199 annual subscription just to create graphs and charts directly within the application. My Java coding skills are rusty and I don't feel like taking weeks to relearn how to build Eclipse widgets, (only to find that DBeaver has probably disabled the ability to add third-party widgets to the DBeaver Community Edition.)

    Can DBeaver power users who are Java developers provide some insight about the steps to create analytics widgets to add into the Community Edition of DBeaver?

    0 讨论(0)
  • 2020-11-22 03:06
    1. create a table first

    2. Then use copy command to copy the table details:

    copy table_name (C1,C2,C3....)
    from 'path to your csv file' delimiter ',' csv header;

    Thanks

    0 讨论(0)
  • 2020-11-22 03:08

    As Paul mentioned, import works in pgAdmin:

    right click on table -> import

    select local file, format and coding

    here is a german pgAdmin GUI screenshot:

    similar thing you can do with DbVisualizer (I have a license, not sure about free version)

    right click on a table -> Import Table Data...

    0 讨论(0)
  • 2020-11-22 03:11

    One quick way of doing this is with the Python pandas library (version 0.15 or above works best). This will handle creating the columns for you - although obviously the choices it makes for data types might not be what you want. If it doesn't quite do what you want you can always use the 'create table' code generated as a template.

    Here's a simple example:

    import pandas as pd
    df = pd.read_csv('mypath.csv')
    df.columns = [c.lower() for c in df.columns] #postgres doesn't like capitals or spaces
    
    from sqlalchemy import create_engine
    engine = create_engine('postgresql://username:password@localhost:5432/dbname')
    
    df.to_sql("my_table_name", engine)
    

    And here's some code that shows you how to set various options:

    # Set it so the raw sql output is logged
    import logging
    logging.basicConfig()
    logging.getLogger('sqlalchemy.engine').setLevel(logging.INFO)
    
    df.to_sql("my_table_name2", 
              engine, 
              if_exists="append",  #options are ‘fail’, ‘replace’, ‘append’, default ‘fail’
              index=False, #Do not output the index of the dataframe
              dtype={'col1': sqlalchemy.types.NUMERIC,
                     'col2': sqlalchemy.types.String}) #Datatypes should be [sqlalchemy types][1]
    
    0 讨论(0)
  • 2020-11-22 03:13

    How to import CSV file data into a PostgreSQL table?

    steps:

    1. Need to connect postgresql database in terminal

      psql -U postgres -h localhost
      
    2. Need to create database

      create database mydb;
      
    3. Need to create user

      create user siva with password 'mypass';
      
    4. Connect with database

      \c mydb;
      
    5. Need to create schema

      create schema trip;
      
    6. Need to create table

      create table trip.test(VendorID int,passenger_count int,trip_distance decimal,RatecodeID int,store_and_fwd_flag varchar,PULocationID int,DOLocationID int,payment_type decimal,fare_amount decimal,extra decimal,mta_tax decimal,tip_amount decimal,tolls_amount int,improvement_surcharge decimal,total_amount
      );
      
    7. Import csv file data to postgresql

      COPY trip.test(VendorID int,passenger_count int,trip_distance decimal,RatecodeID int,store_and_fwd_flag varchar,PULocationID int,DOLocationID int,payment_type decimal,fare_amount decimal,extra decimal,mta_tax decimal,tip_amount decimal,tolls_amount int,improvement_surcharge decimal,total_amount) FROM '/home/Documents/trip.csv' DELIMITER ',' CSV HEADER;
      
    8. Find the given table data

      select * from trip.test;
      
    0 讨论(0)
  • 2020-11-22 03:15

    Personal experience with PostgreSQL, still waiting for a faster way.

    1. Create table skeleton first if the file is stored locally:

        drop table if exists ur_table;
        CREATE TABLE ur_table
        (
            id serial NOT NULL,
            log_id numeric, 
            proc_code numeric,
            date timestamp,
            qty int,
            name varchar,
            price money
        );
        COPY 
            ur_table(id, log_id, proc_code, date, qty, name, price)
        FROM '\path\xxx.csv' DELIMITER ',' CSV HEADER;
    

    2. When the \path\xxx.csv is on the server, postgreSQL doesn't have the permission to access the server, you will have to import the .csv file through the pgAdmin built in functionality.

    Right click the table name choose import.

    If you still have problem, please refer this tutorial. http://www.postgresqltutorial.com/import-csv-file-into-posgresql-table/

    0 讨论(0)
提交回复
热议问题