gjfvip123 2018-05-18 08:47 采纳率: 0%
浏览 2433
已结题

python3中如何在多线程中操作sql server数据库

python37+sql server+win10环境

大概的意思就是,在python中,我开启了n个线程,进入同一个函数,每个线程传递的参数都不一样:如下图:
图片说明
在再每个线程中,将传递过来的参数 update到数据库中,会报一个错误,我想是不是多个线程同时操作一个,导致锁死?如下图:

其中,
conn.connect()我只在程序最开始链接了一次,
conn.cloese(),和cursor.close()只在程序最结尾执行了一次。
每个线程中我试过在函数开头链接数据库,函数结尾关闭数据库,但是应该是串行的,即第一个线程链接数据库,更新数据,第二个线程等待...等到第一个线程关闭连接后,第二个线程才开始链接...
请高手指点一下,应该如何更改代码?

图片说明图片说明

  • 写回答

4条回答

  • EuclideanSpace 2018-05-18 09:01
    关注

    你这样就是每执行一次线程,都会连接一次数据库,这样当然会乱了
    你把conn =pymsql.connect()和cursor = conn.cursor( )函数放到for i in range(count):语句的上面
    然后再func1函数加个cursor的参数传入cursor就行了
    这样在开头打开数据库,然后执行多线程把数据放入数据库
    然后关闭数据库的语句放在执行线程完了以后,就是最后一行。这样试试看

    评论

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置