从 Python 到 SQL(Aginity、Netezza)的 CREATE/DROP 调用不起作用

Posted

技术标签:

【中文标题】从 Python 到 SQL(Aginity、Netezza)的 CREATE/DROP 调用不起作用【英文标题】:CREATE/DROP call from Python to SQL (Aginity, Netezza) not working 【发布时间】:2020-01-02 17:52:43 【问题描述】:

我正在尝试弄清楚如何使用 Python 将 csv 表文件上传/插入到 Aginity Workbench(使用 Netezza 驱动程序)中,用于现有和不存在的表。

    是否有从指定路径直接上传到 SQL 数据库的功能?我一直找不到 Aginity/Netezza 特有的功能。 我尝试了一个循序渐进的过程:将csv上传到Python,转换为dataframe,然后上传到SQL数据库(想弄清楚如何将完整的csv文件作为新表上传以及插入csv文件数据到现有表中)。

我的 Python 代码能够打印显示数据的查询,但我无法删除或创建表。当我运行创建或删除代码时,它不会显示任何错误,但是当我进入 Aginity 时,我打算创建的表不存在,我要删除的表也没有被删除。

import pyodbc

# pyodbc connection string
conn = pyodbc.connect("DRIVER=driver;SERVER=server; PORT=port;DATABASE=database; UID=username;PWD=password;")

# Define Cursor
cus = conn.cursor()

# SQL query
sql = 'drop table username.test'
cus.execute(sql)

我得到一个没有如下错误的输出,但实际上并没有发生下降。

<pyodbc.Cursor at 0x1ac108181b0>

任何提示将不胜感激!

【问题讨论】:

因为你没有conn.commit()这些变化 【参考方案1】:

@roganjosh 指出我应该添加 conn.commit()

【讨论】:

以上是关于从 Python 到 SQL(Aginity、Netezza)的 CREATE/DROP 调用不起作用的主要内容,如果未能解决你的问题,请参考以下文章

如何从 Aginity 工作台检查在 IBM Netezza SQL 中处理表的数据和时间?

如何从 Aginity 工作台检查在 IBM Netezza SQL 中创建表的数据和时间

在 Aginity Workbench SQL 中选择 1% 的样本

在 IBM netezza aginity sql 数据库工作台中导出大表时如何添加列名

Win7 上 Aginity 工作台对 IBM netezza SQL 数据库的 SQL 查询错误

如何从 Aginity 工作台为 Redshift 导出数据结构