版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
12Python的數(shù)據(jù)庫(kù)編程12Python的數(shù)據(jù)庫(kù)編程第12章Python的數(shù)據(jù)庫(kù)編程本章內(nèi)容數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)SQLITE數(shù)據(jù)庫(kù)關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQLPython的SQLITE3編程數(shù)據(jù)庫(kù)編程應(yīng)用Python支持Sybase、SQLServer、SQLite等多種數(shù)據(jù)庫(kù),本章主要介紹Python自帶的關(guān)系型數(shù)據(jù)庫(kù)SQLite的應(yīng)用第12章Python的數(shù)據(jù)庫(kù)編程本章內(nèi)容12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)數(shù)據(jù)庫(kù)的概念數(shù)據(jù)庫(kù)(DataBase,DB)將大量數(shù)據(jù)按照一定的方式組織并存儲(chǔ)起來,是相互關(guān)聯(lián)的數(shù)據(jù)的集合。數(shù)據(jù)庫(kù)為用戶提供安全、高效、快速檢索和修改的數(shù)據(jù)集合。數(shù)據(jù)庫(kù)在數(shù)據(jù)庫(kù)系統(tǒng)中使用,其核心是數(shù)據(jù)庫(kù)管理系統(tǒng)。1.?dāng)?shù)據(jù)庫(kù)系統(tǒng)2.?dāng)?shù)據(jù)庫(kù)管理系統(tǒng)數(shù)據(jù)定義功能。數(shù)據(jù)操縱功能。數(shù)據(jù)庫(kù)的運(yùn)行管理。數(shù)據(jù)通信功能。12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)數(shù)據(jù)庫(kù)的概念12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)關(guān)系型數(shù)據(jù)庫(kù)關(guān)系型數(shù)據(jù)庫(kù)是目前的主流數(shù)據(jù)庫(kù)。1.關(guān)系型數(shù)據(jù)庫(kù)的基本概念關(guān)系、元組、屬性、域、關(guān)鍵字。2.實(shí)體間聯(lián)系的類型實(shí)體是指客觀世界的事物,實(shí)體的集合構(gòu)成實(shí)體集,在關(guān)系數(shù)據(jù)庫(kù)中用二維表來描述實(shí)體。實(shí)體之間有各種各樣的聯(lián)系,歸納起來有以下3種類型。
一對(duì)一聯(lián)系(1∶1),一對(duì)多聯(lián)系(1∶n),多對(duì)多聯(lián)系(m∶n)12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)關(guān)系型數(shù)據(jù)庫(kù)12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)Python的sqlite3模塊Python內(nèi)置了SQLite數(shù)據(jù)庫(kù),通過內(nèi)置的sqlite3模塊可以直接訪問數(shù)據(jù)庫(kù)。sqlite3提供的Python程序上遵守PythonDB-API規(guī)范。PythonDB-API是為不同的數(shù)據(jù)庫(kù)提供的訪問接口規(guī)范。該接口定義了一系列必需的對(duì)象和數(shù)據(jù)庫(kù)存取方式,以便為各種底層數(shù)據(jù)庫(kù)系統(tǒng)和多樣的數(shù)據(jù)庫(kù)接口程序提供一致的訪問接口。12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)Python的sqlite3模塊12.2SQLite數(shù)據(jù)庫(kù)SQLite數(shù)據(jù)庫(kù)簡(jiǎn)介SQLit是用C語(yǔ)言編寫的嵌入式數(shù)據(jù)庫(kù),體積很小。SQLite不需要一個(gè)單獨(dú)的服務(wù)器進(jìn)程或操作系統(tǒng)(無服務(wù)器的),也不需要配置。一個(gè)完整的SQLite數(shù)據(jù)庫(kù)存儲(chǔ)在單一的跨平臺(tái)的磁盤文件中。SQLite支持SQL92(SQL2)標(biāo)準(zhǔn)的大多數(shù)查詢語(yǔ)言的功能,并提供了簡(jiǎn)單和易于使用的APl。12.2SQLite數(shù)據(jù)庫(kù)SQLite數(shù)據(jù)庫(kù)簡(jiǎn)介12.2SQLite數(shù)據(jù)庫(kù)下載和安裝SQLite數(shù)據(jù)庫(kù)SQLite是開源的數(shù)據(jù)庫(kù),可以在其官網(wǎng)免費(fèi)下載。SQLite3是SQLite的第3個(gè)版本。SQLite數(shù)據(jù)庫(kù)不需要安裝,直接運(yùn)行sqlite3.exe,即可打開SQLite數(shù)據(jù)庫(kù)的命令行窗口。12.2SQLite數(shù)據(jù)庫(kù)下載和安裝SQLite數(shù)據(jù)庫(kù)12.2SQLite數(shù)據(jù)庫(kù)SQLite3常用命令SQLite3命令可以分為兩類,一類是SQLite3交互模式命令,另一類是SQL命令。SQLite3交互模式常用的命令。交互命令功能sqlite3.exe[dbname]啟動(dòng)sqlite3的交互模式,并創(chuàng)建dbname數(shù)據(jù)庫(kù).opendbname創(chuàng)建數(shù)據(jù)庫(kù)或打開數(shù)據(jù)庫(kù).databases顯示當(dāng)前打開的數(shù)據(jù)庫(kù)文件.tables查看當(dāng)前數(shù)據(jù)庫(kù)下的所有表.schema[tbname]查看表結(jié)構(gòu)信息.exit退出交互模式.help列出命令的提示信息12.2SQLite數(shù)據(jù)庫(kù)SQLite3常用命令交互命令功12.2SQLite數(shù)據(jù)庫(kù)SQLite3的數(shù)據(jù)類型SQLite數(shù)據(jù)庫(kù)中的數(shù)據(jù)分為整數(shù)、小數(shù)、字符、日期、時(shí)間等類型。動(dòng)態(tài)的數(shù)據(jù)類型,數(shù)據(jù)庫(kù)管理系統(tǒng)會(huì)根據(jù)列值自動(dòng)判斷列的數(shù)據(jù)類型。靜態(tài)數(shù)據(jù)類型取決于它的存儲(chǔ)單元(所在列)的類型。SQLite3的動(dòng)態(tài)數(shù)據(jù)類型向后兼容其他數(shù)據(jù)庫(kù)普遍使用的靜態(tài)類型。SQLite3使用弱數(shù)據(jù)類型。SQLite3的表可以不聲明列的類型。12.2SQLite數(shù)據(jù)庫(kù)SQLite3的數(shù)據(jù)類型12.2SQLite數(shù)據(jù)庫(kù)sqlite3模塊中的對(duì)象下面是sqlite3模塊中的部分常量、函數(shù)或?qū)ο?。?)sqlite3.version:常量,返回sqlite3模塊的版本號(hào)。(2)sqlite3.sqlite_version:常量,返回sqlite數(shù)據(jù)庫(kù)的版本號(hào)。(3)sqlite3.connect:數(shù)據(jù)庫(kù)連接對(duì)象。(4)sqlite3.Cursor:游標(biāo)對(duì)象。(5)sqlite3.Row:行對(duì)象。(6)sqlite3.connect(dbname):函數(shù),鏈接到數(shù)據(jù)庫(kù),返回connect對(duì)象。12.2SQLite數(shù)據(jù)庫(kù)sqlite3模塊中的對(duì)象12.2SQLite數(shù)據(jù)庫(kù)SQLite3的函數(shù)
SQLite數(shù)據(jù)庫(kù)提供算術(shù)、字符串、日期、時(shí)間等操作函數(shù),方便用戶處理數(shù)據(jù)庫(kù)中的數(shù)據(jù)。函數(shù)需要在SQLite的命令窗口使用select命令運(yùn)行。SQLite3算術(shù)函數(shù)abs(x)返回絕對(duì)值max(x,y,……)返回最大值min(x,y,……)返回最小值random(*)返回隨機(jī)數(shù)round(x[,y])四含五入SQLite3字符串函數(shù)length(x)返回字符個(gè)數(shù)lower(x)大寫轉(zhuǎn)小寫upper(x)小寫轉(zhuǎn)大寫substr(x,y,Z)截取子串like(A,B)確定給定的字符串與指定的模式是否匹配SQLite3時(shí)間/日期函數(shù)date()產(chǎn)生日期datetime()產(chǎn)生日期和時(shí)間time()產(chǎn)生時(shí)間strftime()格式化字符串12.2SQLite數(shù)據(jù)庫(kù)SQLite3的函數(shù) SQLit12.2SQLite數(shù)據(jù)庫(kù)創(chuàng)建SQLite數(shù)據(jù)庫(kù)運(yùn)行SQLite數(shù)據(jù)庫(kù)的同時(shí),通過參數(shù)創(chuàng)建Sqlite數(shù)據(jù)庫(kù),方法如下。sqlite3dbname數(shù)據(jù)庫(kù)文件的擴(kuò)展名為.db。如果數(shù)據(jù)庫(kù)文件存在,則打開該數(shù)據(jù)庫(kù);否則創(chuàng)建該數(shù)據(jù)庫(kù)。12.2SQLite數(shù)據(jù)庫(kù)創(chuàng)建SQLite數(shù)據(jù)庫(kù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQLSQL是StructuredQueryLanguage的縮寫,即結(jié)構(gòu)化查詢語(yǔ)言SQL命令的執(zhí)行,需要注意下面的問題。SQL命令需要在數(shù)據(jù)庫(kù)管理系統(tǒng)中運(yùn)行。在SQLite窗口運(yùn)行SQL命令,需要在SQL語(yǔ)句后加英文的分號(hào)后回車執(zhí)行。SQL命令不區(qū)分大小寫。12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQLSQL是Structured12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL數(shù)據(jù)表的建立和刪除在SQL中,使用createtable語(yǔ)句創(chuàng)建表,deletetable刪除表。創(chuàng)建表的語(yǔ)法結(jié)構(gòu)和示例12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL數(shù)據(jù)表的建立和刪除創(chuàng)建表的語(yǔ)法12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中添加列altertable語(yǔ)句向表中添加列。altertable<表名>addcolumn<字段名>[<類型>]例12-3為表
employee中增加一列,列名為tele,數(shù)據(jù)類型為varchar,長(zhǎng)度為50,列屬性不允許為空。altertableemployeeaddcolumntelevarchar(50)notnullschemaemployee用于查看表
eployee的結(jié)構(gòu)。12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中添加列12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中插人數(shù)據(jù)insert語(yǔ)句向表中插入數(shù)據(jù)。insertinto<表名>[<字段名表>]values(<表達(dá)式表>)例12-4將下面數(shù)據(jù)插入到employee表中。1132,李四,男,部門經(jīng)理,7548.6,11insertintoemployee(emp_id,emp_name,sex,title,wage,dep_id)values(1132,'李四','男','部門經(jīng)理',7548.6,11)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中插人數(shù)據(jù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL修改表中的數(shù)據(jù)update語(yǔ)句修改表中的數(shù)據(jù)。update<表名>set<字段名1>=<表達(dá)式1>[,<字段名2>=<表達(dá)式2>…][where<條件表達(dá)式>]例10-5將employee表中,李四的工資改為7550元。
updateemployeesetwage=7550whereemp_name="李四"將李四的工資增加550元updateemployeesetwage=wage+550whereemp_name="李四"12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL修改表中的數(shù)據(jù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL刪除數(shù)據(jù)DELETE語(yǔ)句刪除表中的數(shù)據(jù)。deletefrom<表名>[where<條件表達(dá)式>]from指定從哪個(gè)表中刪除數(shù)據(jù),where指定被刪除的記錄所滿足的條件,如果省略where子句,則刪除該表中的全部記錄。例10-6刪除表employee中性別為女的記錄。
deletefromemployeewheresex=’女’12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL刪除數(shù)據(jù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL查詢數(shù)據(jù)SQL語(yǔ)句創(chuàng)建查詢使用的是select命令,基本形式是由select-from-where子句組成。select<字段名表>|*from<表名>[join<表名>on<聯(lián)接條件>][where<條件表達(dá)式>][groupby<分組字段名>[having<條件表達(dá)式>]][orderby<排序選項(xiàng)>[asc|desc]]例10-7檢索工資高于6000元的雇員的雇員號(hào)和姓名信息。selectemp_id,emp_namefromemployeewherewage>6000例10-8檢索性別為“男”,并且工資高于5500的的雇員信息。select*fromemployeewheresex="男"andwage>550012.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL查詢數(shù)據(jù)12.4Python的SQLite3編程訪問數(shù)據(jù)庫(kù)的步驟訪問SQLite3數(shù)據(jù)庫(kù)主要過程如下。(1)導(dǎo)入Pythonsqlite3模塊(2)建立數(shù)據(jù)庫(kù)連接的Connection對(duì)象(3)創(chuàng)建游標(biāo)對(duì)象(4)使用Cursor對(duì)象的execute()方法執(zhí)行SQL命令返回結(jié)果集(5)獲取游標(biāo)的查詢結(jié)果集(6)數(shù)據(jù)庫(kù)的提交和回滾(7)關(guān)閉Cursor對(duì)象和Connection對(duì)象12.4Python的SQLite3編程訪問數(shù)據(jù)庫(kù)的步驟12.4Python的SQLite3編程>>>importsqlite3>>>dbstr="d:/sqlite/test.db"#連接到數(shù)據(jù)庫(kù),還回sqlite3.Connection對(duì)象>>>con=sqlite3.connect(dbstr)>>>cur=con.cursor()>>>cur.execute("insertintoempvalues(101,'Jack',23)")>>>cur.execute("select*fromemp")>>>print(cur.fetchall())#提取查詢到的數(shù)據(jù)>>>
mit()#事務(wù)提交。>>>cur.close()#關(guān)閉Cursor對(duì)象。12.4Python的SQLite3編程>>>impor12.4Python的SQLite3編程創(chuàng)建數(shù)據(jù)庫(kù)和表例10-11使用sqlite3模塊創(chuàng)建數(shù)據(jù)庫(kù)managedb,并在其中創(chuàng)建表goods,表中包含id、name、gnumber、price等4列,其中id為主鍵(primarykey)。>>>importsqlite3#導(dǎo)入sqlite3模塊>>>dbstr="d:/sqlite/managedb.db">>>con=sqlite3.connect(dbstr)#創(chuàng)建sqlite數(shù)據(jù)庫(kù)>>>stmt="createtablegoods(idintprimarykey,name,gnumberinteger(2),price)">>>con.execute(stmt)12.4Python的SQLite3編程創(chuàng)建數(shù)據(jù)庫(kù)和表12.4Python的SQLite3編程數(shù)據(jù)庫(kù)的插入、更新和刪除操作在數(shù)中插入、更新、刪除記錄的一般步驟如下。(1)建立數(shù)據(jù)庫(kù)連接。(2)創(chuàng)建游標(biāo)對(duì)象cur,使用cur.execute(sql)方法執(zhí)行SQL的insert、update、delete等語(yǔ)句,完成數(shù)據(jù)庫(kù)記錄錄的插入、更新、刪除操作,并根據(jù)返回值判斷操作結(jié)果。(3)提交操作。(4)關(guān)閉數(shù)據(jù)庫(kù)。例12-12在goods表中完成記錄的插入、更新和刪除操作。12.4Python的SQLite3編程數(shù)據(jù)庫(kù)的插入、更新12.5SQLite編程的應(yīng)用使用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的訂單管理系統(tǒng)。數(shù)據(jù)庫(kù)名稱為test.db,訂單數(shù)據(jù)保存在order1表中,實(shí)現(xiàn)的是訂單數(shù)據(jù)的增刪改查的功能。應(yīng)用程序中涉及的函數(shù)及功能如表。函數(shù)名稱函數(shù)功能getConnection()連接數(shù)據(jù)庫(kù)的通用函數(shù)showAllData()顯示所有記錄getOrderListInfo()獲得用戶輸入數(shù)據(jù)addRec()增加記錄delRec()刪除記錄modifyRec(修改記錄searchRec()查找記錄continueif()判斷是否繼續(xù)操作12.5SQLite編程的應(yīng)用使用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)一小結(jié)數(shù)據(jù)庫(kù)、數(shù)據(jù)庫(kù)系統(tǒng)、數(shù)據(jù)庫(kù)管理系統(tǒng)等基本概念關(guān)系型數(shù)據(jù)庫(kù)是目前的主流數(shù)據(jù)庫(kù),關(guān)系與二維表是等價(jià)的實(shí)體之間的對(duì)應(yīng)關(guān)系稱為實(shí)體間的聯(lián)系Python自帶的關(guān)系型數(shù)據(jù)庫(kù)SQLite是一種開源的、嵌入式數(shù)據(jù)庫(kù)SQLite3交互模式常用的命令,SQLite3數(shù)據(jù)庫(kù)使用動(dòng)態(tài)的數(shù)據(jù)類型SQL語(yǔ)言基本知識(shí)用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的訂單管理系統(tǒng)小結(jié)數(shù)據(jù)庫(kù)、數(shù)據(jù)庫(kù)系統(tǒng)、數(shù)據(jù)庫(kù)管理系統(tǒng)等基本概念作業(yè):
設(shè)計(jì)GUI界面,模擬用戶登錄功能,用戶輸入用戶名和密碼,如果正確提示登錄成功;否則提示登錄失敗,用戶的密碼信息保存在SQLite數(shù)據(jù)庫(kù)中。作業(yè):ThanksThanks12Python的數(shù)據(jù)庫(kù)編程12Python的數(shù)據(jù)庫(kù)編程第12章Python的數(shù)據(jù)庫(kù)編程本章內(nèi)容數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)SQLITE數(shù)據(jù)庫(kù)關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQLPython的SQLITE3編程數(shù)據(jù)庫(kù)編程應(yīng)用Python支持Sybase、SQLServer、SQLite等多種數(shù)據(jù)庫(kù),本章主要介紹Python自帶的關(guān)系型數(shù)據(jù)庫(kù)SQLite的應(yīng)用第12章Python的數(shù)據(jù)庫(kù)編程本章內(nèi)容12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)數(shù)據(jù)庫(kù)的概念數(shù)據(jù)庫(kù)(DataBase,DB)將大量數(shù)據(jù)按照一定的方式組織并存儲(chǔ)起來,是相互關(guān)聯(lián)的數(shù)據(jù)的集合。數(shù)據(jù)庫(kù)為用戶提供安全、高效、快速檢索和修改的數(shù)據(jù)集合。數(shù)據(jù)庫(kù)在數(shù)據(jù)庫(kù)系統(tǒng)中使用,其核心是數(shù)據(jù)庫(kù)管理系統(tǒng)。1.?dāng)?shù)據(jù)庫(kù)系統(tǒng)2.?dāng)?shù)據(jù)庫(kù)管理系統(tǒng)數(shù)據(jù)定義功能。數(shù)據(jù)操縱功能。數(shù)據(jù)庫(kù)的運(yùn)行管理。數(shù)據(jù)通信功能。12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)數(shù)據(jù)庫(kù)的概念12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)關(guān)系型數(shù)據(jù)庫(kù)關(guān)系型數(shù)據(jù)庫(kù)是目前的主流數(shù)據(jù)庫(kù)。1.關(guān)系型數(shù)據(jù)庫(kù)的基本概念關(guān)系、元組、屬性、域、關(guān)鍵字。2.實(shí)體間聯(lián)系的類型實(shí)體是指客觀世界的事物,實(shí)體的集合構(gòu)成實(shí)體集,在關(guān)系數(shù)據(jù)庫(kù)中用二維表來描述實(shí)體。實(shí)體之間有各種各樣的聯(lián)系,歸納起來有以下3種類型。
一對(duì)一聯(lián)系(1∶1),一對(duì)多聯(lián)系(1∶n),多對(duì)多聯(lián)系(m∶n)12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)關(guān)系型數(shù)據(jù)庫(kù)12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)Python的sqlite3模塊Python內(nèi)置了SQLite數(shù)據(jù)庫(kù),通過內(nèi)置的sqlite3模塊可以直接訪問數(shù)據(jù)庫(kù)。sqlite3提供的Python程序上遵守PythonDB-API規(guī)范。PythonDB-API是為不同的數(shù)據(jù)庫(kù)提供的訪問接口規(guī)范。該接口定義了一系列必需的對(duì)象和數(shù)據(jù)庫(kù)存取方式,以便為各種底層數(shù)據(jù)庫(kù)系統(tǒng)和多樣的數(shù)據(jù)庫(kù)接口程序提供一致的訪問接口。12.1數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí)Python的sqlite3模塊12.2SQLite數(shù)據(jù)庫(kù)SQLite數(shù)據(jù)庫(kù)簡(jiǎn)介SQLit是用C語(yǔ)言編寫的嵌入式數(shù)據(jù)庫(kù),體積很小。SQLite不需要一個(gè)單獨(dú)的服務(wù)器進(jìn)程或操作系統(tǒng)(無服務(wù)器的),也不需要配置。一個(gè)完整的SQLite數(shù)據(jù)庫(kù)存儲(chǔ)在單一的跨平臺(tái)的磁盤文件中。SQLite支持SQL92(SQL2)標(biāo)準(zhǔn)的大多數(shù)查詢語(yǔ)言的功能,并提供了簡(jiǎn)單和易于使用的APl。12.2SQLite數(shù)據(jù)庫(kù)SQLite數(shù)據(jù)庫(kù)簡(jiǎn)介12.2SQLite數(shù)據(jù)庫(kù)下載和安裝SQLite數(shù)據(jù)庫(kù)SQLite是開源的數(shù)據(jù)庫(kù),可以在其官網(wǎng)免費(fèi)下載。SQLite3是SQLite的第3個(gè)版本。SQLite數(shù)據(jù)庫(kù)不需要安裝,直接運(yùn)行sqlite3.exe,即可打開SQLite數(shù)據(jù)庫(kù)的命令行窗口。12.2SQLite數(shù)據(jù)庫(kù)下載和安裝SQLite數(shù)據(jù)庫(kù)12.2SQLite數(shù)據(jù)庫(kù)SQLite3常用命令SQLite3命令可以分為兩類,一類是SQLite3交互模式命令,另一類是SQL命令。SQLite3交互模式常用的命令。交互命令功能sqlite3.exe[dbname]啟動(dòng)sqlite3的交互模式,并創(chuàng)建dbname數(shù)據(jù)庫(kù).opendbname創(chuàng)建數(shù)據(jù)庫(kù)或打開數(shù)據(jù)庫(kù).databases顯示當(dāng)前打開的數(shù)據(jù)庫(kù)文件.tables查看當(dāng)前數(shù)據(jù)庫(kù)下的所有表.schema[tbname]查看表結(jié)構(gòu)信息.exit退出交互模式.help列出命令的提示信息12.2SQLite數(shù)據(jù)庫(kù)SQLite3常用命令交互命令功12.2SQLite數(shù)據(jù)庫(kù)SQLite3的數(shù)據(jù)類型SQLite數(shù)據(jù)庫(kù)中的數(shù)據(jù)分為整數(shù)、小數(shù)、字符、日期、時(shí)間等類型。動(dòng)態(tài)的數(shù)據(jù)類型,數(shù)據(jù)庫(kù)管理系統(tǒng)會(huì)根據(jù)列值自動(dòng)判斷列的數(shù)據(jù)類型。靜態(tài)數(shù)據(jù)類型取決于它的存儲(chǔ)單元(所在列)的類型。SQLite3的動(dòng)態(tài)數(shù)據(jù)類型向后兼容其他數(shù)據(jù)庫(kù)普遍使用的靜態(tài)類型。SQLite3使用弱數(shù)據(jù)類型。SQLite3的表可以不聲明列的類型。12.2SQLite數(shù)據(jù)庫(kù)SQLite3的數(shù)據(jù)類型12.2SQLite數(shù)據(jù)庫(kù)sqlite3模塊中的對(duì)象下面是sqlite3模塊中的部分常量、函數(shù)或?qū)ο蟆#?)sqlite3.version:常量,返回sqlite3模塊的版本號(hào)。(2)sqlite3.sqlite_version:常量,返回sqlite數(shù)據(jù)庫(kù)的版本號(hào)。(3)sqlite3.connect:數(shù)據(jù)庫(kù)連接對(duì)象。(4)sqlite3.Cursor:游標(biāo)對(duì)象。(5)sqlite3.Row:行對(duì)象。(6)sqlite3.connect(dbname):函數(shù),鏈接到數(shù)據(jù)庫(kù),返回connect對(duì)象。12.2SQLite數(shù)據(jù)庫(kù)sqlite3模塊中的對(duì)象12.2SQLite數(shù)據(jù)庫(kù)SQLite3的函數(shù)
SQLite數(shù)據(jù)庫(kù)提供算術(shù)、字符串、日期、時(shí)間等操作函數(shù),方便用戶處理數(shù)據(jù)庫(kù)中的數(shù)據(jù)。函數(shù)需要在SQLite的命令窗口使用select命令運(yùn)行。SQLite3算術(shù)函數(shù)abs(x)返回絕對(duì)值max(x,y,……)返回最大值min(x,y,……)返回最小值random(*)返回隨機(jī)數(shù)round(x[,y])四含五入SQLite3字符串函數(shù)length(x)返回字符個(gè)數(shù)lower(x)大寫轉(zhuǎn)小寫upper(x)小寫轉(zhuǎn)大寫substr(x,y,Z)截取子串like(A,B)確定給定的字符串與指定的模式是否匹配SQLite3時(shí)間/日期函數(shù)date()產(chǎn)生日期datetime()產(chǎn)生日期和時(shí)間time()產(chǎn)生時(shí)間strftime()格式化字符串12.2SQLite數(shù)據(jù)庫(kù)SQLite3的函數(shù) SQLit12.2SQLite數(shù)據(jù)庫(kù)創(chuàng)建SQLite數(shù)據(jù)庫(kù)運(yùn)行SQLite數(shù)據(jù)庫(kù)的同時(shí),通過參數(shù)創(chuàng)建Sqlite數(shù)據(jù)庫(kù),方法如下。sqlite3dbname數(shù)據(jù)庫(kù)文件的擴(kuò)展名為.db。如果數(shù)據(jù)庫(kù)文件存在,則打開該數(shù)據(jù)庫(kù);否則創(chuàng)建該數(shù)據(jù)庫(kù)。12.2SQLite數(shù)據(jù)庫(kù)創(chuàng)建SQLite數(shù)據(jù)庫(kù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQLSQL是StructuredQueryLanguage的縮寫,即結(jié)構(gòu)化查詢語(yǔ)言SQL命令的執(zhí)行,需要注意下面的問題。SQL命令需要在數(shù)據(jù)庫(kù)管理系統(tǒng)中運(yùn)行。在SQLite窗口運(yùn)行SQL命令,需要在SQL語(yǔ)句后加英文的分號(hào)后回車執(zhí)行。SQL命令不區(qū)分大小寫。12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQLSQL是Structured12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL數(shù)據(jù)表的建立和刪除在SQL中,使用createtable語(yǔ)句創(chuàng)建表,deletetable刪除表。創(chuàng)建表的語(yǔ)法結(jié)構(gòu)和示例12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL數(shù)據(jù)表的建立和刪除創(chuàng)建表的語(yǔ)法12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中添加列altertable語(yǔ)句向表中添加列。altertable<表名>addcolumn<字段名>[<類型>]例12-3為表
employee中增加一列,列名為tele,數(shù)據(jù)類型為varchar,長(zhǎng)度為50,列屬性不允許為空。altertableemployeeaddcolumntelevarchar(50)notnullschemaemployee用于查看表
eployee的結(jié)構(gòu)。12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中添加列12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中插人數(shù)據(jù)insert語(yǔ)句向表中插入數(shù)據(jù)。insertinto<表名>[<字段名表>]values(<表達(dá)式表>)例12-4將下面數(shù)據(jù)插入到employee表中。1132,李四,男,部門經(jīng)理,7548.6,11insertintoemployee(emp_id,emp_name,sex,title,wage,dep_id)values(1132,'李四','男','部門經(jīng)理',7548.6,11)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL向表中插人數(shù)據(jù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL修改表中的數(shù)據(jù)update語(yǔ)句修改表中的數(shù)據(jù)。update<表名>set<字段名1>=<表達(dá)式1>[,<字段名2>=<表達(dá)式2>…][where<條件表達(dá)式>]例10-5將employee表中,李四的工資改為7550元。
updateemployeesetwage=7550whereemp_name="李四"將李四的工資增加550元updateemployeesetwage=wage+550whereemp_name="李四"12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL修改表中的數(shù)據(jù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL刪除數(shù)據(jù)DELETE語(yǔ)句刪除表中的數(shù)據(jù)。deletefrom<表名>[where<條件表達(dá)式>]from指定從哪個(gè)表中刪除數(shù)據(jù),where指定被刪除的記錄所滿足的條件,如果省略where子句,則刪除該表中的全部記錄。例10-6刪除表employee中性別為女的記錄。
deletefromemployeewheresex=’女’12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL刪除數(shù)據(jù)12.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL查詢數(shù)據(jù)SQL語(yǔ)句創(chuàng)建查詢使用的是select命令,基本形式是由select-from-where子句組成。select<字段名表>|*from<表名>[join<表名>on<聯(lián)接條件>][where<條件表達(dá)式>][groupby<分組字段名>[having<條件表達(dá)式>]][orderby<排序選項(xiàng)>[asc|desc]]例10-7檢索工資高于6000元的雇員的雇員號(hào)和姓名信息。selectemp_id,emp_namefromemployeewherewage>6000例10-8檢索性別為“男”,并且工資高于5500的的雇員信息。select*fromemployeewheresex="男"andwage>550012.3關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言SQL查詢數(shù)據(jù)12.4Python的SQLite3編程訪問數(shù)據(jù)庫(kù)的步驟訪問SQLite3數(shù)據(jù)庫(kù)主要過程如下。(1)導(dǎo)入Pythonsqlite3模塊(2)建立數(shù)據(jù)庫(kù)連接的Connection對(duì)象(3)創(chuàng)建游標(biāo)對(duì)象(4)使用Cursor對(duì)象的execute()方法執(zhí)行SQL命令返回結(jié)果集(5)獲取游標(biāo)的查詢結(jié)果集(6)數(shù)據(jù)庫(kù)的提交和回滾(7)關(guān)閉Cursor對(duì)象和Connection對(duì)象12.4Python的SQLite3編程訪問數(shù)據(jù)庫(kù)的步驟12.4Python的SQLite3編程>>>importsqlite3>>>dbstr="d:/sqlite/test.db"#連接到數(shù)據(jù)庫(kù),還回sqlite3.Connection對(duì)象>>>con=sqlite3.connect(dbstr)>>>cur=con.cursor()>>>cur.execute("insertintoempvalues(101,'Jack',23)")>>>cur.execute("select*fromemp")>>>print(cur.fetchall())#提取查詢到的數(shù)據(jù)>>>
mit()#事務(wù)提交。>>>cur.close()#關(guān)閉Cursor對(duì)象。12.4Python的SQLite3編程>>>impor
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 大排檔施工組織設(shè)計(jì)
- 法治政 府說課稿
- 次根式的加減說課稿
- 南京工業(yè)大學(xué)浦江學(xué)院《酒店市場(chǎng)營(yíng)銷》2023-2024學(xué)年第一學(xué)期期末試卷
- 南京工業(yè)大學(xué)浦江學(xué)院《機(jī)械設(shè)計(jì)基礎(chǔ)》2023-2024學(xué)年第一學(xué)期期末試卷
- 中學(xué)語(yǔ)文教學(xué)反思14
- 南京工業(yè)大學(xué)《儀器分析測(cè)試原理與應(yīng)用》2021-2022學(xué)年第一學(xué)期期末試卷
- 南京工業(yè)大學(xué)《思想政治教育原理專題研究》2022-2023學(xué)年第一學(xué)期期末試卷
- 南京工業(yè)大學(xué)《食品添加劑》2022-2023學(xué)年第一學(xué)期期末試卷
- 南京工業(yè)大學(xué)《嵌入式系統(tǒng)及應(yīng)用》2023-2024學(xué)年期末試卷
- 建筑工程各種材料臺(tái)賬樣表格模板
- 配餐學(xué)校供餐企業(yè)交接餐檢查記錄表
- 通風(fēng)隊(duì)崗位說明書XXXX117
- 初中體育與健康人教九年級(jí)(2023年修訂) 田徑初三跨欄教案
- DB13T 5216-2020 建設(shè)用地土壤污染風(fēng)險(xiǎn)篩選值
- 金壇區(qū)蘇科版六年級(jí)上冊(cè)勞動(dòng)《09T形路口信號(hào)燈》課件
- 車間注塑工藝表
- 公司電動(dòng)三輪車使用管理規(guī)定
- 新部編人教版六年級(jí)下冊(cè)道德與法治全冊(cè)精品教案(教學(xué)設(shè)計(jì))
- 《太陽(yáng)出來喜洋洋》 課件
- 《管理會(huì)計(jì)》課程標(biāo)準(zhǔn)
評(píng)論
0/150
提交評(píng)論