开发者社区> 问答> 正文

从python脚本执行psql命令

如何从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

展开
收起
kun坤 2019-12-25 10:04:23 885 0
1 条回答
写回答
取消 提交回答
  • 用Python自带的IDEL python 自带了一款 IDE,叫做 IDLE。 image.png

    2019-12-26 13:59:35
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
From Python Scikit-Learn to Sc 立即下载
Data Pre-Processing in Python: 立即下载
双剑合璧-Python和大数据计算平台的结合 立即下载