您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

PostgreSQL PL / Python如何在性能方面与Python之外的Python进行比较?

5b51 2022/1/14 8:20:43 python 字数 3390 阅读 470 来源 www.jb51.cc/python

我运行完全相同的Python函数,一个作为PostgreSQL PL / Python,另一个作为通常的Python脚本在PostgreSQL之外运行.令人惊讶的是,当我使用select * from pymax7(20000);调用PostgreSQL PL / Python时,它平均花费65秒,而当我调用通常的Python脚本python myscrip

概述

我运行完全相同的Python函数,一个作为Postgresql PL / Python,另一个作为通常的Python脚本在Postgresql之外运行.

令人惊讶的是,当我使用select * from pymax7(20000);调用Postgresql PL / Python时,它平均花费65秒,而当我调用通常的Python脚本python myscript.py 20000时,它平均需要48秒.计算运行查询和脚本10次的平均值.

是否应该有这样的差异? Postgresql RDBMS(PL / Python)中的Python如何在性能方面与Python之外的Python进行比较?

我在Ubuntu 12.04 64位上运行Postgresql 9.1和Python 2.7.

Postgresql PL / Python:

CREATE FUNCTION pymax7 (b integer)
  RETURNS float
AS $$   
  a = 0
  for i in range(b):
    for ii in range(b):
      a = (((i+ii)%100)*149819874987) 
  return a
$$LANGUAGE plpythonu;

Python:

import time
import sys

def pymax7 (b):     
    a = 0
    for i in range(b):
        for ii in range(b):
            a = (((i+ii)%100)*149819874987) # keeping Python busy
    return a

def main():    
    numIterations = int(sys.argv[1])        
    start = time.time()
    print pymax7(numIterations)
    end = time.time()
    print "Time elapsed in Python:"
    print str((end - start)*1000) + ' ms'        

if __name__ == "__main__":
    main()

我确实调整了PL / Python测试用例,使用与普通Python测试用例相同的测量技术:

CREATE FUNCTION pymax7a (b integer)
  RETURNS float
AS $$
  import time
  start = time.time()
  a = 0
  for i in range(b):
    for ii in range(b):
      a = (((i+ii)%100)*149819874987)
  end = time.time()
  plpy.info("Time elapsed in Python: " + str((end - start)*1000) + ' ms')
  return a
$$LANGUAGE plpythonu;

这将告诉您是否涉及任何非Python开销. FWIW,对我来说,这个打印和客户端打印的psql与总时间之间的差异始终小于1毫秒.

总结

以上是编程之家为你收集整理的PostgreSQL PL / Python如何在性能方面与Python之外的Python进行比较?全部内容,希望文章能够帮你解决PostgreSQL PL / Python如何在性能方面与Python之外的Python进行比较?所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶