欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python基于Pymssql模塊實(shí)現(xiàn)連接SQL Server數(shù)據(jù)庫的方法詳解

 更新時(shí)間:2017年07月20日 11:59:29   作者:不想長(zhǎng)大啊  
這篇文章主要介紹了Python基于Pymssql模塊實(shí)現(xiàn)連接SQL Server數(shù)據(jù)庫的方法,較為詳細(xì)的分析了pymssql模塊的下載、安裝及連接、操作SQL Server數(shù)據(jù)庫的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了Python基于Pymssql模塊實(shí)現(xiàn)連接SQL Server數(shù)據(jù)庫的方法。分享給大家供大家參考,具體如下:

數(shù)據(jù)庫版本:SQL Server 2012。

按照Python版本來選擇下載pymssql模塊,這樣才能連接上sql server。

我安裝的python版本是3.5 ,64位的,所以下載的pymssql模塊是:pymssql-2.1.3-cp35-cp35m-win_amd64.whl

我把文件下載后放到E盤,安裝pymssql模塊:

C:\Users\Administrator>pip install e:\pymssql-2.1.3-cp35-cp35m-win_amd64.whl
Processing e:\pymssql-2.1.3-cp35-cp35m-win_amd64.whl
Installing collected packages: pymssql
Successfully installed pymssql-2.1.3

一、創(chuàng)建數(shù)據(jù)庫Test、表tb、插入數(shù)據(jù)

特別需要注意的是:為了避免亂碼問題,這里Name列是nvarchar類型的(適合中文),不會(huì)出現(xiàn)亂碼現(xiàn)象,一開始用的varchar類型出現(xiàn)了亂碼。

create database Test;
go
use test;
go
if object_id('tb') is not null
  drop table tb;
go
CREATE TABLE TB(ID INT,NAME NVARCHAR(20),SCORE NUMERIC(10,2));
INSERT INTO TB(ID,NAME,SCORE)
VALUES(1,'語文',100),
   (2,'數(shù)學(xué)',80),
   (3,'英語',900),
   (4,'政治',65),
   (5,'物理',65),
   (6,'化學(xué)',85),
   (7,'生物',55),
   (8,'地理',100)

二、連接數(shù)據(jù)庫、查詢、增加、更新數(shù)據(jù)

connect的參數(shù):

user:用戶名
password:密碼
trusted:布爾值,指定是否使用windows身份認(rèn)證登陸
host :主機(jī)名
database:數(shù)據(jù)庫
timeout:查詢超時(shí)
login_timeout:登陸超時(shí)
charset:數(shù)據(jù)庫的字符集
as_dict:布爾值,指定返回值是字典還是元組
max_conn:最大連接數(shù)

# -*- coding:gbk -*-
import pymssql
#數(shù)據(jù)庫連接
conn=pymssql.connect(host='wc-pc',user='sa',password='ggg',database='Test')
#打開游標(biāo)
cur=conn.cursor();
if not cur:
  raise Exception('數(shù)據(jù)庫連接失敗!')
sSQL = 'SELECT * FROM TB'
#執(zhí)行sql,獲取所有數(shù)據(jù)
cur.execute(sSQL)
result=cur.fetchall()
#1.result是list,而其中的每個(gè)元素是 tuple
print(type(result),type(result[0]))
#2.
print('\n\n總行數(shù):'+ str(cur.rowcount))
#3.通過enumerate返回行號(hào)
for i,(id,name,v) in enumerate(result):
  print('第 '+str(i+1)+' 行記錄->>> '+ str(id) +':'+ name+ ':' + str(v) )
#4.修改數(shù)據(jù)
cur.execute("insert into tb(id,name,score) values(9,'歷史',75)")
cur.execute("update tb set score=95 where id=7")
conn.commit() #修改數(shù)據(jù)后提交事務(wù)
#再查一次
cur.execute(sSQL)
#5.一次取一條數(shù)據(jù),cur.rowcount為-1
r=cur.fetchone()
i=1
print('\n')
while r:
  id,name,v =r #r是一個(gè)元祖
  print('第 '+str(i)+' 行記錄->>> '+ str(id) +':'+ name+ ':' + str(v) )
  r=cur.fetchone()
  i+= 1
conn.close()

基本的步驟就是:

(1)連接數(shù)據(jù)庫,指定連接參數(shù)
(2)打開cursor,執(zhí)行sql
(3)通過cursor獲取數(shù)據(jù),具體可以是一次獲取所有數(shù)據(jù),也可以是一次獲取一行。
 整個(gè)結(jié)果集是元組列表,就是list類型的,而每一條記錄是一個(gè)tuple,也就是元祖。
(4)如果是增、改數(shù)據(jù),必須就要調(diào)用commit()函數(shù)來提交事務(wù),否則程序已退出,數(shù)據(jù)庫里的數(shù)據(jù)不會(huì)有變化。
(5)最后要用close關(guān)閉連接。

運(yùn)行效果:

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python常見數(shù)據(jù)庫操作技巧匯總》、《Python編碼操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • python利用socket實(shí)現(xiàn)udp文件傳輸功能

    python利用socket實(shí)現(xiàn)udp文件傳輸功能

    這篇文章主要為大家詳細(xì)介紹了python利用socket實(shí)現(xiàn)udp文件傳輸功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Python中用pyinstaller打包時(shí)的圖標(biāo)問題及解決方法

    Python中用pyinstaller打包時(shí)的圖標(biāo)問題及解決方法

    這篇文章主要介紹了python中用pyinstaller打包時(shí)的圖標(biāo)問題及解決方法,本文從兩方面給大家分析原因所在,通過截圖實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2020-02-02
  • Python深度學(xué)習(xí)線性代數(shù)示例詳解

    Python深度學(xué)習(xí)線性代數(shù)示例詳解

    這篇文章主要為大家講解了Python深度學(xué)習(xí)中線性代數(shù)的示例詳解有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-10-10
  • python3 實(shí)現(xiàn)在運(yùn)行的時(shí)候隱藏命令窗口

    python3 實(shí)現(xiàn)在運(yùn)行的時(shí)候隱藏命令窗口

    這篇文章主要介紹了python3 實(shí)現(xiàn)在運(yùn)行的時(shí)候隱藏命令窗口方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • 詳解Python中的函數(shù)參數(shù)傳遞方法*args與**kwargs

    詳解Python中的函數(shù)參數(shù)傳遞方法*args與**kwargs

    本文將討論P(yáng)ython的函數(shù)參數(shù)。我們將了解args和kwargs,/和的都是什么,雖然這個(gè)問題是一個(gè)基本的python問題,但是在我們寫代碼時(shí)會(huì)經(jīng)常遇到,比如timm中就大量使用了這樣的參數(shù)傳遞方式
    2023-03-03
  • Python淺析匿名函數(shù)lambda的用法

    Python淺析匿名函數(shù)lambda的用法

    lambda所表示的匿名函數(shù)的內(nèi)容應(yīng)該是很簡(jiǎn)單的,如果復(fù)雜的話,干脆就重新定義一個(gè)函數(shù)了,使用lambda就有點(diǎn)過于執(zhí)拗了。lambda就是用來定義一個(gè)匿名函數(shù)的,如果還要給他綁定一個(gè)名字的話,就會(huì)顯得有點(diǎn)畫蛇添足,通常是直接使用lambda函數(shù)
    2022-07-07
  • 使用python生成定制化詞云的代碼示例

    使用python生成定制化詞云的代碼示例

    詞云,作為一種流行的數(shù)據(jù)可視化形式,能夠?qū)⒋罅课谋緮?shù)據(jù)中的關(guān)鍵詞以視覺化的方式呈現(xiàn),讓我們迅速捕捉到文本的核心,本文將通過Python編程語言,使用jieba和wordcloud庫,生成一個(gè)具有特定形狀的詞云,需要的朋友可以參考下
    2024-09-09
  • Python中Array特性與應(yīng)用實(shí)例深入探究

    Python中Array特性與應(yīng)用實(shí)例深入探究

    這篇文章主要為大家介紹了Python中Array特性與應(yīng)用實(shí)例深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • Django項(xiàng)目中用JS實(shí)現(xiàn)加載子頁面并傳值的方法

    Django項(xiàng)目中用JS實(shí)現(xiàn)加載子頁面并傳值的方法

    今天小編就為大家分享一篇Django項(xiàng)目中用JS實(shí)現(xiàn)加載子頁面并傳值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 人工智能學(xué)習(xí)pyTorch的ResNet殘差模塊示例詳解

    人工智能學(xué)習(xí)pyTorch的ResNet殘差模塊示例詳解

    這篇文章主要為大家介紹了人工智能學(xué)習(xí)pyTorch的ResNet殘差模塊示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-11-11

最新評(píng)論