PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Jak wycofać dataframe.to_sql w Pythonie w SQLAlchemy?

Możesz rozpocząć transakcję przed wywołaniem to_sql a potem cofnij:

import pandas as pd
import sqlalchemy as sa

engine = sa.create_engine("mssql+pyodbc://@mssqlLocal64")

def dump_tran_test_table(conn):
    print(conn.execute(sa.text("SELECT * FROM tran_test")).fetchall())

# set up test environment
with engine.begin() as conn:
    conn.exec_driver_sql("DROP TABLE IF EXISTS tran_test")
    conn.exec_driver_sql(
        "CREATE TABLE tran_test "
        "(txt varchar(10), id int primary key)"
    )
    conn.exec_driver_sql(
        "INSERT INTO tran_test (txt, id) VALUES "
        "('old_foo', 1), ('old_bar', 2)"
    )

# test
with engine.connect() as conn:
    tran = conn.begin()
    df = pd.DataFrame([("new_baz", 3)], columns=["txt", "id"])
    df.to_sql("tran_test", conn, index=False, if_exists="append")
    dump_tran_test_table(conn)
    """console output:
    [('old_foo', 1), ('old_bar', 2), ('new_baz', 3)]
    """
    tran.rollback()
    dump_tran_test_table(conn)
    """console output:
    [('old_foo', 1), ('old_bar', 2)]
    """



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wzór na współczynnik korelacji Pearsona w SQL

  2. Jak działają widoki bariery bezpieczeństwa PostgreSQL?

  3. Analiza sonaru zajmuje dużo czasu

  4. Dzienniki JBoss Sterownik Postgres nie jest zgodny ze standardem JDBC

  5. Jak wygenerować losowy, unikalny, alfanumeryczny identyfikator o długości N w Postgresie 9.6+?