網站首頁 編程語言 正文
用python操作ms?sqlserver,有好幾種方法:
(1)利用pymssql (2)利用pyodbc
這里講import?pyodbc來操作sql?server?database。
pyodbc是Python包,使用ODBC驅動器來連接SQL Server數據庫,其中pyodbc的基本類型是Connection,Cursor、Row
其中,Connection表示客戶端和數據庫的連接,并用于提交事務;
Cursor表示向數據庫發送的查詢請求;
Row表示獲取的結果集。
首先查看自己電腦有沒有安裝sql?server對應的odbc,在控制面板中可以查:
控制面板-->管理工具-->數據源(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的結果了。
備注:如果使用pymssql,可能會出現中文亂碼的問題,我搞不懂怎么解決。而使用pyodbc就沒出現亂碼。哪個簡單用哪個。
原文鏈接:https://blog.csdn.net/MFCdestoryer/article/details/128903053
相關推薦
- 2022-12-09 pygame畫點線方法詳解_python
- 2022-12-12 python語法之通過value找key問題_python
- 2023-04-19 C/C++實現內存泄漏檢測詳解_C 語言
- 2022-07-22 如何處理SQL Server中附加數據庫時出現的錯誤
- 2022-05-10 筆記本能連接 WiFi,但在瀏覽器中并不能訪問網頁的問題的四種方案;
- 2022-07-12 element表格 頻繁切換維度,導致表頭渲染有誤
- 2022-12-25 React不使用requestIdleCallback實現調度原理解析_React
- 2022-07-11 UVM中超時退出set_timeout函數
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支