《Java程序設(shè)計案例教程》第11章 數(shù)據(jù)庫編程_第1頁
《Java程序設(shè)計案例教程》第11章 數(shù)據(jù)庫編程_第2頁
《Java程序設(shè)計案例教程》第11章 數(shù)據(jù)庫編程_第3頁
《Java程序設(shè)計案例教程》第11章 數(shù)據(jù)庫編程_第4頁
《Java程序設(shè)計案例教程》第11章 數(shù)據(jù)庫編程_第5頁
已閱讀5頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

程序設(shè)計第11章數(shù)據(jù)庫編程目錄2

11.1數(shù)據(jù)庫編程概述

11.2數(shù)據(jù)庫訪問流程

11.1數(shù)據(jù)庫編程概述JDBC(JavaDatabaseConnection)Java程序連接和存取數(shù)據(jù)庫的應(yīng)用程序接口(API)JDBC為Java數(shù)據(jù)庫開發(fā)人員提供了一個標(biāo)準的API以一致的方式連接多種不同的數(shù)據(jù)庫系統(tǒng)JDBC的功能建立與數(shù)據(jù)庫的連接。發(fā)送SQL語句到數(shù)據(jù)庫系統(tǒng)中執(zhí)行。返回SQL查詢語句的執(zhí)行結(jié)果。關(guān)閉與數(shù)據(jù)庫的連接。支持的數(shù)據(jù)庫系統(tǒng)所有關(guān)系型數(shù)據(jù)庫系統(tǒng)如商用的:Oracle,DB2,SQLServer`免費的:MySQL,PostgreSQL,HSQLDB,Derby3MySQLMySQL的優(yōu)點跨平臺可以在Windows或Linux等平臺下運行,這與Java語言的理念相吻合。性能高在較低配置的硬件上也能具有較高的性能。功能適中具有標(biāo)準的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)的功能,滿足Java應(yīng)用程序或JSP網(wǎng)站開發(fā)的需要。穩(wěn)定性好經(jīng)過大量用戶的檢驗,技術(shù)成熟,穩(wěn)定可靠。Java與MySQL的組合是業(yè)界最普遍的做法4安裝MySQL安裝MySQL服務(wù)器從網(wǎng)站上下載安裝時注意選擇多國語言時要用utf8。添加MySQL的安裝目錄到Path路徑中,應(yīng)該打上勾。設(shè)置系統(tǒng)管理員(root)用戶的密碼,建議在開發(fā)階段使用sa作為密碼。安裝MySQL的JDBC驅(qū)動程序從網(wǎng)站上下載“MySQLConnector/J”文件名為mysql-connector-java-8.0.29.jar5使用MySQL圖形界面需安裝MySQL-gui-tools,或第三方的phpMyAdmin、Navicat和MySQL-Front,選擇其中之一圖形界面的優(yōu)點界面直觀,使用方便字符界面優(yōu)點字符界面是內(nèi)置的,不需要另外安裝由于在真實的工作環(huán)境中,常常是遠程管理MySQL,這時需要通過字符界面來使用MySQLJava程序員應(yīng)該學(xué)會字符界面的使用6字符界面7mysql-uroot-p-u后的參數(shù)是用戶名-p表示提示輸入密碼輸入安裝時設(shè)置的密碼mysql>是提示符,在后面可以輸入命令及SQL語句常用命令usedb_name切換數(shù)據(jù)庫db_name。showdatabases列出所有數(shù)據(jù)庫的信息。showtables列出當(dāng)前數(shù)據(jù)庫的所有表的信息。showcolumnsfromtbl_name列出表tbl_name的各個列的信息。showindexfromtbl_name列出表tbl_name的索引信息(包括主鍵等)。quit退出MySQL控制臺。8SQL語句可以使用所有SQL語句createdatabase、createtable、select、insert、update和delete等輸入方式直接在字符界面窗口打字輸入先在記事本上編程,然后然后復(fù)制到字符界面窗口輸入的要求一行一條語句,在最后一定要加上分號“;”,表示SQL的結(jié)束語句太長一行寫不下時,可以分成多行,但只需在最后加分號特別注意:每條語句都必須要有分號“;”作為結(jié)束符注:SQL語言在其它課程中學(xué)習(xí)9數(shù)據(jù)的備份與恢復(fù)數(shù)據(jù)備份使用MySQLDump命令,直接在命令行下使用:命令的含義是將名為mydb的數(shù)據(jù)庫的內(nèi)容備份到backdb.sql文件中,包括數(shù)據(jù)庫中的表結(jié)構(gòu)和數(shù)據(jù)記錄。數(shù)據(jù)恢復(fù)使用MySQL命令,直接在命令行下使用:命令的含義是將備份文件backdb.sql中的數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)記錄恢復(fù)到名為mydb的數(shù)據(jù)庫中,前提條件是該數(shù)據(jù)庫已經(jīng)存在。如果數(shù)據(jù)庫不存在,則需要事先創(chuàng)建。創(chuàng)建數(shù)據(jù)庫的命令命令是在MySQL控制臺上發(fā)出的,而不是在命令行下發(fā)出的10C:\>mysqldump-uroot-pmydb>backdb.sqlC:\>mysql-uroot-pmydb<backdb.sqlmysql>createdatabasemydb11.2數(shù)據(jù)庫訪問流程數(shù)據(jù)準備創(chuàng)建數(shù)據(jù)庫,創(chuàng)建表,插入測試用數(shù)據(jù)等添加JDBC類庫將JDBC驅(qū)動程序添加到項目中加載JDBC驅(qū)動程序在程序中加載JDBC創(chuàng)建數(shù)據(jù)庫連接通過連接字符串建立與數(shù)據(jù)庫的連接執(zhí)行SQL語句執(zhí)行select或insert等語句接收并處理SQL的返回結(jié)果如果執(zhí)行的是select語句,則需要處理該語句返回的結(jié)果關(guān)閉創(chuàng)建的對象結(jié)束時一定要關(guān)閉數(shù)據(jù)庫連接11數(shù)據(jù)準備在需求分析和系統(tǒng)設(shè)計的基礎(chǔ)上進行創(chuàng)建數(shù)據(jù)庫創(chuàng)建表插入測試用數(shù)據(jù)12mysql>createdatabasetestdb;mysql>usetestdb;mysql>createtableuser(usrIDintprimarykeyauto_increment,accountvarchar(20),passwordvarchar(20),fullnamevarchar(20));mysql>insertintouser(account,password,fullname)values('huang','12345','HuangMing');添加JDBC類庫將JDBC驅(qū)動程序添加到項目將下載解壓縮出mysql-connector-java-8.0.29.jar文件再將該文件添加到項目中13加載JDBC驅(qū)動程序加載JDBC加載的方式很簡單每種JDBC的DriverName(全限定名)都是約定好的MySQLOracle14Class.forName("DriverName");Class.forName("com.mysql.cj.jdbc.Driver");Class.forName("oracle.jdbc.driver.OracleDriver");創(chuàng)建數(shù)據(jù)庫連接通過連接字符串建立與數(shù)據(jù)庫的連接使用DriverManager類的getConnection()靜態(tài)方法直接使用數(shù)據(jù)源名(用于ODBC數(shù)據(jù)源)

使用URL每種JDBC對連接字符串的規(guī)定不同MySQLOracle15Connectionconn=DriverManager.getConnection(jdbcURL,jdbcUser,jdbcPassword);Connectionconn=DriverManager.getConnection("jdbc:odbc:TestDB");Connectionconn;conn=DriverManager.getConnection("jdbc:mysql://:3306/TestDB","root","sa");Connectionconn;conn=DriverManager.getConnection("jdbc:oracle:thin:@:1521:TestDB","root","sa");執(zhí)行SQL語句不論對什么數(shù)據(jù)庫系統(tǒng),后續(xù)的操作都是一樣的,體現(xiàn)了JDBC與數(shù)據(jù)庫的解藕建立與數(shù)據(jù)庫的連接之后,執(zhí)行select或insert等語句無返回結(jié)果的SQL語句insert,delete,update,create等語句有返回結(jié)果的SQL語句(見下頁)select語句16//從數(shù)據(jù)庫連接中創(chuàng)建一個Statement的實例Statementstmt=conn.createStatement();//然后通過該實例執(zhí)行SQL語句(execute方法)stmt.execute("insertintouservalues(1,'zhangs','123','張三')");接收并處理SQL的返回結(jié)果如果執(zhí)行的是select語句,則需要處理該語句返回的結(jié)果ResultSet類的常用方法17//從數(shù)據(jù)庫連接中創(chuàng)建一個Statement的實例Statementstmt=conn.createStatement();//然后通過該實例執(zhí)行SQL語句(executeQuery方法)ResultSetrs=stmt.executeQuery("SELECT*FROMuser");//再通過列名訪問數(shù)據(jù)庫的內(nèi)容while(rset.next()){ System.out.println(rset.getInt("usrID")+","+rset.getString("account"));}關(guān)閉創(chuàng)建的對象結(jié)束時一定要關(guān)閉數(shù)據(jù)庫連接關(guān)閉語句應(yīng)該放在try結(jié)構(gòu)中的finally語句塊中形成一個嵌套的try結(jié)構(gòu)18

Connectionconn=null;//在try結(jié)構(gòu)前聲明

try{//加載JDBC、創(chuàng)建連接、執(zhí)行SQL語句、處理返回的結(jié)果等處理}catch(ClassNotFoundExceptione){//異常處理}catch(SQLExceptione){//異常處理}finally{if(conn!=null){

try{

溫馨提示

  • 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論