繁体   English   中英

Python sqlalchemy(postgresql)不返回真实表 state

[英]Python sqlalchemy (postgresql) not returning real table state

这是从 PostgreSQL function 运行 python 脚本时我的问题的下一章。

我将不胜感激任何进一步的帮助或想法。

我在 PostgreSQL 上创建了 function

CREATE FUNCTION getSomeData()
RETURNS trigger
AS $$
import subprocess
subprocess.call(['/path/to/your/virtual/environment/bin/python3', '/some_folder/some_sub_folder/get_data.py'])
$$ 
LANGUAGE plpythonu;

并触发

CREATE TRIGGER executePython 
AFTER INSERT OR UPDATE OR DELETE ON mysensor
FOR EACH ROW EXECUTE PROCEDURE callMyApp();

使用get_data.py

from sqlalchemy import create_engine

SQLALCHEMY_DATABASE_URI = 'postgresql:///database_name'

db = create_engine(SQLALCHEMY_DATABASE_URI)
some_file = "my_file.txt"

#store pair of id and value
someDictionary = {}
with db.connect() as dbcon:
#Get sensor unique ID and room name for every room_id from mysensor existent in rooms
    mydata = dbcon.execute('SELECT mytable1.uid, mytable2.name FROM mytable1,mytable2 WHERE mytable1.some_id = mytable2.id')
    for row in mydata:
        # add key,value from touple to dictionary
        someDictionary[row[0]] = row[1]


f = open(config_file,"w")
#write section name in config file
f.write("[somepairing]\n")

for key, value in someDictionary.items():
    print(key, value)
    f.write(key + "=" +value+"\n")
f.close()

当我通过我的 Postgresql 触发器/函数运行此脚本时,我得到的数据落后于我当前的操作。

如果我现在进行插入,我的脚本将不会返回任何内容(假设我的表是空的)。 如果我进行其他操作,如插入、删除、更新,我的脚本将记录我第一次插入的数据,而不反映我当前的表格内容,等等。

例子

数据库 state 真实表状态

触发触发器后我的脚本得到了什么我得到了什么

如果我单独运行这个 python 脚本,而不是通过触发器,一切都很好并获得准确的表状态。

非常感谢您的帮助。

我已经根据我的代码编辑了,现在我的 function 就是这种形式

CREATE FUNCTION callMyApp()
RETURNS trigger
AS $$
import sys
sys.path.insert(0, '/path/to/my/module')
import get_config
return get_config.get_data()
$$ LANGUAGE plpythonu;

新问题是我在 get_config 中导入的模块无法识别/脚本不知道如何定位。

Error: ERROR:  ImportError: No module named sqlalchemy

解决了这种情况。 我确信存在更好的方法来解决它,但目前这就是我所需要的。

第 1 步 - 创建 function

CREATE FUNCTION callMyApp()
RETURNS trigger
AS $$
import sys
sys.path.insert(0, '/path/to/my/module')
import my_module
myresult = plpy.execute('some_query_here',100)
list2=""
for i in range(len(myresult)):
    list2 = list2+ myresult[i]["some_table_row_here_returned_from_query"]+","
list3=""
for j in range(len(myresult)):
    list3 = list3+ myresult[j]["another_table_row_here_returned_from_query"]+","

return get_configV2.get_data(list2,list3)
$$ LANGUAGE plpythonu;

第 2 步 - 创建触发器

CREATE TRIGGER executePython
AFTER INSERT OR UPDATE OR DELETE ON mysensor
EXECUTE PROCEDURE callMyApp();

第 3 步 - python 脚本

def get_data(received1,received2):
    config_file = "/some/path/here/file.txt"
def convert(string):
    mylist = list(string.split(","))
    return mylist
f = open(config_file,"w")

#write section name in config file
f.write("Ziua buna din Braila!\n")

kkk = convert(received1)
ppp = convert(received2)
for i in range(len(kkk)):
    if (kkk[i] != ""):
        output = kkk[i]+"="+ppp[i]+"\n"
        f.write(output)
f.close()

希望对您有所帮助并节省您的时间。 感谢您的支持Ilja Everilä

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM