如何从Python脚本中执行psql命令?我的代码插入、更新来自PostgreSQL DB的数据(使用psycopg2和cursor方法)。当我执行smth时,它工作得很好
cursor.execute("UPDATE Segment set idcurve = %s where id = %s ", (id_curve, id_segment,))
但是对于psql,当将命令传递到游标时。我得到了SyntaxError: syntax error at或near ""。 而且,该命令在控制台失败。sql DataGRIP(它执行所有的行…) 这个命令只适用于shell(我必须使用os.system)?游标不能解释它吗? 编辑 在子流程:
import subprocess
sql = """SELECT uuid IS NULL AS is_uuid FROM dpoint WHERE uuid = '5547f4b7-00b3-4aac-8ceb-c9ca163a0214';
\gset
\if :is_uuid
INSERT INTO DPoint (uuid) VALUES ('5547f4b7-00b3-4aac-8ceb-c9ca163a0214');
WITH ins1 AS (INSERT INTO Point (latitude, longitude, srid)
VALUES (64.44, 28.77, 4326) RETURNING id AS id_point)
INSERT INTO SPoint (idPoint, uuiddpt) VALUES ((SELECT id_point FROM ins1), '5547f4b7-00b3-4aac-8ceb-c9ca163a0214');
\endif
"""
subprocess.check_call(['psql -h localhost -d dbase -U myuser -W --command={}'.format(sql)], env={'PGPASSWORD': 'mypass'})
抛出OSError: [Errno 36]文件名太长 问题来源StackOverflow 地址:/questions/59466319/execute-psql-command-from-python-script
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。