电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java 數據庫連接(JDBC)的相關總結

瀏覽:4日期:2022-08-15 10:32:59

Java 數據庫連接(Java DataBase Connectivity,縮寫JDBC)是官方(sun公司)定義的一套操作所有關系型數據庫的規則(即接口)。各個數據庫廠商去實現這套接口,提供數據庫驅動jar包。我們可以使用這套接口(JDBC)編程,真正執行的代碼是驅動jar包中的實現類。

一、JDBC API 概述

JDBC API主要位于JDK中的java.sql包中(之后擴展的內容位于javax.sql包中),主要包括(下面的接口,需驅動程序提供者來具體實現):

DriverManager:負責加載各種不同驅動程序(Driver),并根據不同的請求,向調用者返回相應的數據庫連接(Connection)。 Driver:驅動程序,會將自身加載到DriverManager中去,并處理相應的請求,返回相應的數據庫連接(Connection)。 Connection:與數據庫連接,負責與進行數據庫間通訊,SQL執行、事務處理都是在某個特定Connection環境中進行的。 Statement:用以執行SQL查詢和更新(針對靜態SQL語句和單次執行)。 PreparedStatement:用以執行包含動態參數的SQL查詢和更新(在服務器端編譯,允許重復執行以提高效率)。 CallableStatement:用以調用數據庫中的存儲過程。 SQLException:代表在數據庫連接的建立和關閉和SQL語句的執行過程中發生了例外情況(即錯誤)。 二、JDBC 和 數據庫建立連接的過程2.1、裝載驅動程序

Java 程序和數據庫建立連接,首先需要下載好對應數據庫的驅動程序包,并放置在程序的依賴庫中。程序將依賴庫中的驅動加載到程序中的方式非常簡單,使用Class.forName()即可。

假如需要導入的驅動包為 mysql-connector-java-5.1.37-bin.jar,則裝載驅動的方式:Class.forName('com.mysql.jdbc.Driver');在驅動程序的文檔中會告訴你應該使用的類名。在裝載驅動的過程中,會執行驅動程序中的部分代碼(靜態代碼塊);實現驅動與 DriverManager的綁定。

static { try { java.sql.DriverManager.registerDriver(new Driver()); } catch (SQLException E) { throw new RuntimeException('Can’t register driver!'); } }

注意:mysql5之后的驅動jar包可以省略注冊驅動(forName)的步驟。Jar包中內置包含處理了此過程。

2.2、獲取數據庫連接

下一步就是用適當的驅動程序類與 DBMS 建立一個連接。下列代碼是一般的做法:

Connection con = DriverManager.getConnection(url,user,password);

方法:static Connection getConnection(String url, String user, String password)說明:返回一個打開的連接,你可以使用此連接創建 JDBC statements 并發送 SQL 語句到數據庫。參數: * url:指定連接的路徑;如:jdbc:mysql://localhost:3306/db3 * user:用戶名 * password:密碼

如果你裝載的驅動程序識別了提供給 DriverManager.getConnection 的 JDBC URL ,那個驅動程序將根據 JDBC URL 建立一個到指定 DBMS 的連接。正如名稱所示,DriverManager 類在幕后為你管理建立連接的所有細節。除非你是正在寫驅動程序,你可能無需使用此類的其它任何方法,一般程序員需要在此類中直接使用的唯一方法是 DriverManager.getConnection。

2.2.1、Connection:數據庫連接對象介紹

Connection 對象與數據庫連接;負責與進行數據庫間通訊,SQL執行以及事務處理都是在某個特定Connection環境中進行的。

產生用以執行SQL指令的 Statement、PreparedStatement 對象。 事務管理中:setAutoCommit(boolean autoCommit)開啟事務、commit()提交事務、rollback()回滾事務。 2.3、創建 JDBC Statement 對象

Statement 是執行SQL 的對象;其用于把 SQL 語句發送到 DBMS。不同的SQL語句使用不同的 Statement 對象的方法,發送到 DBMS中。

Statement stmt = con.createStatement();2.4、執行SQL 語句 (Statement對象方法使用)

不同的 SQL 語句需要使用不同的 Statement 對象方法。

boolean execute(String sql):可以執行任意的sql(了解 )。 int executeUpdate(String sql):執行DML(insert、update、delete)語句、DDL(create,alter、drop)語句。 ResultSet executeQuery(String sql):執行DQL(select)語句

其中 executeUpdate() 方法的返回值為影響的行數;可以通過這個影響的行數判斷DML語句是否執行成功 ;返回值>0的則執行成功,反之,則失敗。

執行DML語句

String sql = 'insert into account values(null,’王五’,3000)';int count = stmt.executeUpdate(sql);//影響的行數

執行DQL語句

ResultSet rs = stmt.executeQuery('SELECT user_name, age FROM student');//如果有數據,rs.next()返回truewhile(rs.next()){System.out.println(rs.getString('user_name')+' 年齡:'+rs.getInt('age'));}2.4.1、ResultSet 結果集對象,封裝查詢結果

java.sql.ResultSet 接口表示一個數據庫查詢的結果集;一個ResultSet對象具有一個游標指向當前行的結果集。最初,光標被置于第一行之前;調用 next() 方法將光標移動到下一行;當 ResultSet 對象沒有下一行時,next() 方法返回 false。

一般使用方法:

while(rs.next()){ //獲取數據 int id = rs.getInt(1); String name = rs.getString('name'); double balance = rs.getDouble(3); System.out.println(id + '---' + name + '---' + balance);}

getXxx(參數):獲取數據 * Xxx:代表數據類型如:int getInt(),String getString() ... * 參數: 1. int:代表列的編號,從1開始 如: getString(1) 2. String:代表列名稱。 如: getDouble('balance')

2.5、釋放資源

SQL 語句執行完成后,需要是否創建的資源對象。包括連接對象、Statement對象和ResultSet 對象等。

以上就是Java 數據庫連接(JDBC)的相關總結的詳細內容,更多關于Java 數據庫連接(JDBC)的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 东莞办公家具厂家直销-美鑫【免费3D效果图】全国办公桌/会议桌定制 | 济南电缆桥架|山东桥架-济南航丰实业有限公司 | 济南菜鸟驿站广告|青岛快递车车体|社区媒体-抖音|墙体广告-山东揽胜广告传媒有限公司 | 控显科技 - 工控一体机、工业显示器、工业平板电脑源头厂家 | LED投光灯-工矿灯-led路灯头-工业灯具 - 山东普瑞斯照明科技有限公司 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 浙江华锤电器有限公司_地磅称重设备_防作弊地磅_浙江地磅售后维修_无人值守扫码过磅系统_浙江源头地磅厂家_浙江工厂直营地磅 | 千淘酒店差旅平台-中国第一家针对TMC行业的酒店资源供应平台 | 广州昊至泉水上乐园设备有限公司 | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | 洁净化验室净化工程_成都实验室装修设计施工_四川华锐净化公司 | 顶空进样器-吹扫捕集仪-热脱附仪-二次热解吸仪-北京华盛谱信仪器 | 全自动包装秤_全自动上袋机_全自动套袋机_高位码垛机_全自动包装码垛系统生产线-三维汉界机器(山东)股份有限公司 | 板框压滤机-隔膜压滤机-厢式压滤机生产厂家-禹州市君工机械设备有限公司 | 厚壁钢管-厚壁无缝钢管-小口径厚壁钢管-大口径厚壁钢管 - 聊城宽达钢管有限公司 | 耐热钢-耐磨钢-山东聚金合金钢铸造有限公司 | 全自动端子机|刺破式端子压接机|全自动双头沾锡机|全自动插胶壳端子机-东莞市傅氏兄弟机械设备有限公司 | 成都顶呱呱信息技术有限公司-贷款_个人贷款_银行贷款在线申请 - 成都贷款公司 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 武汉高低温试验箱_恒温恒湿试验箱厂家-武汉蓝锐环境科技有限公司 | 济南宣传册设计-画册设计_济南莫都品牌设计公司 | 桨叶搅拌机_螺旋挤压/方盒旋切造粒机厂家-无锡市鸿诚输送机械有限公司 | 河南卓美创业科技有限公司-河南卓美防雷公司-防雷接地-防雷工程-重庆避雷针-避雷器-防雷检测-避雷带-避雷针-避雷塔、机房防雷、古建筑防雷等-山西防雷公司 | 蒜肠网-动漫,二次元,COSPLAY,漫展以及收藏型模型,手办,玩具的新媒体.(原变形金刚变迷TF圈) | 耐火浇注料-喷涂料-浇注料生产厂家_郑州市元领耐火材料有限公司 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 防水套管-柔性防水套管-刚性防水套管-上海执品管件有限公司 | 非标压力容器_碳钢储罐_不锈钢_搪玻璃反应釜厂家-山东首丰智能环保装备有限公司 | 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | 干式磁选机_湿式磁选机_粉体除铁器-潍坊国铭矿山设备有限公司 | 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | Eiafans.com_环评爱好者 环评网|环评论坛|环评报告公示网|竣工环保验收公示网|环保验收报告公示网|环保自主验收公示|环评公示网|环保公示网|注册环评工程师|环境影响评价|环评师|规划环评|环评报告|环评考试网|环评论坛 - Powered by Discuz! | 仿古建筑设计-仿古建筑施工-仿古建筑公司-汉匠古建筑设计院 | 优考试_免费在线考试系统_培训考试系统_题库系统_组卷答题系统_匡优考试 | 手术室净化厂家-成都做医院净化工程的公司-四川华锐-15年特殊科室建设经验 | 炉门刀边腹板,焦化设备配件,焦化焦炉设备_沧州瑞创机械制造有限公司 | 2-羟基泽兰内酯-乙酰蒲公英萜醇-甘草查尔酮A-上海纯优生物科技有限公司 | 播音主持培训-中影人教育播音主持学苑「官网」-中国艺考界的贵族学校 | 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 | 紫外可见光分光度计-紫外分光度计-分光光度仪-屹谱仪器制造(上海)有限公司 | arch电源_SINPRO_开关电源_模块电源_医疗电源-东佑源 | 电销卡 防封电销卡 不封号电销卡 电话销售卡 白名单电销卡 电销系统 外呼系统 |