微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何通过python获得对heroku-postgresql数据库的完全访问权限

如何解决如何通过python获得对heroku-postgresql数据库的完全访问权限

我在 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 行进行比较时,会有很大的不同。

这会调用对象 execute 上的方法 cur,以 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  

如果从第二个语句中删除 =,就可以了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。