一文教會(huì)你用python連接并簡(jiǎn)單操作SQLserver數(shù)據(jù)庫(kù)
實(shí)驗(yàn)環(huán)境:
python版本3.9
Python 3.9.7 (tags/v3.9.7:1016ef3, Aug 30 2021, 20:19:38) [MSC v.1929 64 bit (AMD64)] on win32 Type "help", "copyright", "credits" or "license" for more information. >>>
SQLserver版本2019
exec xp_msver

基本步驟:
安裝pymssql模塊
#pip 安裝pymssql (python3.6以上直接安裝不上) pip install pymssql
#在官網(wǎng)下載pymssql對(duì)應(yīng)版本,在當(dāng)前文件夾下 https://pypi.org/project/pymssql/ pip install pymssql-2.2.4-cp39-cp39-win_amd64.whl
編寫(xiě)代碼
sqlserver.py
#coding=utf-8 #settng設(shè)置全局為utf—8格式
#導(dǎo)包
import pymssql
#創(chuàng)建連接字符串 (sqlserver默認(rèn)端口為1433)
conn =pymssql.connect(host='localhost', #這里的host='_'可以用本機(jī)ip或ip+端口號(hào)
server="******",#本地服務(wù)器
port="1433",#TCP端口
user="sa",password="******",
database="******",
charset="GBK"
#這里設(shè)置全局的GBK,如果設(shè)置的是UTF—8需要將數(shù)據(jù)庫(kù)默認(rèn)的GBK轉(zhuǎn)化成UTF-8
)
if conn:
print('連接數(shù)據(jù)庫(kù)成功!')#測(cè)試是否連接上
查詢(xún)
#查詢(xún)語(yǔ)句
cursor =conn.cursor() #使用cursor()方法獲取操作游標(biāo)
sql_select="SELECT * FROM STUDENT" #數(shù)據(jù)庫(kù)查詢(xún)語(yǔ)句
cursor.execute(sql_select) #執(zhí)行語(yǔ)句
results =cursor.fetchall() #獲取所有記錄列表
#print('原始:',end="")
#print(result) #后邊有空格
for result in results:
result= list(result) #元組轉(zhuǎn)化為列表
for res in range (len(result)):
if isinstance(result[res],str):
result[res]=result[res].replace(' ','')解決空格問(wèn)題
result=tuple(result) #列表再轉(zhuǎn)換為元組
print("處理后:",end="")
print(result)
#
conn.commit()
#關(guān)閉數(shù)據(jù)庫(kù)
conn.close()原始:

處理后:

插入
#插入語(yǔ)句 cursor =conn.cursor() sql_insert="insert into student values(990031,'wang',20,'男','bb','aa')" cursor.execute(sql_insert) conn.commit() conn.close()
更新
#更新語(yǔ)句 cursor =conn.cursor() sql_update="update student set AGE=21 where SNO='990031' " cursor.execute(sql_update) conn.commit() conn.close()
刪除語(yǔ)句
#刪除語(yǔ)句 cursor =conn.cursor() sql_delete="delete from student where sno='990031'" cursor.execute(sql_delete) conn.commit() conn.close()
增加表
#新建表 cursor =conn.cursor() sql_create="""create table table_student(SNO int primary key not null,SNAME varchar(100),SDEPT varchar(100),BPLACE varchar(100))""" cursor.execute(sql_create) conn.commit() conn.close()
錯(cuò)誤1:
報(bào)錯(cuò)

原因
沒(méi)有把TCP/IP協(xié)議打開(kāi)
查看TCP端口位置:

保證TCP/IP開(kāi)啟:
開(kāi)啟之后,服務(wù),重新啟動(dòng)服務(wù)


錯(cuò)誤2:
出現(xiàn)查詢(xún)結(jié)果亂碼:
解決辦法:
查看sqlserver的編碼:
select COLLATIONPROPERTY('chinese_PRC_Stroke_CI_AI_KS_WS','CodePage')
查詢(xún)結(jié)果:
936 簡(jiǎn)體中文gbk
950 繁體中文BIG5
437 加拿大/美國(guó) 英語(yǔ)
932 日文
949 韓文
866 俄文
總結(jié)
到此這篇關(guān)于python連接并簡(jiǎn)單操作SQLserver數(shù)據(jù)庫(kù)的文章就介紹到這了,更多相關(guān)python連接操作SQLserver數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
pytorch 實(shí)現(xiàn)在一個(gè)優(yōu)化器中設(shè)置多個(gè)網(wǎng)絡(luò)參數(shù)的例子
今天小編就為大家分享一篇pytorch 實(shí)現(xiàn)在一個(gè)優(yōu)化器中設(shè)置多個(gè)網(wǎng)絡(luò)參數(shù)的例子,具有很好參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02
python讀寫(xiě)ini配置文件方法實(shí)例分析
這篇文章主要介紹了python讀寫(xiě)ini配置文件方法,實(shí)例分析了Python針對(duì)ini配置文件的相關(guān)讀寫(xiě)技巧,需要的朋友可以參考下2015-06-06
Python變量和數(shù)據(jù)類(lèi)型和數(shù)據(jù)類(lèi)型的轉(zhuǎn)換
這篇文章主要介紹了Python變量和數(shù)據(jù)類(lèi)型和數(shù)據(jù)類(lèi)型的轉(zhuǎn)換,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
淺談Python3中打開(kāi)文件的方式(With open)
本文主要介紹了淺談Python3中打開(kāi)文件的方式(With open),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
Python實(shí)現(xiàn)極限車(chē)神游戲的示例代碼
今天小編要為大家介紹一款小編自己用Python代碼碼出來(lái)的賽車(chē)風(fēng)格的打字小游戲,不僅能游戲還能學(xué)到很多不同類(lèi)型的編程代碼關(guān)鍵字的語(yǔ)言,需要的可以參考一下2023-02-02
使用Python處理json字符串中的非法雙引號(hào)問(wèn)題
這篇文章主要介紹了使用Python處理json字符串中的非法雙引號(hào)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
Python 70行代碼實(shí)現(xiàn)簡(jiǎn)單算式計(jì)算器解析
這篇文章主要介紹了Python 70行代碼實(shí)現(xiàn)簡(jiǎn)單算式計(jì)算器解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08

