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

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

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

瀏覽:2日期: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
相關文章:
主站蜘蛛池模板: 体坛网_体坛+_体坛周报新闻客户端 | 杭州实验室尾气处理_实验台_实验室家具_杭州秋叶实验设备有限公司 | 即用型透析袋,透析袋夹子,药敏纸片,L型涂布棒-上海桥星贸易有限公司 | 碳纤维复合材料制品生产定制工厂订制厂家-凯夫拉凯芙拉碳纤维手机壳套-碳纤维雪茄盒外壳套-深圳市润大世纪新材料科技有限公司 | 成都思迪机电技术研究所-四川成都思迪编码器 | 免费B2B信息推广发布平台 - 推发网 | 安徽控制器-合肥船用空调控制器-合肥家电控制器-合肥迅驰电子厂 安徽净化板_合肥岩棉板厂家_玻镁板厂家_安徽科艺美洁净科技有限公司 | 超声波焊接机,振动摩擦焊接机,激光塑料焊接机,超声波焊接模具工装-德召尼克(常州)焊接科技有限公司 | 扒渣机,铁水扒渣机,钢水扒渣机,铁水捞渣机,钢水捞渣机-烟台盛利达工程技术有限公司 | 杭州画室_十大画室_白墙画室_杭州美术培训_国美附中培训_附中考前培训_升学率高的画室_美术中考集训美术高考集训基地 | 耐高温电缆厂家-远洋高温电缆| 浙江富广阀门有限公司| lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 南京租车,南京汽车租赁,南京包车,南京会议租车-南京七熹租车 | 振动时效_振动时效仪_超声波冲击设备-济南驰奥机电设备有限公司 北京宣传片拍摄_产品宣传片拍摄_宣传片制作公司-现像传媒 | 液压压力机,液压折弯机,液压剪板机,模锻液压机-鲁南新力机床有限公司 | 锂辉石检测仪器,水泥成分快速分析仪-湘潭宇科分析仪器有限公司 | 北京开源多邦科技发展有限公司官网| 工业胀紧套_万向节联轴器_链条-规格齐全-型号选购-非标订做-厂家批发价格-上海乙谛精密机械有限公司 | 上海刑事律师|刑事辩护律师|专业刑事犯罪辩护律师免费咨询-[尤辰荣]金牌上海刑事律师团队 | PCB厂|线路板厂|深圳线路板厂|软硬结合板厂|电路板生产厂家|线路板|深圳电路板厂家|铝基板厂家|深联电路-专业生产PCB研发制造 | 工业rfid读写器_RFID工业读写器_工业rfid设备厂商-ANDEAWELL | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | ICP备案查询_APP备案查询_小程序备案查询 - 备案巴巴 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | 东莞精密模具加工,精密连接器模具零件,自動機零件,冶工具加工-益久精密 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛婚外情取证-青岛王军侦探事务所 | 除湿机|工业除湿机|抽湿器|大型地下室车间仓库吊顶防爆除湿机|抽湿烘干房|新风除湿机|调温/降温除湿机|恒温恒湿机|加湿机-杭州川田电器有限公司 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 双舌接地线-PC68数字式高阻计-ZC36|苏海百科 | 金属软管_不锈钢金属软管_巩义市润达管道设备制造有限公司 | 冷凝锅炉_燃气锅炉_工业燃气锅炉改造厂家-北京科诺锅炉 | 飞飞影视_热门电影在线观看_影视大全 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 黄石妇科医院_黄石东方女子医院_黄石东方妇产医院怎么样 | 一体化污水处理设备-一体化净水设备-「山东梦之洁水处理」 | 机床主轴维修|刀塔维修|C轴维修-常州翔高精密机械有限公司 | 并网柜,汇流箱,电控设备,中高低压开关柜,电气电力成套设备,PLC控制设备订制厂家,江苏昌伟业新能源科技有限公司 | 硅胶制品-硅橡胶制品-东莞硅胶制品厂家-广东帝博科技有限公司 | 新型锤式破碎机_新型圆锥式_新型颚式破碎机_反击式打沙机_锤式制砂机_青州建源机械 |