AWSGlue写入Snowflake表时出错。
创始人
2024-09-25 17:01:52
0

一种可能的解决方法是检查 AWS Glue 与 Snowflake 之间的连接是否正确配置并且可以正常通信。同时,还需要检查 AWS Glue 作业使用的 IAM 角色是否具有适当的访问权限以访问 Snowflake 表。以下是一个示例,展示如何在 AWS Glue 作业中使用 boto3 和 snowflake-connector-python 包连接 Snowflake 并将数据写入表中:

import snowflake.connector
import boto3
import uuid
import os

# Set up the connection properties
connection_properties = {
    "account": "myaccount",
    "user": "myuser",
    "password": "mypassword",
    "database": "mydatabase",
    "schema": "myschema",
    "warehouse": "mywarehouse",
}

# Set up the AWS credentials
session = boto3.Session()
credentials = session.get_credentials()
aws_access_key_id = credentials.access_key
aws_secret_access_key = credentials.secret_key

# Add the AWS keys to the Snowflake connection properties
connection_properties['aws_access_key_id'] = aws_access_key_id
connection_properties['aws_secret_access_key'] = aws_secret_access_key

try:
    # Connect to Snowflake
    conn = snowflake.connector.connect(**connection_properties)
    cursor = conn.cursor()

    # Create a unique temporary table name
    temp_table_name = "temp_" + str(uuid.uuid4()).replace("-", "")

    # Write data to the temporary table
    cursor.execute("CREATE TABLE " + temp_table_name + " (col1 string, col2 int)")
    cursor.execute("INSERT INTO " + temp_table_name + " VALUES ('foo', 1), ('bar', 2)")

    # Copy data from the temporary table to a target table
    cursor.execute(f"COPY INTO final_table FROM {temp_table_name}")

    # Clean up the temporary table
    cursor.execute(f"DROP TABLE IF EXISTS {temp_table_name}")

    # Commit the changes
    conn.commit()

except Exception as e:
    print("Error while writing to Snowflake table:", e)
    conn.rollback()

finally:
    # Close the connection
    conn.close()

在上

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...