Python程序設計教程-12-數據庫編程課件_第1頁
Python程序設計教程-12-數據庫編程課件_第2頁
Python程序設計教程-12-數據庫編程課件_第3頁
Python程序設計教程-12-數據庫編程課件_第4頁
Python程序設計教程-12-數據庫編程課件_第5頁
已閱讀5頁,還剩49頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

12Python的數據庫編程12Python的數據庫編程第12章Python的數據庫編程本章內容數據庫的基礎知識SQLITE數據庫關系數據庫語言SQLPython的SQLITE3編程數據庫編程應用Python支持Sybase、SQLServer、SQLite等多種數據庫,本章主要介紹Python自帶的關系型數據庫SQLite的應用第12章Python的數據庫編程本章內容12.1數據庫的基礎知識數據庫的概念數據庫(DataBase,DB)將大量數據按照一定的方式組織并存儲起來,是相互關聯(lián)的數據的集合。數據庫為用戶提供安全、高效、快速檢索和修改的數據集合。數據庫在數據庫系統(tǒng)中使用,其核心是數據庫管理系統(tǒng)。1.數據庫系統(tǒng)2.數據庫管理系統(tǒng)數據定義功能。數據操縱功能。數據庫的運行管理。數據通信功能。12.1數據庫的基礎知識數據庫的概念12.1數據庫的基礎知識關系型數據庫關系型數據庫是目前的主流數據庫。1.關系型數據庫的基本概念關系、元組、屬性、域、關鍵字。2.實體間聯(lián)系的類型實體是指客觀世界的事物,實體的集合構成實體集,在關系數據庫中用二維表來描述實體。實體之間有各種各樣的聯(lián)系,歸納起來有以下3種類型。

一對一聯(lián)系(1∶1),一對多聯(lián)系(1∶n),多對多聯(lián)系(m∶n)12.1數據庫的基礎知識關系型數據庫12.1數據庫的基礎知識Python的sqlite3模塊Python內置了SQLite數據庫,通過內置的sqlite3模塊可以直接訪問數據庫。sqlite3提供的Python程序上遵守PythonDB-API規(guī)范。PythonDB-API是為不同的數據庫提供的訪問接口規(guī)范。該接口定義了一系列必需的對象和數據庫存取方式,以便為各種底層數據庫系統(tǒng)和多樣的數據庫接口程序提供一致的訪問接口。12.1數據庫的基礎知識Python的sqlite3模塊12.2SQLite數據庫SQLite數據庫簡介SQLit是用C語言編寫的嵌入式數據庫,體積很小。SQLite不需要一個單獨的服務器進程或操作系統(tǒng)(無服務器的),也不需要配置。一個完整的SQLite數據庫存儲在單一的跨平臺的磁盤文件中。SQLite支持SQL92(SQL2)標準的大多數查詢語言的功能,并提供了簡單和易于使用的APl。12.2SQLite數據庫SQLite數據庫簡介12.2SQLite數據庫下載和安裝SQLite數據庫SQLite是開源的數據庫,可以在其官網免費下載。SQLite3是SQLite的第3個版本。SQLite數據庫不需要安裝,直接運行sqlite3.exe,即可打開SQLite數據庫的命令行窗口。12.2SQLite數據庫下載和安裝SQLite數據庫12.2SQLite數據庫SQLite3常用命令SQLite3命令可以分為兩類,一類是SQLite3交互模式命令,另一類是SQL命令。SQLite3交互模式常用的命令。交互命令功能sqlite3.exe[dbname]啟動sqlite3的交互模式,并創(chuàng)建dbname數據庫.opendbname創(chuàng)建數據庫或打開數據庫.databases顯示當前打開的數據庫文件.tables查看當前數據庫下的所有表.schema[tbname]查看表結構信息.exit退出交互模式.help列出命令的提示信息12.2SQLite數據庫SQLite3常用命令交互命令功12.2SQLite數據庫SQLite3的數據類型SQLite數據庫中的數據分為整數、小數、字符、日期、時間等類型。動態(tài)的數據類型,數據庫管理系統(tǒng)會根據列值自動判斷列的數據類型。靜態(tài)數據類型取決于它的存儲單元(所在列)的類型。SQLite3的動態(tài)數據類型向后兼容其他數據庫普遍使用的靜態(tài)類型。SQLite3使用弱數據類型。SQLite3的表可以不聲明列的類型。12.2SQLite數據庫SQLite3的數據類型12.2SQLite數據庫sqlite3模塊中的對象下面是sqlite3模塊中的部分常量、函數或對象。(1)sqlite3.version:常量,返回sqlite3模塊的版本號。(2)sqlite3.sqlite_version:常量,返回sqlite數據庫的版本號。(3)sqlite3.connect:數據庫連接對象。(4)sqlite3.Cursor:游標對象。(5)sqlite3.Row:行對象。(6)sqlite3.connect(dbname):函數,鏈接到數據庫,返回connect對象。12.2SQLite數據庫sqlite3模塊中的對象12.2SQLite數據庫SQLite3的函數

SQLite數據庫提供算術、字符串、日期、時間等操作函數,方便用戶處理數據庫中的數據。函數需要在SQLite的命令窗口使用select命令運行。SQLite3算術函數abs(x)返回絕對值max(x,y,……)返回最大值min(x,y,……)返回最小值random(*)返回隨機數round(x[,y])四含五入SQLite3字符串函數length(x)返回字符個數lower(x)大寫轉小寫upper(x)小寫轉大寫substr(x,y,Z)截取子串like(A,B)確定給定的字符串與指定的模式是否匹配SQLite3時間/日期函數date()產生日期datetime()產生日期和時間time()產生時間strftime()格式化字符串12.2SQLite數據庫SQLite3的函數 SQLit12.2SQLite數據庫創(chuàng)建SQLite數據庫運行SQLite數據庫的同時,通過參數創(chuàng)建Sqlite數據庫,方法如下。sqlite3dbname數據庫文件的擴展名為.db。如果數據庫文件存在,則打開該數據庫;否則創(chuàng)建該數據庫。12.2SQLite數據庫創(chuàng)建SQLite數據庫12.3關系數據庫語言SQLSQL是StructuredQueryLanguage的縮寫,即結構化查詢語言SQL命令的執(zhí)行,需要注意下面的問題。SQL命令需要在數據庫管理系統(tǒng)中運行。在SQLite窗口運行SQL命令,需要在SQL語句后加英文的分號后回車執(zhí)行。SQL命令不區(qū)分大小寫。12.3關系數據庫語言SQLSQL是Structured12.3關系數據庫語言SQL數據表的建立和刪除在SQL中,使用createtable語句創(chuàng)建表,deletetable刪除表。創(chuàng)建表的語法結構和示例12.3關系數據庫語言SQL數據表的建立和刪除創(chuàng)建表的語法12.3關系數據庫語言SQL向表中添加列altertable語句向表中添加列。altertable<表名>addcolumn<字段名>[<類型>]例12-3為表

employee中增加一列,列名為tele,數據類型為varchar,長度為50,列屬性不允許為空。altertableemployeeaddcolumntelevarchar(50)notnullschemaemployee用于查看表

eployee的結構。12.3關系數據庫語言SQL向表中添加列12.3關系數據庫語言SQL向表中插人數據insert語句向表中插入數據。insertinto<表名>[<字段名表>]values(<表達式表>)例12-4將下面數據插入到employee表中。1132,李四,男,部門經理,7548.6,11insertintoemployee(emp_id,emp_name,sex,title,wage,dep_id)values(1132,'李四','男','部門經理',7548.6,11)12.3關系數據庫語言SQL向表中插人數據12.3關系數據庫語言SQL修改表中的數據update語句修改表中的數據。update<表名>set<字段名1>=<表達式1>[,<字段名2>=<表達式2>…][where<條件表達式>]例10-5將employee表中,李四的工資改為7550元。

updateemployeesetwage=7550whereemp_name="李四"將李四的工資增加550元updateemployeesetwage=wage+550whereemp_name="李四"12.3關系數據庫語言SQL修改表中的數據12.3關系數據庫語言SQL刪除數據DELETE語句刪除表中的數據。deletefrom<表名>[where<條件表達式>]from指定從哪個表中刪除數據,where指定被刪除的記錄所滿足的條件,如果省略where子句,則刪除該表中的全部記錄。例10-6刪除表employee中性別為女的記錄。

deletefromemployeewheresex=’女’12.3關系數據庫語言SQL刪除數據12.3關系數據庫語言SQL查詢數據SQL語句創(chuàng)建查詢使用的是select命令,基本形式是由select-from-where子句組成。select<字段名表>|*from<表名>[join<表名>on<聯(lián)接條件>][where<條件表達式>][groupby<分組字段名>[having<條件表達式>]][orderby<排序選項>[asc|desc]]例10-7檢索工資高于6000元的雇員的雇員號和姓名信息。selectemp_id,emp_namefromemployeewherewage>6000例10-8檢索性別為“男”,并且工資高于5500的的雇員信息。select*fromemployeewheresex="男"andwage>550012.3關系數據庫語言SQL查詢數據12.4Python的SQLite3編程訪問數據庫的步驟訪問SQLite3數據庫主要過程如下。(1)導入Pythonsqlite3模塊(2)建立數據庫連接的Connection對象(3)創(chuàng)建游標對象(4)使用Cursor對象的execute()方法執(zhí)行SQL命令返回結果集(5)獲取游標的查詢結果集(6)數據庫的提交和回滾(7)關閉Cursor對象和Connection對象12.4Python的SQLite3編程訪問數據庫的步驟12.4Python的SQLite3編程>>>importsqlite3>>>dbstr="d:/sqlite/test.db"#連接到數據庫,還回sqlite3.Connection對象>>>con=sqlite3.connect(dbstr)>>>cur=con.cursor()>>>cur.execute("insertintoempvalues(101,'Jack',23)")>>>cur.execute("select*fromemp")>>>print(cur.fetchall())#提取查詢到的數據>>>

mit()#事務提交。>>>cur.close()#關閉Cursor對象。12.4Python的SQLite3編程>>>impor12.4Python的SQLite3編程創(chuàng)建數據庫和表例10-11使用sqlite3模塊創(chuàng)建數據庫managedb,并在其中創(chuàng)建表goods,表中包含id、name、gnumber、price等4列,其中id為主鍵(primarykey)。>>>importsqlite3#導入sqlite3模塊>>>dbstr="d:/sqlite/managedb.db">>>con=sqlite3.connect(dbstr)#創(chuàng)建sqlite數據庫>>>stmt="createtablegoods(idintprimarykey,name,gnumberinteger(2),price)">>>con.execute(stmt)12.4Python的SQLite3編程創(chuàng)建數據庫和表12.4Python的SQLite3編程數據庫的插入、更新和刪除操作在數中插入、更新、刪除記錄的一般步驟如下。(1)建立數據庫連接。(2)創(chuàng)建游標對象cur,使用cur.execute(sql)方法執(zhí)行SQL的insert、update、delete等語句,完成數據庫記錄錄的插入、更新、刪除操作,并根據返回值判斷操作結果。(3)提交操作。(4)關閉數據庫。例12-12在goods表中完成記錄的插入、更新和刪除操作。12.4Python的SQLite3編程數據庫的插入、更新12.5SQLite編程的應用使用SQLite數據庫實現(xiàn)一個簡單的訂單管理系統(tǒng)。數據庫名稱為test.db,訂單數據保存在order1表中,實現(xiàn)的是訂單數據的增刪改查的功能。應用程序中涉及的函數及功能如表。函數名稱函數功能getConnection()連接數據庫的通用函數showAllData()顯示所有記錄getOrderListInfo()獲得用戶輸入數據addRec()增加記錄delRec()刪除記錄modifyRec(修改記錄searchRec()查找記錄continueif()判斷是否繼續(xù)操作12.5SQLite編程的應用使用SQLite數據庫實現(xiàn)一小結數據庫、數據庫系統(tǒng)、數據庫管理系統(tǒng)等基本概念關系型數據庫是目前的主流數據庫,關系與二維表是等價的實體之間的對應關系稱為實體間的聯(lián)系Python自帶的關系型數據庫SQLite是一種開源的、嵌入式數據庫SQLite3交互模式常用的命令,SQLite3數據庫使用動態(tài)的數據類型SQL語言基本知識用SQLite數據庫實現(xiàn)一個簡單的訂單管理系統(tǒng)小結數據庫、數據庫系統(tǒng)、數據庫管理系統(tǒng)等基本概念作業(yè):

設計GUI界面,模擬用戶登錄功能,用戶輸入用戶名和密碼,如果正確提示登錄成功;否則提示登錄失敗,用戶的密碼信息保存在SQLite數據庫中。作業(yè):ThanksThanks12Python的數據庫編程12Python的數據庫編程第12章Python的數據庫編程本章內容數據庫的基礎知識SQLITE數據庫關系數據庫語言SQLPython的SQLITE3編程數據庫編程應用Python支持Sybase、SQLServer、SQLite等多種數據庫,本章主要介紹Python自帶的關系型數據庫SQLite的應用第12章Python的數據庫編程本章內容12.1數據庫的基礎知識數據庫的概念數據庫(DataBase,DB)將大量數據按照一定的方式組織并存儲起來,是相互關聯(lián)的數據的集合。數據庫為用戶提供安全、高效、快速檢索和修改的數據集合。數據庫在數據庫系統(tǒng)中使用,其核心是數據庫管理系統(tǒng)。1.數據庫系統(tǒng)2.數據庫管理系統(tǒng)數據定義功能。數據操縱功能。數據庫的運行管理。數據通信功能。12.1數據庫的基礎知識數據庫的概念12.1數據庫的基礎知識關系型數據庫關系型數據庫是目前的主流數據庫。1.關系型數據庫的基本概念關系、元組、屬性、域、關鍵字。2.實體間聯(lián)系的類型實體是指客觀世界的事物,實體的集合構成實體集,在關系數據庫中用二維表來描述實體。實體之間有各種各樣的聯(lián)系,歸納起來有以下3種類型。

一對一聯(lián)系(1∶1),一對多聯(lián)系(1∶n),多對多聯(lián)系(m∶n)12.1數據庫的基礎知識關系型數據庫12.1數據庫的基礎知識Python的sqlite3模塊Python內置了SQLite數據庫,通過內置的sqlite3模塊可以直接訪問數據庫。sqlite3提供的Python程序上遵守PythonDB-API規(guī)范。PythonDB-API是為不同的數據庫提供的訪問接口規(guī)范。該接口定義了一系列必需的對象和數據庫存取方式,以便為各種底層數據庫系統(tǒng)和多樣的數據庫接口程序提供一致的訪問接口。12.1數據庫的基礎知識Python的sqlite3模塊12.2SQLite數據庫SQLite數據庫簡介SQLit是用C語言編寫的嵌入式數據庫,體積很小。SQLite不需要一個單獨的服務器進程或操作系統(tǒng)(無服務器的),也不需要配置。一個完整的SQLite數據庫存儲在單一的跨平臺的磁盤文件中。SQLite支持SQL92(SQL2)標準的大多數查詢語言的功能,并提供了簡單和易于使用的APl。12.2SQLite數據庫SQLite數據庫簡介12.2SQLite數據庫下載和安裝SQLite數據庫SQLite是開源的數據庫,可以在其官網免費下載。SQLite3是SQLite的第3個版本。SQLite數據庫不需要安裝,直接運行sqlite3.exe,即可打開SQLite數據庫的命令行窗口。12.2SQLite數據庫下載和安裝SQLite數據庫12.2SQLite數據庫SQLite3常用命令SQLite3命令可以分為兩類,一類是SQLite3交互模式命令,另一類是SQL命令。SQLite3交互模式常用的命令。交互命令功能sqlite3.exe[dbname]啟動sqlite3的交互模式,并創(chuàng)建dbname數據庫.opendbname創(chuàng)建數據庫或打開數據庫.databases顯示當前打開的數據庫文件.tables查看當前數據庫下的所有表.schema[tbname]查看表結構信息.exit退出交互模式.help列出命令的提示信息12.2SQLite數據庫SQLite3常用命令交互命令功12.2SQLite數據庫SQLite3的數據類型SQLite數據庫中的數據分為整數、小數、字符、日期、時間等類型。動態(tài)的數據類型,數據庫管理系統(tǒng)會根據列值自動判斷列的數據類型。靜態(tài)數據類型取決于它的存儲單元(所在列)的類型。SQLite3的動態(tài)數據類型向后兼容其他數據庫普遍使用的靜態(tài)類型。SQLite3使用弱數據類型。SQLite3的表可以不聲明列的類型。12.2SQLite數據庫SQLite3的數據類型12.2SQLite數據庫sqlite3模塊中的對象下面是sqlite3模塊中的部分常量、函數或對象。(1)sqlite3.version:常量,返回sqlite3模塊的版本號。(2)sqlite3.sqlite_version:常量,返回sqlite數據庫的版本號。(3)sqlite3.connect:數據庫連接對象。(4)sqlite3.Cursor:游標對象。(5)sqlite3.Row:行對象。(6)sqlite3.connect(dbname):函數,鏈接到數據庫,返回connect對象。12.2SQLite數據庫sqlite3模塊中的對象12.2SQLite數據庫SQLite3的函數

SQLite數據庫提供算術、字符串、日期、時間等操作函數,方便用戶處理數據庫中的數據。函數需要在SQLite的命令窗口使用select命令運行。SQLite3算術函數abs(x)返回絕對值max(x,y,……)返回最大值min(x,y,……)返回最小值random(*)返回隨機數round(x[,y])四含五入SQLite3字符串函數length(x)返回字符個數lower(x)大寫轉小寫upper(x)小寫轉大寫substr(x,y,Z)截取子串like(A,B)確定給定的字符串與指定的模式是否匹配SQLite3時間/日期函數date()產生日期datetime()產生日期和時間time()產生時間strftime()格式化字符串12.2SQLite數據庫SQLite3的函數 SQLit12.2SQLite數據庫創(chuàng)建SQLite數據庫運行SQLite數據庫的同時,通過參數創(chuàng)建Sqlite數據庫,方法如下。sqlite3dbname數據庫文件的擴展名為.db。如果數據庫文件存在,則打開該數據庫;否則創(chuàng)建該數據庫。12.2SQLite數據庫創(chuàng)建SQLite數據庫12.3關系數據庫語言SQLSQL是StructuredQueryLanguage的縮寫,即結構化查詢語言SQL命令的執(zhí)行,需要注意下面的問題。SQL命令需要在數據庫管理系統(tǒng)中運行。在SQLite窗口運行SQL命令,需要在SQL語句后加英文的分號后回車執(zhí)行。SQL命令不區(qū)分大小寫。12.3關系數據庫語言SQLSQL是Structured12.3關系數據庫語言SQL數據表的建立和刪除在SQL中,使用createtable語句創(chuàng)建表,deletetable刪除表。創(chuàng)建表的語法結構和示例12.3關系數據庫語言SQL數據表的建立和刪除創(chuàng)建表的語法12.3關系數據庫語言SQL向表中添加列altertable語句向表中添加列。altertable<表名>addcolumn<字段名>[<類型>]例12-3為表

employee中增加一列,列名為tele,數據類型為varchar,長度為50,列屬性不允許為空。altertableemployeeaddcolumntelevarchar(50)notnullschemaemployee用于查看表

eployee的結構。12.3關系數據庫語言SQL向表中添加列12.3關系數據庫語言SQL向表中插人數據insert語句向表中插入數據。insertinto<表名>[<字段名表>]values(<表達式表>)例12-4將下面數據插入到employee表中。1132,李四,男,部門經理,7548.6,11insertintoemployee(emp_id,emp_name,sex,title,wage,dep_id)values(1132,'李四','男','部門經理',7548.6,11)12.3關系數據庫語言SQL向表中插人數據12.3關系數據庫語言SQL修改表中的數據update語句修改表中的數據。update<表名>set<字段名1>=<表達式1>[,<字段名2>=<表達式2>…][where<條件表達式>]例10-5將employee表中,李四的工資改為7550元。

updateemployeesetwage=7550whereemp_name="李四"將李四的工資增加550元updateemployeesetwage=wage+550whereemp_name="李四"12.3關系數據庫語言SQL修改表中的數據12.3關系數據庫語言SQL刪除數據DELETE語句刪除表中的數據。deletefrom<表名>[where<條件表達式>]from指定從哪個表中刪除數據,where指定被刪除的記錄所滿足的條件,如果省略where子句,則刪除該表中的全部記錄。例10-6刪除表employee中性別為女的記錄。

deletefromemployeewheresex=’女’12.3關系數據庫語言SQL刪除數據12.3關系數據庫語言SQL查詢數據SQL語句創(chuàng)建查詢使用的是select命令,基本形式是由select-from-where子句組成。select<字段名表>|*from<表名>[join<表名>on<聯(lián)接條件>][where<條件表達式>][groupby<分組字段名>[having<條件表達式>]][orderby<排序選項>[asc|desc]]例10-7檢索工資高于6000元的雇員的雇員號和姓名信息。selectemp_id,emp_namefromemployeewherewage>6000例10-8檢索性別為“男”,并且工資高于5500的的雇員信息。select*fromemployeewheresex="男"andwage>550012.3關系數據庫語言SQL查詢數據12.4Python的SQLite3編程訪問數據庫的步驟訪問SQLite3數據庫主要過程如下。(1)導入Pythonsqlite3模塊(2)建立數據庫連接的Connection對象(3)創(chuàng)建游標對象(4)使用Cursor對象的execute()方法執(zhí)行SQL命令返回結果集(5)獲取游標的查詢結果集(6)數據庫的提交和回滾(7)關閉Cursor對象和Connection對象12.4Python的SQLite3編程訪問數據庫的步驟12.4Python的SQLite3編程>>>importsqlite3>>>dbstr="d:/sqlite/test.db"#連接到數據庫,還回sqlite3.Connection對象>>>con=sqlite3.connect(dbstr)>>>cur=con.cursor()>>>cur.execute("insertintoempvalues(101,'Jack',23)")>>>cur.execute("select*fromemp")>>>print(cur.fetchall())#提取查詢到的數據>>>

mit()#事務提交。>>>cur.close()#關閉Cursor對象。12.4Python的SQLite3編程>>>impor

溫馨提示

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

評論

0/150

提交評論