Skip to main content

chat1

import duckdb
import pandas as pd

def find_enum_by_prefix(input_string,create_and_populate_table(df, enum_class)db_name, table_name, unique_columns_list):
    for# memberConnect into enum_class:DuckDB
    con = duckdb.connect(database=db_name, read_only=False)

    # Check if the table exists
    table_exists = con.execute(f"SELECT count(*) FROM information_schema.tables WHERE table_name = '{table_name}'").fetchone()[0] > 0

    if input_string.startswith(member.value):not table_exists:
        # Creating column definitions based on DataFrame dtypes
        column_defs = ', '.join([f"{col} {pd.io.sql.get_sqltype(df[col].dtype)}" for col in df.columns])
        
        # Creating UNIQUE constraints string
        unique_str = f"UNIQUE({', '.join(unique_columns_list)})" if unique_columns_list else ""
        
        # Combine column definitions and constraints
        sql_create_table = f"CREATE TABLE {table_name} ({column_defs}, {unique_str})".rstrip(", ")
        try:
            con.execute(sql_create_table)
            print(f"Table '{table_name}' created successfully.")
        except Exception as e:
            print(f"Error creating table: {e}")
            return

member

    # Register the DataFrame with DuckDB
    returncon.register(table_name, Nonedf)

    # Insert data into the table
    try:
        con.execute(f"INSERT INTO {table_name} SELECT * FROM {table_name}")
        print("Data inserted into the table.")
    except Exception as e:
        print(f"Error inserting data: {e}")

    # Fetch and display the table contents to verify
    result_df = con.execute(f"SELECT * FROM {table_name}").df()
    print(result_df)

    # Close the connection
    con.close()

# Example usage:
data = {
    'id': [1, 2, 3],
    'name': ['Alice', 'Bob', 'Charlie'],
    'age': [25, 30, 35]
}
df = pd.DataFrame(data)
create_and_populate_table(df, 'my_duckdb.duckdb', 'my_table', ['id'])