網(wǎng)站首頁 編程語言 正文
用python操作ms?sqlserver,有好幾種方法:
(1)利用pymssql (2)利用pyodbc
這里講import?pyodbc來操作sql?server?database。
pyodbc是Python包,使用ODBC驅(qū)動器來連接SQL Server數(shù)據(jù)庫,其中pyodbc的基本類型是Connection,Cursor、Row
其中,Connection表示客戶端和數(shù)據(jù)庫的連接,并用于提交事務(wù);
Cursor表示向數(shù)據(jù)庫發(fā)送的查詢請求;
Row表示獲取的結(jié)果集。
首先查看自己電腦有沒有安裝sql?server對應(yīng)的odbc,在控制面板中可以查:
控制面板-->管理工具-->數(shù)據(jù)源(ODBC)
我電腦的版本是??ODBC Driver 11 for SQL Server?
不同電腦安裝了不同的sql?server版本,可能driver不同,有可能是12、13、19等等版本。
然后利用powershell下載安裝pyodbc包,如圖輸入
pip install pyodbc
下載成功之后,輸入看看有沒有成功安裝package
pip list
成功安裝package之后,就可以開始編輯python代碼了。
代碼如下(兩個文件DBHelp_SqlServer.py??和?testConn.py):
文件1(DBHelp_SqlServer.py)
import pyodbc
class MSSQL:
def __init__(self, IP, UserID, Pwd, db):
self.host=IP;
self.user=UserID;
self.password=Pwd;
self.dbname=db;
def __getConnect(self):
if not self.dbname:
raise(NameError,"db name undefine error")
else:
connSTR="Driver={ODBC Driver 11 for SQL Server};SERVER=%s,1433;DATABASE=%s;UID=%s;PWD=%s" % (self.host, self.dbname, self.user, self.password)
##example: Driver={ODBC Driver 11 for SQL Server};SERVER=127.0.0.1,1433;DATABASE=MyTestDB;UID=sa;PWD=Abc123
self.conn = pyodbc.connect(connSTR);
cu= self.conn.cursor();
if not cu:
raise(NameError,"db connect error");
else:
return cu;
def ExecuteTableQuery(self,selectSql):
cuu = self.__getConnect();
selectRows = cuu.execute(selectSql);
resList=selectRows.fetchall();
self.conn.close();
return resList;
def ExecuteNonQuery(self,sql):
cuu = self.__getConnect();
cuu.execute(sql);
self.conn.commit();
self.conn.close();
def PrintODBCDrivers(self):
print(pyodbc.drivers() );
文件2(testConn.py)
import DBHelp_SqlServer
db=DBHelp_SqlServer.MSSQL(IP="127.0.0.1", UserID="sa", Pwd="Abc123", db="MyTestDB");
sqlinsert="insert into TeacherTable(TName,TClass) values('呂老師','三年級')"
db.ExecuteNonQuery(sql=sqlinsert);
sql1="select * from TeacherTable";
datatable = db.ExecuteTableQuery(selectSql=sql1);
print(datatable);
運行之后就能看到insert?sql和select?sql的結(jié)果了。
備注:如果使用pymssql,可能會出現(xiàn)中文亂碼的問題,我搞不懂怎么解決。而使用pyodbc就沒出現(xiàn)亂碼。哪個簡單用哪個。
原文鏈接:https://blog.csdn.net/MFCdestoryer/article/details/128903053
相關(guān)推薦
- 2023-04-13 react 打包優(yōu)化,配置生產(chǎn)環(huán)境不輸出console.log
- 2022-04-12 Python?設(shè)計模式行為型訪問者模式_python
- 2022-11-22 在?React?項目中全量使用?Hooks的方法_React
- 2022-10-24 Python?中單例模式的實現(xiàn)方法_python
- 2023-02-04 Python中itertools簡介使用介紹_python
- 2022-07-20 詳解Go程序添加遠(yuǎn)程調(diào)用tcpdump功能_Golang
- 2024-02-26 JqGrid獲得所有選中行數(shù)據(jù)ID數(shù)組,獲取所有行的ID數(shù)組
- 2022-10-11 在NVIDIA Jetson Xavier NX上使用tensorflow-gpu
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支