python連接本地SQL?server詳細圖文教程
一.設置本地賬號
1.新建用戶
在對象資源管理其中,選中 安全性/登錄名 右鍵新建登錄名
在彈出的對話框中,設置登錄名為“sa”(sa是最高權限用戶名,也可以自定義,但不推薦),選擇“SQL Server身份驗證”,設置密碼,在“默認數(shù)據(jù)庫”中選擇我們需要建立聯(lián)系的目標數(shù)據(jù)庫,“默認語言”為簡體中文。
最后在“狀態(tài)”選項卡下選擇“啟用”并確保“允許連接”復選框被選中。
2.開啟雙重驗證
在資源對象管理器中,右鍵單擊SQL Server實例名稱并選擇“屬性”。
在彈出的對話框中,選擇“安全性”選項卡,將“身份驗證”設置為“SQL Server和Windows身份驗證模式”,并選擇“確定”以保存更改。
3,開啟TCP/IP本地服務
在SQL Server Configuration Manager中,右鍵“SQL Server網(wǎng)絡配置”,選擇“TCP/IP”協(xié)議,點擊“啟用”。
選擇TCP/IP屬性,選擇IP,將“TCP動態(tài)端口”設置為0
然后找到“IPALL”選項,將“TCP端口”設置為1433(或其他的端口號)。
保存更改并重啟SQL Server服務。
完成以上步驟后,即可使用Python連接本地SQL Server數(shù)據(jù)庫。
二.python連接實例
注意,下文是本地連接用法,也就是只能連接本機服務器的數(shù)據(jù)庫,想要連接外地服務器請參考其它文章。
以 Pycharm為例
1.下載支持庫
有用pymssql的方法,但是我沒成功,于是換了另一個用pyodbc的方法
進入Anaconda Prompt,進入已有環(huán)境,輸入一下命令下載支持庫(這里命令末尾添加了阿里云鏡像源,能下載的快一點)
pip install pyodbc -i https://mirrors.aliyun.com/pypi/simple/
2.驗證連接
創(chuàng)建一個 .py文件,編輯以下代碼驗證能否建立連接:
import pyodbc server = 'localhost' # 這里就寫localhost就可以了 user = '之前創(chuàng)建的用戶名' password = '給對應賬戶設置的密碼' database = '想要建立連接的數(shù)據(jù)庫名' try: conn_str = f'DRIVER={{SQL Server}};SERVER={server};DATABASE={database};UID={user};PWD={password};TrustServerCertificate=yes' connect = pyodbc.connect(conn_str) print("連接成功") except pyodbc.Error as e: print(f"連接失敗: {e}")
3.可能失敗原因
需要注意的是,如果沒有創(chuàng)建sa賬戶的話,這里應該要先給對應數(shù)據(jù)庫開起用戶權限
在對象資源管理器中,右鍵對應數(shù)據(jù)庫,點擊屬性,點擊文件,點擊如圖紅框
點擊瀏覽,選中需要基于權限的用戶,但是好像只能選擇一個
如圖,我選擇了sd用戶,點擊確定,再點擊確定就可以了。
最后顯示連接成功:
三.基本查詢語法使用
import pyodbc server = 'localhost' # 這里就寫localhost就可以了 user = '之前創(chuàng)建的用戶名' password = '給對應賬戶設置的密碼' database = '想要建立連接的數(shù)據(jù)庫名' conn_str = f'DRIVER={{SQL Server}};SERVER={server};DATABASE={database};UID={user};PWD={password};TrustServerCertificate=yes' connect = pyodbc.connect(conn_str) print("連接成功") # 創(chuàng)建游標對象 cursor = connect.cursor() # 執(zhí)行查詢語句,這里查詢作者數(shù)據(jù)庫里的圖書表 query = "SELECT * FROM 圖書" cursor.execute(query) # 獲取查詢結果 rows = cursor.fetchall() # 打印查詢結果 if rows: print("圖書表的數(shù)據(jù)如下:") for row in rows: print(row) # 關閉游標和連接 cursor.close() connect.close()
結果如下,沒有亂碼問題,不知道是不是引用庫不一樣的原因,pymssql庫看很多博主講是有代碼的,反正不管,能成功就行。
總結
到此這篇關于python連接本地SQL server的文章就介紹到這了,更多相關python連接本地SQL server內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python Django 簡單分頁的實現(xiàn)代碼解析
這篇文章主要介紹了Python Django 簡單分頁的實現(xiàn)代碼解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08PyQt5內(nèi)嵌瀏覽器注入JavaScript腳本實現(xiàn)自動化操作的代碼實例
今天小編就為大家分享一篇關于PyQt5內(nèi)嵌瀏覽器注入JavaScript腳本實現(xiàn)自動化操作的代碼實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-02-02Python數(shù)據(jù)結構dict常用操作代碼實例
這篇文章主要介紹了Python數(shù)據(jù)結構dict常用操作代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03python機器學習deepchecks庫訓練檢查模型特點探索
這篇文章主要介紹了python機器學習deepchecks庫的訓練檢查模型特點實例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01