云数据库 RDS-通过Python连接RDS for PostgreSQL实例:使用SSL证书连接
使用SSL证书连接
下面的代码使用psycopg2.connect函数,基于SSL证书认证方式,连接到RDS for PostgreSQL数据库实例,并使用SQL INSERT、UPDATE操作数据,使用cursor.execute方法对数据库进行SQL操作:
在某些实例版本上,如果创建表报错“permission deny for schema public”,则手动执行grant create on SCHEMA public to root;后可以解决。
import psycopg2 db_params ={'database':'postgres','user':'root','password':'****','host':'xxx.xxx.xxx.xxx','port':'5432','sslmode':'verify-ca','sslrootcert':'/path/to/CA/ca.pem',} conn=psycopg2.connect(**db_params) print("Connection established") cursor = conn.cursor() # Drop previous table of same name if one exists cursor.execute("DROP TABLE IF EXISTS inventory;") print("Finished dropping table (if existed)") # Create a table cursor.execute("grant create on SCHEMA public to root;") cursor.execute("CREATE TABLE inventory (id serial PRIMARY KEY, name VARCHAR(50), quantity INTEGER);") print("Finished creating table") # Insert some data into the table cursor.execute("INSERT INTO inventory (name, quantity) VALUES (%s, %s);",("banana",150)) cursor.execute("INSERT INTO inventory (name, quantity) VALUES (%s, %s);",("orange",154)) cursor.execute("INSERT INTO inventory (name, quantity) VALUES (%s, %s);",("apple",100)) print("Inserted 3 rows of data") cursor.execute("SELECT * FROM inventory;") result = cursor.fetchall() for row in result: print(row) # Clean up conn.commit() cursor.close() conn.close()
输出结果如下:
Connection established Finished dropping table(if existed) Finished creating table Inserted 3 rows of data (1,'banana',150) (2,'orange',154) (3,'apple',100)
- 华为云数据库 RDS for PostgreSQL 实例规格介绍
- 连接RDS for MySQL数据库_华为云数据库RDS_语法_数据库连接_连接命令
- 云数据库 RDS for PostgreSQL只读实例_PG只读实例_华为云
- PostgreSQL_云数据库RDS for PostgreSQL_华为云
- 如何连接云数据库 RDS for MySQL_MySQL数据库连接_华为云
- 云数据库免费_mysql数据库是免费的吗_有哪些数据库
- 云数据库 RDS 的实例类型有哪些
- GaussDB驱动_GaussDB数据库驱动_云数据库GaussDB驱动_华为云
- 免费的MySQL云数据库_数据库管理系统有哪些_MySQL查询表
- 华为云数据库 RDS for MySQL实例规格介绍