第10章 Python程序設(shè)計基礎(chǔ)數(shù)據(jù)庫操作_第1頁
第10章 Python程序設(shè)計基礎(chǔ)數(shù)據(jù)庫操作_第2頁
第10章 Python程序設(shè)計基礎(chǔ)數(shù)據(jù)庫操作_第3頁
第10章 Python程序設(shè)計基礎(chǔ)數(shù)據(jù)庫操作_第4頁
第10章 Python程序設(shè)計基礎(chǔ)數(shù)據(jù)庫操作_第5頁
已閱讀5頁,還剩9頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

第10章數(shù)據(jù)庫操作CONTENTS目錄10.1訪問SQLite數(shù)據(jù)庫0110.2訪問其他數(shù)據(jù)庫0210.1訪問SQLite數(shù)據(jù)庫10.1.1創(chuàng)建數(shù)據(jù)庫連接導(dǎo)入sqlite3模塊:fromsqlite3import*創(chuàng)建數(shù)據(jù)庫連接對象:conn=connect(database)數(shù)據(jù)庫連接對象的常用方法:close(...):關(guān)閉數(shù)據(jù)庫連接;commit(...):提交當(dāng)前數(shù)據(jù)庫事務(wù);cursor(...):返回一個游標(biāo)對象;execute(...):執(zhí)行一個SQL語句;executemany(...):重復(fù)執(zhí)行一個SQL語句;executescript(...):一次執(zhí)行多個SQL語句;interrupt(...):中止待處理的數(shù)據(jù)庫操作;rollback(...):回滾當(dāng)前數(shù)據(jù)庫事務(wù)。10.1.2執(zhí)行SQL數(shù)據(jù)操作(1)調(diào)用數(shù)據(jù)庫連接對象的execute()方法來執(zhí)行一個SQL查詢語句:conn.execute(sql,params)SQLite中常用SQL語:CREATETABLE:在數(shù)據(jù)庫中創(chuàng)建表;DROPTABLE:從數(shù)據(jù)庫中刪除表;INSERT

INTO:在表中添加記錄;UPDATE:修改表中的一條或多條記錄;DELETE:從表中刪除一條或多條記錄;SELECT:從表中返回一些記錄。提交當(dāng)前數(shù)據(jù)庫事務(wù):mit()關(guān)閉數(shù)據(jù)庫連接:conn.close()關(guān)閉數(shù)據(jù)庫連接后,便不能再調(diào)用該連接的相應(yīng)方法進行操作。10.1.2執(zhí)行SQL數(shù)據(jù)操作(2)2.添加數(shù)據(jù)INSERTINTO表名[(列1,列2,列3,

...,列N)]VALUES(值1,值2,值3,...,值N)3.更新數(shù)據(jù)UPDATE表名SET列1=值1,列2=值2,....

,列N=值NWHERE條件4.刪除數(shù)據(jù)DELETEFROM表名WHERE條件10.1.3執(zhí)行SQL數(shù)據(jù)查詢(1)通過調(diào)用數(shù)據(jù)庫連接對象的cursor()方法創(chuàng)建一個游標(biāo)對象:cursor=conn.cursor()通過調(diào)用conn.execute()方法來執(zhí)行一個SELECT查詢語句:cursor.execute(sql,params)SELECT語句的基本語法格式:SELECT列1,列2,...,列NFROM表名WHERE條件GROUPBY列名HAVING條件ORDERBY列表[ASC|DESC]10.1.3執(zhí)行SQL數(shù)據(jù)查詢(2)通過調(diào)用游標(biāo)對象的以下方法來獲取記錄。(1)使用fetchone()方法從結(jié)果集中返回一條記錄:row=cursor.fetchone()(2)使用fetchmany()方法從結(jié)果集中返回多條記錄:rows=cursor.fetchmany(size)(3)使用fetchall()方法從結(jié)果集中返回所有記錄:rows=cursor.fetchall()10.2訪問其他數(shù)據(jù)庫10.2.1訪問MySQL數(shù)據(jù)庫導(dǎo)入pymysql模塊:frompymysqlimport*通過調(diào)用pymysql模塊提供的connect()方法創(chuàng)建數(shù)據(jù)庫連接對象:conn=connect(host=…,port=…,user=…,password=…,db=…,

charset=…)如果要在數(shù)據(jù)庫中進行記錄的增刪改操作,或者要從數(shù)據(jù)庫中查詢所需要的數(shù)據(jù),則應(yīng)應(yīng)創(chuàng)建一個游標(biāo)對象,然后調(diào)用該游標(biāo)對象的execute()方法,以執(zhí)行INSERT

INTO、UPDATE、DELETE或SELECT語句。執(zhí)行SELECT語句時將會生成一個結(jié)果集,通過調(diào)用該游標(biāo)對象的fetchone()、fetchmany()或fetchall()方法,可以從結(jié)果集中獲取數(shù)據(jù)行。10.2.2訪問SQLServer數(shù)據(jù)庫(1)導(dǎo)入pymssql模塊:frompymssqlimport*1.創(chuàng)建數(shù)據(jù)庫連接conn=connection(host=…,database=…,user=…,password=…,as_dict=…,…)使用Windows身份驗證模式連接到SQLServer數(shù)據(jù)庫:conn=connect(host=r"數(shù)據(jù)庫主機名\實例名",

user=r"公司域名\用戶名",

password="密碼",database="數(shù)據(jù)庫名")連接對象的方法。autocommit(status):用于打開或關(guān)閉自動提交模式;close():關(guān)閉數(shù)據(jù)庫連接;cursor():返回一個游標(biāo)對象;commit():用于提交當(dāng)前事務(wù);rollback():用于回滾當(dāng)前事務(wù)。10.2.2訪問SQLServer數(shù)據(jù)庫(2)2.使用游標(biāo)對象創(chuàng)建游標(biāo)對象:cursor=conn.cursor()游標(biāo)對象的屬性rowcount:返回上一次操作影響的行數(shù);connection:返回對其上創(chuàng)建光標(biāo)的連接對象的引用;lastrowid:返回最后插入的行的標(biāo)識值;rownumber:返回結(jié)果集中游標(biāo)的當(dāng)前索引。游標(biāo)對象的方法close():關(guān)閉游標(biāo);execute(sql)、execute(sql,params):對數(shù)據(jù)庫執(zhí)行SQL操作;executemany(sql,params_seq):對數(shù)據(jù)庫重復(fù)執(zhí)行操作;fetchone():讀取查詢結(jié)果的下一行;fetchmany(size=None):獲取查詢結(jié)果的下一批行;fetchall():獲取查詢結(jié)果的所有剩余行;nextset():使游標(biāo)跳到下一個可用的結(jié)果集。10.2.3訪問Access數(shù)據(jù)庫(1)導(dǎo)入win32com.client模塊:fromwin32com.client

import*1.創(chuàng)建數(shù)據(jù)庫連接(1)創(chuàng)建ADODBConnection對象:conn=Dispatch("ADODB.Connection")(2)設(shè)置連接對象的ConnectionString屬性,指定連接字符串:conn.ConnectionString="Provider=Microsoft.ACE.OLEDB.12.0;DataSource=%s"%(dbpath)(3)調(diào)用連接對象的Open()方法,打開數(shù)據(jù)庫連接:conn.Open()10.2.3訪問Access數(shù)據(jù)庫(2)2.執(zhí)行數(shù)據(jù)操作conn.Execute(sql)3.執(zhí)行數(shù)據(jù)查詢(1

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論