python连接本地SQL server详细图文教程

2025-04-10 15:50

本文主要是介绍python连接本地SQL server详细图文教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码...

一.设置本地账号

1.新建用户

在对象资源管理其中,选中 安全性/登录名 右键新建登录名

python连接本地SQL server详细图文教程

在弹出的对话框中,设置登录名为“sa”(sa是最高权限用户名,也可以自定义,但不推荐),选择“SQL Server身份验证”,设置密码,在“默认数据库”中选择我们需要建立联系的目标数据库,“默认语言”为简体中文。

python连接本地SQL server详细图文教程

最后在“状态”选项卡下选择“启用”并确保“允许连接”复选框被选中。

python连接本地SQL server详细图文教程

2.开启双重验证

在资源对象管理器中,右键单击SQL Server实例名称并选择“属性”。

python连接本地SQL server详细图文教程

在弹出的对话框中,选择“安全性”选项卡,将“身份验证”设置为“SQL Server和Windows身份验证模式”,并选择“确定”以保存更改。

python连接本地SQL server详细图文教程

3,开启TCP/IP本地服务

在SQL Server Configuration Manager中,右键“SQL Server网络配置”,选择“TCP/IP”协议,点击“启用”。

python连接本地SQL server详细图文教程

选择TCP/IP属性,选择IP,将“TCP动态端口”设置为0

python连接本地SQL server详细图文教程

然后找到“IPALL”选项,将“TCP端口”设置为1433(或其他的端口号)。

python连接本地SQL server详细图文教程

保存更改并重启SQL Server服务。

python连接本地SQL server详细图文教程

完成以上步骤后,即可使用Python连接本地SQL Server数据库。

二.python连接实例

注意,下文是本地连接用法,也就是只能连接本机服务器的数据库,想要连接外地服务器请参考其它文章。

以 Pycharm为例

1.下载支持库

有用pymssql的方法,但是我没成功,于是换了另一个用pyodbc的方法

进入Anaconda Prompt,进入已有环境,输入一下命令下载支持库(这里命令末尾添加了阿里云镜像源,能下载的快一点)

pip install pyodbc -i https://mirrors.aliyun.com/pypi/simple/

2.验证连接

创建一个 .py文件,编辑以下代码验证能否建立连接:

import pyodbc

server = 'localhost'   # 这里就写localhost就可以了
user = '之前创建的用户名'  
password = '给对应账户设置的密wUjmRioAK码'
database = '想要建立连接的数据库名'

try:
    conn_str = f'DRIVER={{SQL Server}};SERVER={server};DATABASE={database};UID={user};PWD={password};TrustServerCertificate=yes'
    connect = pyodbc.connect(conn_str)
    print("连接成功")

except pyodbc.Error as e:
    print(f"连接失败: {e}")

3.可能失败原因

需要注意的是,如果没有创建sa账户的话,这里应该要先给对应数据库开起用户权限

在对象资源管理器中,右键对应数据库,点击属性,点击文件,点击如图红框

python连接本地SQL server详细图文教程

点击浏览,选中需要基于权限的用户,但是好像只能选择一个

python连接本地SQL server详细图文教程

如图,我选择了sd用户,点击确定,再点击确定就可以了。

最后显示连接成功:

python连接本地SQL server详细图文教程

三.基本查询语法使用

import pyodbc

server = 'localhost'   # 这里就写localhost就可以了
user = '之前创建的用户名'  
password = '给对应账户设置的密码'
database = '想要建立连接的数据库名'

conn_str = f'DRIVER={{SQL Server}};SERVER={server};DATABASE={database};UID={user};PWD={password};TrustServerCertificate=yes'
connect = pyodbc.connect(conn_str)
print("连接成功")

# 创建游标对象
cursor = connect.cursor()

# 执行查询语句,这里查询作者数据库里的图书表
query = "SELECT * FROM 图书"
cursor.exeChina编程cute(query)

# 获取查询结果
rows = cursor.fetchall()

# 打印查询结果
if rows:
    print("图书表的数据如下:")
    for row in rows:
        print(row)

# 关闭游标和连接
cursor.close()
connect.close()

结果如下,没有乱码问题,不知道是不是引用库不一样的原因,pymssql库看很多博主讲是有js代码的,反正不管,能成功就行。

python连接本地SQL server详细图文教程

总结

到此这篇关于python连接本地SQL ser编程China编程ver的文章就介绍到这了,更多相关python连接本地SQL server内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于python连接本地SQL server详细图文教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154165

相关文章

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select

MySQL 横向衍生表(Lateral Derived Tables)的实现

《MySQL横向衍生表(LateralDerivedTables)的实现》横向衍生表适用于在需要通过子查询获取中间结果集的场景,相对于普通衍生表,横向衍生表可以引用在其之前出现过的表名,本文就来... 目录一、横向衍生表用法示例1.1 用法示例1.2 使用建议前面我们介绍过mysql中的衍生表(From子句

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

一文全面详解Python变量作用域

《一文全面详解Python变量作用域》变量作用域是Python中非常重要的概念,它决定了在哪里可以访问变量,下面我将用通俗易懂的方式,结合代码示例和图表,带你全面了解Python变量作用域,需要的朋友... 目录一、什么是变量作用域?二、python的四种作用域作用域查找顺序图示三、各作用域详解1. 局部作

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛