当前位置: 首页 > news >正文

Python连接SQL SEVER数据库全流程

背景介绍

在数据分析领域,经常需要从数据库中获取数据进行分析和处理。而SQL Server是一种常用的关系型数据库管理系统,因此学习如何使用Python连接SQL Server数据库并获取数据是非常有用的。

以下是Python使用pymssql连接SQL Server数据库的全流程:

  • 安装pymssql库
  • 本地账号设置
  • 脚本连接
  • 数据导入函数实现

一、安装pymssql

pymssql是Python连接SQL Server数据库的一个库,可以通过pip命令进行安装。在命令行中输入以下命令即可安装:

pip install pymssql

二、本地账号设置

1、设置sa账户的登录密码

在SQL Server Management Studio中,展开“安全性”文件夹,右键单击“登录名”并选择“新建登录名”。在弹出的对话框中,输入登录名“sa”,选择“SQL Server身份验证”,设置密码并确保“登录”选项卡下“默认数据库”为目标数据库。最后,在“状态”选项卡下选择“启用”并确保“允许连接”复选框被选中。

2、开启双重验证

在SQL Server Management Studio中,右键单击SQL Server实例名称并选择“属性”。在弹出的对话框中,选择“安全性”选项卡,将“身份验证”设置为“SQL Server和Windows身份验证模式”,并选择“应用”以保存更改。

3、开启TCP/IP本地服务

在SQL Server Configuration Manager中,展开“SQL Server网络配置”文件夹,右键单击“协议”文件夹并选择“新建协议”。选择“TCP/IP”协议,右键单击“TCP/IP”协议并选择“属性”。在弹出的对话框中,将“启用”设置为“是”,并确保“IP地址”选项卡下的“TCP动态端口”为空。然后,切换到“IPALL”选项卡,并将“TCP端口”设置为1433(或其他您想要的端口号)。保存更改并重启SQL Server服务。

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

三、脚本连接

做好以上的准备工作,用测试脚本连接(如果连接出错——b’DB-Lib error message 20002,试下在connect函数参数最后面加上tds_version=“7.0” 或者其他值)。

import pymssql server = '(local)' database = '订单信息' username = 'sa' password = '123456' # 连接到数据库 conn = pymssql.connect(server=server, user=username, password=password, database=database,tds_version="7.0")#最后一个参数不是必须的 # 创建游标对象 cursor = conn.cursor() print('连接成功!') # 关闭数据库连接 conn.close()

四、数据导入函数

我们成功连接了数据库以后,可以很方便的导出导入数据,以下是一个将数据导入数据库的函数实现

#coding=utf-8 import time import pymssql import pandas as pd def insert_data_to_sql(df, server, database, username, password, table_name,mode='Overlay'): # 连接到数据库 conn = pymssql.connect(server=server, user=username, password=password, database=database) # 创建游标对象 cursor = conn.cursor() # 获取 DataFrame 对象的字段名和数据类型 columns = list(df.columns) dtypes = df.dtypes if mode=='Overlay': try: #覆盖模式 cursor.execute("DROP TABLE {}".format(table_name)) except: print('表不存在,直接创建……') # 构造创建表的 SQL 语句 create_table_sql = f'CREATE TABLE [{table_name}] (' for col_name, col_type in zip(columns, dtypes): if col_type == 'int64': create_table_sql += f'[{col_name}] BIGINT,' elif col_type == 'float64': create_table_sql += f'[{col_name}] FLOAT,' elif col_type== 'datetime64[ns]' or '时间' in col_name or '日期' in col_name: create_table_sql += f'[{col_name}] DATETIME2(0),' elif col_type == 'date': create_table_sql += f'[{col_name}] DATE,' else: create_table_sql += f'[{col_name}] NVARCHAR(max),' create_table_sql = create_table_sql.rstrip(',') + ');' cursor.execute(create_table_sql) # 将 DataFrame 转换成元组列表 data = [tuple(row) for row in df.fillna(0).values.tolist()] # 构造插入数据的 SQL 语句 insert_sql = f'INSERT INTO [{table_name}] (' insert_sql += ','.join([f'[{col_name}]' for col_name in columns]) + ') VALUES (' insert_sql += ','.join(['%s'] * len(columns)) + ');' # 将数据插入到数据库 cursor.executemany(insert_sql, data) # 提交事务 conn.commit() # 关闭数据库连接 conn.close() # 数据库连接参数

以上是python连接SQL SEVER数据库的全部流程,如果你遇到任何问题,欢迎评论区留言~

http://www.jsqmd.com/news/451496/

相关文章:

  • 避坑指南:用JetBrains Gateway连接Docker容器时常见的5个端口映射错误
  • Qwen-Turbo-BF16助力YOLOv8目标检测:高精度图像分析实战
  • YOLO12在智能交通系统中的应用:车辆与行人检测
  • AIGlasses_for_navigation企业级部署:高可用架构与负载均衡设计
  • Dify混合RAG召回率卡在76.3%无法突破?2024Q3最新生产环境实测:仅需替换1个分词器+微调3个向量归一化参数
  • 基于Qwen3-TTS-12Hz-1.7B-Base的教育语音应用开发
  • SEER‘S EYE预言家之眼助力社区运营:自动化生成游戏战报与精彩集锦
  • 碧蓝幻想Relink数据分析工具:提升战斗表现的游戏优化指南
  • Python 3.15异步I/O模型进化树(含向后兼容性断裂清单):6类旧代码必须在2025年Q2前重构,否则将触发RuntimeWarning→FutureError
  • Qwen3-Reranker-4B在新闻推荐系统中的应用:个性化内容排序
  • Z-Image-GGUF模型生成的人像摄影与时尚大片效果对比
  • Xinference-v1.17.1生产环境配置指南:HTTPS反向代理+认证鉴权+监控埋点
  • 碧蓝幻想Relink伤害统计工具:从数据监控到战斗优化的全方位指南
  • DWPose预处理器ONNX运行时错误实战指南:从环境诊断到深度优化
  • MCP插件响应延迟超800ms?用Chrome DevTools精准定位VS Code Extension Host线程阻塞根源(实测修复提速94%)
  • CYBER-VISION零号协议C盘清理:智能识别与清理AI缓存文件
  • Flutter实战:5分钟搞定微信/QQ消息侧滑功能(flutter_slidable最新版教程)
  • 告别机械音!用QWEN-AUDIO合成带“人类温度”的自然语音
  • 通义千问1.5-1.8B-Chat-GPTQ-Int4入门部署教程:3步完成模型服务搭建
  • Stable-Diffusion-V1-5 文化遗产数字化:生成历史场景复原图与文物虚拟修复
  • 新手零基础入门:借助快马AI创建你的第一个知识库应用“老白的宝库”
  • 告别3ds Max适应难题:BsMax插件的高效迁移指南
  • Wan2.1-umt5模型压缩与量化教程:降低部署显存占用
  • Wireshark抓包分析:S7comm协议在工控系统中的安全隐患排查指南
  • Qwen3-VL-4B Pro新手入门:无需代码,三步开启智能图文问答
  • 新手友好:Python3.8镜像环境搭建,避免常见安装问题
  • Qwen3-ASR-0.6B语音识别部署教程:CSDN GPU实例ID替换与访问验证
  • Hudi表设计实战:如何用FileGroup优化你的数据湖存储(附避坑指南)
  • cv_unet_image-colorization效果评测:强光、逆光、阴天场景稳定性测试
  • 如何解决离线阅读难题?番茄小说下载器让你随时随地畅读无阻