python连接并简单操作SQL server数据库

环境:

pycharm 、SQLserver版本2019

1.首先,在pycharm中点击File,找到setting——project:***,点击”+“,引入pymssql库

2.编写代码连接数据库,并对数据库进行查询等简单操作(此处仅展示查询)

import pymssql
connect=pymssql.connect(server='DESKTOP-08O3C8T',user='sa',password='***',database='1234')
#服务器名,账号,密码,数据库名
if connect:print("连接数据库成功!")#查询
cursor=connect.cursor()
sql_select="select * from SC"
cursor.execute(sql_select)#执行sql语句
results=cursor.fetchall()#读取所有查询结果
for result in results: #循环读取所有结果result=list(result)for res in range(len(result)):if isinstance(result[res],str):result[res]=result[res].replace(' ','')result=tuple(result)print("处理后:",end='')print(result)
connect.commit()
#关闭数据库
connect.close()

 3.在sql server中由于之前使用windows验证模式进入数据库管理器,所以要身份验证修改,更改为sql身份验证连接数据库:

身份验证修改

(1)先是用Windows身份验证登录数据库,右击根目录——属性——安全性——勾选SQL和windows身份验证模式;

(2)选择根目录下安全性——登录名——sa——右击属性——修改密码并取消强制实施密码策略;状态选项里勾选授予和启用;(有一点需要注意,不管你改了几位数密码,在上图都是显示十五位。)

(3)配置协议:找到数据库中的配置工具SQL Server Configuration Manager程序,将SQL Server2005网络配置中的Named Pipes和TCP/IP的状态改成启用。然后使用SQL server身份验证登陆。如果找不到SQL Server Configuration Manager程序,可以右击此电脑——管理——Sql配置管理器:

(4)当你把这些都改好后,需要重启Sql Server Management Studio,注意是重启!!!不是将数据库关闭再打开就行,而是右击根目录——重新启动!!

结果:

 补充:上述简单查询代码查询会出现中文乱码

例如查询student表:

方法一:

在pymqsql.connect()中添加charset='cp936'

原因:因为字符串字段类型为:varchar,造成读取数据乱码

缺点:若sql语句中含有中文,会得不到数据

方法二:(较为通用)

直接用sql语句将varchar转为nvarchar类型,不再需要指定charset了,就没问题了(注意转换列名称起别名),直接写sql语句如下

sql="select Sno,convert(nvarchar(50),Sname) as 'a',convert(nvarchar(50),Ssex) as 'b' from student'

处理后结果如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/213126.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#,数值计算——多项式插值与外推插值(Poly2D_interp)的计算方法与源程序

1 文本格式 using System; namespace Legalsoft.Truffer { /// <summary> /// Object for two-dimensional polynomial interpolation on a matrix.Construct /// with a vector of x1 values, a vector of x2 values, a matrix of tabulated /// func…

代码随想录算法训练营第五十二天|1143.最长公共子序列 1035.不相交的线 53. 最大子序和

文档讲解&#xff1a;代码随想录 视频讲解&#xff1a;代码随想录B站账号 状态&#xff1a;看了视频题解和文章解析后做出来了 1143.最长公共子序列 class Solution:def longestCommonSubsequence(self, text1: str, text2: str) -> int:dp [[0] * (len(text2) 1) for _ i…

LeetCode | 622. 设计循环队列

LeetCode | 622. 设计循环队列 OJ链接 思路&#xff1a; 我们这里有一个思路&#xff1a; 插入数据&#xff0c;bank往后走 删除数据&#xff0c;front往前走 再插入数据&#xff0c;就循环了 那上面这个方法可行吗&#xff1f; 怎么判断满&#xff0c;怎么判断空&#xff1…

yolov5s模型剪枝详细过程(v6.0)

本文参考github上大神的开源剪枝项目进行学习与分享&#xff0c;具体链接放在文后&#xff0c;希望与大家多多交流&#xff01; 一、原模型训练 在官方源码上训练yolov5模型&#xff0c;支持v6.0分支的n/s/m/l模型&#xff0c;我这里使用的是v5s&#xff0c;得到后将项目clone到…

我去图书馆微信公众号抢座【Python版本】

更新记录 介于大部分是小白这里就重新整理一下思路 直接跳第十次更新&#xff01;第一次更新 抓包抢座2023-4-28日第二次更新&#xff08;更新了指定时间抢座 加了时间戳&#xff09;2023-5-9日第三次更新&#xff08;更新了延迟时间 测试成功案例&#xff09;2023-5-31日第四次…

如何将本地websocket发布至公网并实现远程访问?

本地websocket服务端暴露至公网访问【cpolar内网穿透】 文章目录 本地websocket服务端暴露至公网访问【cpolar内网穿透】1. Java 服务端demo环境2. 在pom文件引入第三包封装的netty框架maven坐标3. 创建服务端,以接口模式调用,方便外部调用4. 启动服务,出现以下信息表示启动成功…

2023年第十六届中国系统架构师大会(SACC2023)-核心PPT资料下载

一、峰会简介 本届大会以“数字转型 架构演进”为主题&#xff0c; 涵盖多个热门领域&#xff0c;如多云多活、海量分布式存储、容器、云成本、AIGC大数据等&#xff0c;同时还关注系统架构在各个行业中的应用&#xff0c;如金融、制造业、互联网、教育等。 与往届相比&#…

15.Python 异常处理和程序调试

1. 异常处理 异常就是在程序执行过程中发生的超出预期的事件。一般情况下&#xff0c;当程序无法正常执行时&#xff0c;都会抛出异常。 在开发过程中&#xff0c;由于疏忽或考虑不周&#xff0c;出现的设计错误。因此&#xff0c;在后期程序调试中应该根据错误信息&#xff…

2022版 的IDEA创建一个maven项目(超详细)

一.设置idea中指定的maven的位置以及本地存储仓库 开发中一般我们使用自己下载的maven&#xff0c;不使用IDEA工具自带的&#xff0c;这就需要将我们下载的maven配置到IDEA工具中&#xff0c;配置如下图所示&#xff1a; 或者直接 快捷键 CtrlAltS 直接进入设置 maven home pa…

经营现金流转正,宝尊电商解构内容电商3.0时代长期价值

在过去的“黄金十年”里&#xff0c;货架电商、直播电商鱼贯而出&#xff0c;接力式地推动品牌增长。彼时&#xff0c;价格换市场、“以快打快”的打法足以满足品牌发展所需。 然而&#xff0c;随着流量红利消退&#xff0c;消费者愈发理性&#xff0c;品牌增长集体“失速”。…

案例023:基于微信小程序的童装商城的设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder X 小程序…

C/C++内存管理(2):`new`和`delete`的实现原理

new和delete操作自定义类型 class Stack { public:Stack(int capacity 3):_top(0), _capacity(capacity){cout << "Stack(int capacity 3)" << endl;_a new int[capacity];}~Stack(){cout << "~Stack()" << endl;delete _a;_to…