导航:首页 > 编程语言 > python连接mssql

python连接mssql

发布时间:2023-01-24 15:25:32

python3连接MSSQL数据库 中文乱码怎么解决

以前用php连mssqy时也经常出现中文乱码(中文变问号)的问题,那时就明白是编码没设置好导航,现在的Python连mssql数据库也同样出现这问题,问题一样,解决的办法当然也会相似,现在我们来看看解决方法。
python一直对中文支持的不好,最近老遇到编码问题,而且几乎没有通用的方案来解决这个问题,但是对常见的方法都试过之后,发现还是可以解决的,下面总结了常用的支持中文的编码问题(这些方法中可能其中一个就能解决问题,也可能是多个组合)。
(1)、首先,要保证文件的开头要加上编码设置来说明文件的编码
代码如下
复制代码
#encoding=utf-8
(2)、然后,在连接数据的连接参数里加上字符集说明查询出的结果的编码,这个不加的后果可能是查询出的汉字字符都是问号
代码如下
复制代码
conn=pymssql.connect(server='.',user='',
password='',database='MyTest',charset='utf8')
(3)、设置python系统的默认编码(对于文件来说,这招几乎屡试不爽,呵呵~~)
代码如下
复制代码
import
sys
reload(sys)
sys.setdefaultencoding('utf8')
注意:上述编码是“utf8”,而不是“utf-8”,我也没弄明白,大部分情况下,这个无所谓的,但是这里我试了必须要是“utf8”
一个简单的完整的python连接mssqlserver的例子如下(得安装pymssql包):
代码如下
复制代码
#encoding:utf8
import
sys
reload(sys)
sys.setdefaultencoding('utf8')
import
pymssql
try:
conn=pymssql.connect(server='.',user='',
password='',database='MyTest',charset='utf8')
sql="select
*
from
UserInfo"
cur=conn.cursor()
cur.execute(sql)
data=cur.fetchall()
conn.close()
print
data
except
Exception,e:
print
e
运行结果如下:
代码如下
复制代码
[(u'20093501',
u'xb9xf9xbexb8',
u'u7537
',
35,
u'xb4xf3xcfxc0'),
(u'20093502',
u'xbbxc6xc8xd8',
u'u5973
',
34,
u'xc3xc0xc5xae'),
(u'20093503',
u'xc1xeexbaxfcxb3xe5',
u'u7537
',
25,
u'2Bxc7xe0xc4xea'),
(u'20093504',
u'xc8xcexd3xafxd3xaf',
u'u5973
',
24,
u'xc6xafxc1xc1')]
[Finished
in
0.2s]
虽然摆脱了问号和乱码的困扰,但这仍不是我们想要的结果,但这个确实是正确的,因为结果是utf8编码。这个现象确实诡异,请教了许多高手,得知,最好的结果就是逐个字段查询,才能显示中文,整个查询的话,会以utf8的格式显示出来。
上述代码中第14行data是整个查询的结果,如果指定某个具体的字段,如print
data[0][2](表示取查询结果的第一行第三列的字段的值),则会输出中文。
其实不仅仅是mssqlserver数据库,mysql(需下载MySQLdb包)、sqllite(python自带的文件数据库)、mongodb(需下载PyMongo包)等或者是普通文本文件也是类似的解决方案。

Ⅱ pycharm连接mssql报错ValueError怎么办

要这样写:
pymssql.connect(host='数据库服务器地址',user='user',password='密码',database='数据库名称',charset='utf8')
MSSQL是要密码认证的,它不是SQLite这种轻量可不加密的数据库。

Ⅲ 使用python pymssql连接 sql server报错,怎么解决

conn = pymssql.connect(host=r"localhost",user=r"sa",password=r"pwd",database=r"proction")

stack overflow 上有个类似的问题 有个答案是这样的 你试试 没用过mssql

Ⅳ python怎么连接sqlserver

如果使用pyodbc,直接看2就可以了,可以略过1
1. Python连接mssql
ubuntu linux
1.1
sudo apt-get install python
1.2 重启终端
1.3

sudo apt-get --assume-yes update
sudo apt-get --assume-yes install freetds-dev freetds-bin
sudo apt-get --assume-yes install python-dev python-pip
sudo pip install pymssql

1.4
sudo vi /etc/freetds/freetds.conf
2.安装pyodbc
2.1为了解决pyodbc.h:52:17: fatal error: sql.h: No such file or directory

sudo yum install unixODBC-devel.x86_64
然后:
sudo pip install pyodbc
2.2安装MSSQL native client
2.3

编写Python程序:
import pyodbc
conn = pyodbc.connect('DRIVER={SQL Server Native Client 11.0};
SERVER=aaaa; UID=bbbb; PWD=ccc; DATABASE=ddd; Encrypt=yes;
TrustServerCertificate=no');
cursor = conn.cursor()
cursor.execute("select count(distinct d) as cnt from ddddd6 where day_id=20160531")
row = cursor.fetchone()
while row:
print str(row[0])
row = cursor.fetchone()

Ⅳ python3连接MSSQL数据库 中文乱码怎么解决

在获取数据之前,执行mysql的命令set names utf8;
同时在python的文件头,加上
# -*- coding: utf-8 -*-
将这个文件也编码为utf8
如果还是乱码,就更改mysql的编码.

Ⅵ 如何使用Python3.4连接MySQL

序号 描述

1 去github上下载pymysql的安装包pymysql

2 解压到某个盘符下

3 打开cmd窗口(win环境下),进入pymysql的根目录下执行命令,python setup.py install

4 在程序里,导入pymysql

5 开始连接数据库


数据库操作的API文档连接:http://legacy.python.org/dev/peps/pep-0249/

代码如下:

Python代码

Ⅶ 您好,请问你的python连接数据库的问题是怎么解决的

mssql 是不是可以考虑直接用 os.popen,pymssql并不是很好用,老是会有大大小小的问题

defdbtest(dbpasswd):
#检查数据库是否可以登录
cmd="osql-Unetcafe-P"+dbpasswd+"-Q"+"""+
""+"""
popenstr=os.popen(cmd)
popenstrreadlines=popenstr.readlines()
iflen(popenstrreadlines)==0:return1
returnpopenstrreadlines

看一下这个,很久前写的
网页链接

Ⅷ 用python 实现一个批量打印的功能

你这些都是业务逻辑,你应该自己尝试实现,遇到具体技术问题再提

Ⅸ python用pymssql连接数据库时出现未知错误的问题

import pymssql

conn=pymssql.connect(host="localhost",user="sa",password="pwd",database="proction",charset='utf8')

缺少后边的charset是很容易报错的

Ⅹ python3 连接 sql server 2014

真巧,刚刚做过,链接的也是MSSQL2014的数据库,并且测试是成功的

importpymssql

conn=pymssql.connect(host='主机名或IP',user='数据库用户名',password='数据库用户密码',database='数据库名',charset='utf8')
cursor=conn.cursor()
ifnotcursor:
raise(NameError,"连接数据库失败")

strsql="select*from表"

try:
cursor.execute(strsql)#执行SQL语句
conn.commit()#修改数据后提交事务
except:
print(0,"错误:"+strsql)
pass
finally:
print(l,"成功!")
pass
cursor.close()#关闭对象
conn.close()#关闭数据库连接

import pymssql这句话必须有,主要是pymssql必须要安装上,可以使用pip list来查看是否安装

阅读全文

与python连接mssql相关的资料

热点内容
泰国剧罪孽父亲出海 浏览:7
叶天明柳韵txt 浏览:825
bch主流算法 浏览:767
免费在线国产片 浏览:200
苹果平板为什么连接服务器错误 浏览:89
穿越东晋成为王凝之 浏览:958
手机里的文件夹怎么拉出来 浏览:281
饥荒怎么输入ip进服务器 浏览:470
美国恐怖三极片 浏览:995
四川虚拟主机云服务器 浏览:780
母乳喂养真人版电影 浏览:396
免费看片链接 浏览:492
编程将中断类型号 浏览:597
数字编程学院 浏览:95
程序员不时尚 浏览:746
不付费看网站 浏览:230
《代人受过》训诫文 浏览:258
1n.d5h49m6. 浏览:687
linuxweb目录权限 浏览:945