如何通过 python 获得对 heroku-postgresql 数据库的完全访问权限
How to gain complete access to a heroku-postgresql database via python
我在heroku上做了一个postrgesql数据库。然后我尝试通过 python 脚本访问它。为此,我编写了以下代码。
import psycopg2
#connect to the db
con = psycopg2.connect(
host = "an_aws_ec2_instance",
database="d57kjtuarj5li8",
user = "mmpywqodjzxlzr",
password = "************************************")
#cursor
cur = con.cursor()
#execute query
cur.execute("CREATE TABLE accounts (user_id serial PRIMARY KEY, username VARCHAR ( 50 ) UNIQUE NOT NULL, password VARCHAR ( 50 ) NOT NULL, email VARCHAR ( 255 ) UNIQUE NOT NULL, created_on TIMESTAMP NOT NULL, last_login TIMESTAMP)")
cur.execute = ("""SELECT * FROM accounts""")
rows = cur.fetchall()
for r in rows:
print (r)
#commit the transcation
con.commit()
#close the cursor
cur.close()
#close the connection
con.close()
但是在执行代码时,出现了以下错误。
---> 15 cur.execute = ("""SELECT * FROM accounts""")
16 rows = cur.fetchall()
AttributeError: 'psycopg2.extensions.cursor' object attribute 'execute' is read-only
当你比较你的两条 SQL 行时,会有很大的不同。
这将调用对象 cur
上的方法 execute
,将 SQL 语句作为参数:
cur.execute("CREATE TABLE accounts (user_id serial PRIMARY KEY, username VARCHAR ( 50 ) UNIQUE NOT NULL, password VARCHAR ( 50 ) NOT NULL, email VARCHAR ( 255 ) UNIQUE NOT NULL, created_on TIMESTAMP NOT NULL, last_login TIMESTAMP)")
这里有些不同。此处您尝试将字符串(SQL 语句)分配给属性 (execute
),该属性在该对象上是只读的。
cur.execute = ("""SELECT * FROM accounts""")
# THIS
如果从第二个语句中删除 =
,就可以了。
我在heroku上做了一个postrgesql数据库。然后我尝试通过 python 脚本访问它。为此,我编写了以下代码。
import psycopg2
#connect to the db
con = psycopg2.connect(
host = "an_aws_ec2_instance",
database="d57kjtuarj5li8",
user = "mmpywqodjzxlzr",
password = "************************************")
#cursor
cur = con.cursor()
#execute query
cur.execute("CREATE TABLE accounts (user_id serial PRIMARY KEY, username VARCHAR ( 50 ) UNIQUE NOT NULL, password VARCHAR ( 50 ) NOT NULL, email VARCHAR ( 255 ) UNIQUE NOT NULL, created_on TIMESTAMP NOT NULL, last_login TIMESTAMP)")
cur.execute = ("""SELECT * FROM accounts""")
rows = cur.fetchall()
for r in rows:
print (r)
#commit the transcation
con.commit()
#close the cursor
cur.close()
#close the connection
con.close()
但是在执行代码时,出现了以下错误。
---> 15 cur.execute = ("""SELECT * FROM accounts""")
16 rows = cur.fetchall()
AttributeError: 'psycopg2.extensions.cursor' object attribute 'execute' is read-only
当你比较你的两条 SQL 行时,会有很大的不同。
这将调用对象 cur
上的方法 execute
,将 SQL 语句作为参数:
cur.execute("CREATE TABLE accounts (user_id serial PRIMARY KEY, username VARCHAR ( 50 ) UNIQUE NOT NULL, password VARCHAR ( 50 ) NOT NULL, email VARCHAR ( 255 ) UNIQUE NOT NULL, created_on TIMESTAMP NOT NULL, last_login TIMESTAMP)")
这里有些不同。此处您尝试将字符串(SQL 语句)分配给属性 (execute
),该属性在该对象上是只读的。
cur.execute = ("""SELECT * FROM accounts""")
# THIS
如果从第二个语句中删除 =
,就可以了。