Computer >> Máy Tính >  >> Lập trình >> Python

Làm cách nào để sử dụng Boto3 để xóa một bảng khỏi danh mục Dữ liệu Keo AWS?

Tuyên bố sự cố - Sử dụng thư viện boto3 bằng Python để xóa bảng, được tạo trong tài khoản của bạn.

Ví dụ - Xóa bảng ‘bảo mật’ khỏi ‘kiểm tra’ cơ sở dữ liệu được tạo trong tài khoản của bạn.

Phương pháp tiếp cận / Thuật toán để giải quyết vấn đề này

Bước 1 - Nhập các ngoại lệ boto3 và botocore để xử lý các ngoại lệ.

Bước 2 - Chuyển tham số database_name và table_name sẽ bị xóa khỏi AWS Glue Catalog.

Bước 3 - Tạo phiên AWS bằng thư viện boto3. Đảm bảo rằng tên miền được đề cập trong hồ sơ mặc định. Nếu nó không được đề cập, thì hãy chuyển rõ ràng region_name trong khi tạo phiên.

Bước 4 - Tạo ứng dụng AWS cho keo dán.

Bước 5 - Bây giờ sử dụng chức năng delete_table và chuyển database_name làm tham số DatabaseName và table_name làm tham số Name.

Bước 6 - Nó sẽ xóa bảng và trả về siêu dữ liệu phản hồi.

Bước 7 - Xử lý ngoại lệ chung nếu có sự cố xảy ra trong khi kiểm tra công việc.

Ví dụ

Sử dụng mã sau để xóa bảng khỏi cơ sở dữ liệu AWS Glue -

import boto3
from botocore.exceptions import ClientError

def delete_a_table_from_database(database_name, table_name):
   session = boto3.session.Session()
   glue_client = session.client('glue')
   try:
      response = glue_client.delelte_table(DatabaseName= database_name, Name = table_name)
   return response
   except ClientError as e:
      raise Exception( "boto3 client error in delete_a_table_from_database: " + e.__str__())
   except Exception as e:
      raise Exception("Unexpected error in delete_a_table_from_database: " + e.__str__())

print(delete_a_table_from_database("test","security"))

Đầu ra

{'ResponseMetadata': {'RequestId': '7aa7c3cb…………….-8610318a238c',
'HTTPStatusCode': 200, 'HTTPHeaders': {'date': 'Sun, 21 Feb 2021
04:58:04 GMT', 'content-type': 'application/x-amz-json-1.1', 'contentlength': '2', 'connection': 'keep-alive', 'x-amzn-requestid': '7aa7c3cbf611-494e-b923-8610318a238c'}, 'RetryAttempts': 0}}