Python连接SQL Sever报错

场景:

初学python连接数据库,连接语句正确,但是就是报错,别急,看看引入的模块是不是错了。

问题1描述:

课上老师讲了连接MySQL数据库的方法,首先导入用于连接MySQL服务器的库——PyMySQL,然后建立连接。connect参数:host是数据库主机名,user是数据库登录用户名,password是登录密码,database是自己创建的数据库。 的确代码一点问题都没有可是为什么会报错呢?不李姐。。。
import pymysql
db = pymysql.connect(host='DESKTOP-FBB7URP',port=3306,user='sa',password='local',database='student')

报错信息


ConnectionResetError: [WinError 10054] 远程主机强迫关闭了一个现有的连接。
pymysql.err.OperationalError: (2013, 'Lost connection to MySQL server during query ([WinError 10054] 远程主机强迫关闭了一个现有的连接。)')

在这里插入图片描述
在这里插入图片描述


原因分析:

这个问题耗费了我一个半小时的时间,但是问题还是没有解决。正当我将要放弃的时候。朋友给我了一个提示,我用的数据库是SQL Server,但是老师讲课用的是MySQL,啊啊啊啊,天哪,激动的心颤抖的手,这这这难道就是问题的根源?
后来查阅发现,MySQL和SQL Server连接数据库导入的模块确实不一样,MySQL用pymysql,SQL Server用pymssql。于是我又重新导入pymssql,尝试运行看看能不能成功。这次又报错了,但是错误不一样了,内心五味杂陈,还是得硬着头皮整它,勇敢牛牛,不怕困难。几经周折,最后终于解决了,在这里记录一下,也希望对大家有所帮助。

问题2描述:

这次导入的模块以及连接语句都正确

内联代码片

import pymssql
print("start")
db = pymssql.connect(host='DESKTOP-FBB7URP',port=3306,user='sa',password='local',database='student')

报错信息:

  pymssql.OperationalError: (20009, b'DB-Lib error message 20009, severity 9:\nUnable to connect: Adaptive Server is unavailable or does not exist (SZS\\SQLEXPRESS)\n')

在这里插入图片描述

原因分析:

数据库端口没有开

通过查阅一些文章,这种造成这种情况的可能性有多种,由于个人是初学者,能力有限,就紧着看得懂的方法尝试。接下来给大家展示怎样解决这个问题。
进行以下配置
sql server配置管理器—>SQL Server 网络配置---->选择当前使用的实例------>开启TCP/IP---->找到当前的动态端口号(当前是3306),如下图:
在这里插入图片描述
然后重启你的数据库,连接数据库。

这次终于运行成功了。
在这里插入图片描述
感谢大家阅读,如有错误或者不妥之处,请指正。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值