




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第23章java 數(shù)據(jù)庫(kù)編程o 數(shù)據(jù)庫(kù)連接的基本概念o 使用數(shù)據(jù)庫(kù)的準(zhǔn)備工作o 連接數(shù)據(jù)庫(kù)的步驟o 數(shù)據(jù)庫(kù)連接的詳細(xì)步驟o 數(shù)據(jù)維護(hù)o 查詢(xún)數(shù)據(jù)庫(kù)中的內(nèi)容o 查詢(xún)信息實(shí)例o 與數(shù)據(jù)庫(kù)相關(guān)的接口o 批處理o 事務(wù)處理o mysql數(shù)據(jù)庫(kù)23.1 數(shù)據(jù)庫(kù)連接的基本概念 jdbc(java database connective),java數(shù)據(jù)庫(kù)連接,是一組專(zhuān)門(mén)負(fù)責(zé)連接并操作數(shù)據(jù)庫(kù)的標(biāo)準(zhǔn) jdbc能完成許多事情 完成數(shù)據(jù)庫(kù)的連接創(chuàng)建 傳送sql命令給數(shù)據(jù)庫(kù),完成數(shù)據(jù)庫(kù)操作及數(shù)據(jù)表 接受和處理數(shù)據(jù)庫(kù)所執(zhí)行的結(jié)果23.1 數(shù)據(jù)庫(kù)連接的基本概念 jdbc在使用中有常見(jiàn)的以下三類(lèi) 1. jdbc-odbc橋
2、連接(jdbd-odbc bridge) 2. jdbc連接 3. jdbc網(wǎng)絡(luò)連接23.2 使用數(shù)據(jù)庫(kù)的準(zhǔn)備工作23.2.1 oracle數(shù)據(jù)庫(kù)的安裝23.2.2 數(shù)據(jù)庫(kù)連接驅(qū)動(dòng)程序設(shè)置23.2.3 數(shù)據(jù)庫(kù)表的準(zhǔn)備23.2.1 oracle數(shù)據(jù)庫(kù)的安裝 oracle的安裝方法 打開(kāi)oracle安裝目錄下的安裝文件夾,雙擊“setup.exe”文件 進(jìn)行安裝的源和目標(biāo)文件地點(diǎn)設(shè)置 單擊【標(biāo)準(zhǔn)版】,然后單擊【下一步】按鈕 在接下來(lái)的頁(yè)面中選擇相應(yīng)設(shè)置,并繼續(xù)安裝23.2.2 數(shù)據(jù)庫(kù)連接驅(qū)動(dòng)程序設(shè)置 oracle提供java環(huán)境下的數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序 驅(qū)動(dòng)程序路徑:e:oracleproduct10.
3、1.0db_1jdbclibclasses12.jar 如果是直接使用命令行方式進(jìn)行開(kāi)發(fā)的話,則需要在屬性中增加classpath 23.2.3 數(shù)據(jù)庫(kù)表的準(zhǔn)備 數(shù)據(jù)表類(lèi)型結(jié)構(gòu)如下表no.列名稱(chēng)類(lèi)型描述1pidnumber表 示 人 員 編 號(hào) , 自 動(dòng) 增 長(zhǎng) , 通 過(guò)sequence2namevarchar2姓名3agenumber年齡4birthdaydate生日5salarynumber工資,小數(shù)23.2.3 數(shù)據(jù)庫(kù)表的準(zhǔn)備 在eclipse中新建一個(gè)名稱(chēng)為jdbcproject1.0的包,接下來(lái)完成編寫(xiě)數(shù)據(jù)庫(kù)的創(chuàng)建腳本 1. 新建名稱(chēng)為“數(shù)據(jù)庫(kù)創(chuàng)建腳本.sql”的文件 2. 用s
4、ql語(yǔ)言新建一個(gè)類(lèi)型為上表類(lèi)型所示的數(shù)據(jù)庫(kù)表,具體語(yǔ)言?xún)?nèi)容見(jiàn)【范例23-1】 3. 打開(kāi)oracle數(shù)據(jù)庫(kù)的監(jiān)聽(tīng)服務(wù)和項(xiàng)目服務(wù)“oraclejobschedulerorcl“23.2.3 數(shù)據(jù)庫(kù)表的準(zhǔn)備 4. 點(diǎn)擊【開(kāi)始】按鈕,選擇【運(yùn)行】命令,在【打開(kāi)】文本框中輸入“sqlplus”,單擊【確定】按鈕 5. 輸入用戶(hù)名和剛安裝oracle時(shí)設(shè)置的用戶(hù)密碼,進(jìn)入到數(shù)據(jù)庫(kù)管理后臺(tái) 6. 然后將剛才創(chuàng)建的文件指令輸入到控制臺(tái)中,此時(shí),便創(chuàng)建了一個(gè)新的名稱(chēng)為person的數(shù)據(jù)表 【范例23-1】 建立新序列和新表23.3 連接數(shù)據(jù)庫(kù)的步驟 進(jìn)行jdbc操作的時(shí)候,主要按照以下的步驟完成 1. 加載數(shù)
5、據(jù)庫(kù)驅(qū)動(dòng)程序,加載的時(shí)候需要將驅(qū)動(dòng)程序配置到classpath之中 2. 連接數(shù)據(jù)庫(kù),通過(guò)connection接口和drivermanager類(lèi)完成 3. 操作數(shù)據(jù)庫(kù),主要通過(guò)statement、preparedstatement、resultset三個(gè)接口完成 4. 關(guān)閉數(shù)據(jù)庫(kù) 23.4 數(shù)據(jù)庫(kù)連接的詳細(xì)步驟 在jdbc的操作過(guò)程中中,進(jìn)行數(shù)據(jù)庫(kù)的連接的主要幾個(gè)步驟如下 1. 通過(guò)class.forname()加載數(shù)據(jù)庫(kù)的驅(qū)動(dòng)程序 2. 通過(guò)drivermanager類(lèi)進(jìn)行數(shù)據(jù)庫(kù)的連接 3. 通過(guò)connection接口接收連接 4. 此時(shí)輸出的是一個(gè)對(duì)象,則表示數(shù)據(jù)庫(kù)已經(jīng)連接上了 【范例2
6、3-2】 通過(guò)java指令進(jìn)行實(shí)際數(shù)據(jù)庫(kù)連接過(guò)程。本例是在用戶(hù)建立過(guò)oracle數(shù)據(jù)表之后,通過(guò)java程序進(jìn)行數(shù)據(jù)庫(kù)連接的操作 23.5 數(shù)據(jù)維護(hù)23.5.1 增加數(shù)據(jù)23.5.2 更新數(shù)據(jù)23.5.3 刪除數(shù)據(jù)23.5.1 增加數(shù)據(jù) 增加操作要編寫(xiě)增加的sql語(yǔ)句:insert,但是因?yàn)闋砍兜搅诵蛄械母拍?,所以在使用的時(shí)候需要編寫(xiě)sql語(yǔ)句進(jìn)行增加操作,所以在sql語(yǔ)句中直接寫(xiě)上序列的nextval即可。形式為:序列名.nextval 【范例23-3】 為數(shù)據(jù)表增加數(shù)據(jù)。這里使用statement接口為數(shù)據(jù)庫(kù)中新建立的表進(jìn)行增加數(shù)據(jù)操作23.5.2 更新數(shù)據(jù) 數(shù)據(jù)庫(kù)的更新操作同增加數(shù)據(jù)操作
7、相同,直接編寫(xiě)update語(yǔ)句即可 【范例23-4】 更新數(shù)據(jù)。在其后增加更新數(shù)據(jù)的sql語(yǔ)句23.5.3 刪除數(shù)據(jù) 數(shù)據(jù)的增加,更新,刪除等都是通過(guò)sql語(yǔ)句完成,所以在修改數(shù)據(jù)的時(shí)候,只需要更改該程序下的sql語(yǔ)句即可實(shí)現(xiàn)目的。使用delete語(yǔ)句執(zhí)行刪除數(shù)據(jù)的操作【范例23-5】 刪除數(shù)據(jù)庫(kù)中的數(shù)據(jù)信息。通過(guò)修改sql語(yǔ)句進(jìn)行刪除數(shù)據(jù)命令。代碼的整體流程同上次范例相似,不同的為sql語(yǔ)句。由于數(shù)據(jù)庫(kù)操作有自己獨(dú)特的一種語(yǔ)言,所以當(dāng)控制數(shù)據(jù)庫(kù)操作時(shí)需要sql語(yǔ)言才能達(dá)成目的23.6 查詢(xún)數(shù)據(jù)庫(kù)中的內(nèi)容 在oracle中,可以通過(guò)select語(yǔ)句,查詢(xún)數(shù)據(jù)庫(kù)中的內(nèi)容 【范例23-6】 通過(guò)s
8、tatement類(lèi)進(jìn)行數(shù)據(jù)庫(kù)查詢(xún)操作 【范例23-7】 用索引號(hào)進(jìn)行數(shù)據(jù)查詢(xún) 23.7 查詢(xún)數(shù)據(jù)實(shí)例 【范例23-8】 通過(guò)實(shí)例化程序了解控制臺(tái)輸入數(shù)據(jù)。接下來(lái)進(jìn)行的是當(dāng)用戶(hù)自己輸入數(shù)據(jù)時(shí),需要如何將輸入的數(shù)據(jù)保存到數(shù)據(jù)庫(kù)當(dāng)中 【范例23-9】 從控制臺(tái)輸入特殊內(nèi)容。用戶(hù)在用戶(hù)名一項(xiàng)中輸入特殊內(nèi)容,比如為英文名稱(chēng),添加了單引號(hào) 23.8 與數(shù)據(jù)庫(kù)相關(guān)的接口23.8.1 完成增加操作23.8.2 完成查詢(xún)操作23.8.3 完成模糊查詢(xún)操作23.8.1 完成增加操作 【范例23-10】 運(yùn)用preparedstatement接口代替statement接口進(jìn)行增加內(nèi)容操作23.8.2 完成查詢(xún)操作
9、【范例23-11】 運(yùn)用preparedstatement接口完成查詢(xún)操作。運(yùn)用preparedstatement接口做查詢(xún)操作要比用statement接口直接做查詢(xún)操作更有準(zhǔn)確性和可塑性23.8.3 完成模糊查詢(xún)操作 【范例23-12】 運(yùn)用preparedstatement類(lèi)中的方法進(jìn)行模糊操作。所謂模糊,就是指有一定相似程度的值的查詢(xún)。如同搜索關(guān)鍵字進(jìn)行具有關(guān)鍵字信息的查詢(xún)類(lèi)似23.9 批處理 批處理(batch),也稱(chēng)為批處理腳本。顧名思義,批處理就是對(duì)某對(duì)象進(jìn)行批量的處理 【范例23-13】 一次性輸入數(shù)據(jù)庫(kù)多條語(yǔ)句。在jdbc2.0之后,java提出的新概念,表示一次性可以處理多條
10、數(shù)據(jù)庫(kù)信息內(nèi)容,以方便增加數(shù)據(jù)操作 23.10 事務(wù)處理 oracle數(shù)據(jù)庫(kù)支持事務(wù)處理,可以通過(guò)commit提交事務(wù),通過(guò)rollback回滾事務(wù)。這兩種方式是進(jìn)行事務(wù)處理的首要手段 【范例23-14】 通過(guò)commit()方法提交事務(wù) 23.11 mysql數(shù)據(jù)庫(kù)23.11.1 mysql數(shù)據(jù)庫(kù)的安裝23.11.2 mysql數(shù)據(jù)庫(kù)的基本命令23.11.3 使用mysql數(shù)據(jù)庫(kù)23.11.1 mysql數(shù)據(jù)庫(kù)的安裝 mysql安裝的過(guò)程非常簡(jiǎn)單,但是需要進(jìn)行合理的配置 mysql數(shù)據(jù)庫(kù)的默認(rèn)端口號(hào)是3306 選擇數(shù)據(jù)庫(kù)的編碼為gbk,否則程序在讀取的時(shí)候?qū)⒊霈F(xiàn)亂碼問(wèn)題23.11.2 mys
11、ql數(shù)據(jù)庫(kù)的基本命令 1. 連接數(shù)據(jù)庫(kù):mysql -u用戶(hù)名 -p密碼 2. 查看全部的數(shù)據(jù)庫(kù):show databases ; 3. 創(chuàng)建數(shù)據(jù)庫(kù):create database orcl ; 4. 使用數(shù)據(jù)庫(kù):use orcl ; 5. 查看全部的表:show tables ;23.11.2 mysql數(shù)據(jù)庫(kù)的基本命令 6. 創(chuàng)建一張表,其中id可以自動(dòng)增長(zhǎng) drop table person ; - 刪除表 create table person( pid int auto_increment primary key not null , name varchar(50) not null , age int not null , birthday date not null , salary float not null )
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二年級(jí)下冊(cè)數(shù)學(xué)教案 - 第三單元 第一節(jié)【第一課時(shí)】 數(shù)一數(shù)(一)(認(rèn)識(shí)并感受“千”1)北師大版
- 2025年師范大學(xué)協(xié)議管理辦法
- 勞動(dòng)協(xié)議:勞務(wù)分包協(xié)議(2025年版)
- 2024年水利機(jī)械項(xiàng)目資金需求報(bào)告代可行性研究報(bào)告
- 2024年高性能陶瓷刀具材料項(xiàng)目資金需求報(bào)告代可行性研究報(bào)告
- 全國(guó)清華版信息技術(shù)小學(xué)三年級(jí)上冊(cè)新授課 第11課 智能輸詞句-詞組和整句輸入 教學(xué)設(shè)計(jì)
- 2025年度手房交易資金監(jiān)管補(bǔ)充協(xié)議
- 2025年度大米產(chǎn)業(yè)投資基金簡(jiǎn)易合作協(xié)議
- 2025年度商標(biāo)同授權(quán)及品牌授權(quán)許可合同
- 二零二五年度網(wǎng)紅直播帶貨營(yíng)銷(xiāo)推廣服務(wù)合同
- 【寒假開(kāi)學(xué)第一課】AI時(shí)代做自己的哪吒
- 2025年度光伏電站光伏組件回收處理合同示范文本
- 2025年春季少先隊(duì)工作計(jì)劃及安排表(附:少先隊(duì)每月工作安排表)
- 中央2025年公安部部分直屬事業(yè)單位招聘84人筆試歷年參考題庫(kù)附帶答案詳解
- CWAN 0043-2021攪拌摩擦焊攪拌頭設(shè)計(jì)及制造標(biāo)準(zhǔn)
- 教學(xué)課件:《公共關(guān)系學(xué)》(本科)
- 劉聰版在燦爛陽(yáng)光下鋼琴伴奏譜簡(jiǎn)譜版
- 《教育強(qiáng)國(guó)建設(shè)規(guī)劃綱要(2024-2035年)》全文
- 2025年春新人教PEP版英語(yǔ)三年級(jí)下冊(cè)全冊(cè)教學(xué)課件
- 體育老師籃球說(shuō)課
- 化學(xué)-江蘇省蘇州市2024-2025學(xué)年2025屆高三第一學(xué)期學(xué)業(yè)期末質(zhì)量陽(yáng)光指標(biāo)調(diào)研卷試題和答案
評(píng)論
0/150
提交評(píng)論