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 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题