數據庫---JDBC

1.1 JDBC概述
JDBC(Java DataBase Connectivity,java數據庫連接)是一種用于執行SQL語句的Java API。JDBC是Java訪問數據庫的標準規范,可以為不同的關系型數據庫提供統一訪問,它由一組用Java語言編寫的接口和類組成。
JDBC需要連接驅動,驅動是兩個設備要進行通信,滿足一定通信數據格式,數據格式由設備提供商規定,設備提供商為設備提供驅動軟件,通過軟件可以與該設備進行通信。
此時我們使用的是mysql的驅動(mysql-connector-java-5.1.37-bin.jar)
JDBC與數據庫驅動的關系:接口與實現的關系。
?
JDBC規范(掌握四個核心對象):
DriverManager:用于注冊驅動
Connection: 表示與數據庫創建的連接
Statement: 操作數據庫sql語句的對象
ResultSet: 結果集或一張虛擬表
2、案例實現
? ? ? ? 2.1準備數據-->數據庫
create database day04;
create table category(
cid int PRIMARY KEYAUTO_INCREMENT ?,
? cname varchar(100)
);
insert into category (cname) values('家電');
insert into category (cname) values('服飾');
insert into category (cname) values('化妝品');
? ? ?2.2導入驅動jar包
創建一個java項目Demo,復制mysql-connector-java-5.1.37-bin.jar到該項目中,選中jar包右鍵Build path-->Add Build Path就好了
? ? 2.3具體代碼實現-->查詢數據
public class Demo {
public static void main(String[] args) throws Exception {
JDBCPool();
}
public static void JDBCPool() throws Exception{
//1注冊驅動
Class.forName( "com.mysql.jdbc.Driver");
//2獲取連接
String url="jdbc:mysql://localhost:3306/day04";
// jdbc: mysql:// localhost: 3306/ day04
? ? ? ? ? ? ? ? // 協議: 子協議:// ? ?? IP? ? ?: 端口號/ 數據庫
Connection conn=DriverManager.getConnection(url," root"," root");//數據庫的 賬號密碼
//3獲得執行SQL語句
Statement stmt=conn.createStatement();
//執行SQL語句

ResultSet rs=stmt.executeQuery("select * from category");????????????????????????????????????????????????????????????????????????? ?????????????????//僅有查詢使用executeQuery(),增刪改使用executeUpdate()

//處理結果集
while(rs.next()){
//獲得每一行數據
Integer cid=rs.getInt("CID");
String cname=rs.getString("CNAME");
System.out.println(cid+":"+cname);
}
// 與IO流一樣,使用后的東西都需要關閉!關閉的順序是先得到的后關閉,后得到的先關閉。
rs.close();
stmt.close();
conn.close();

}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/273741.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/273741.shtml
英文地址,請注明出處:http://en.pswp.cn/news/273741.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

23種設計模式之簡單工廠

簡單工廠模式描述的是,通過類的繼承關系,父類(工廠類)與子類(產品類),調用父類中的方法,實際干活兒的是子類中的方法;封裝需求的不確定性,做出通用的編程&…

原生JDBC操作數據庫流程

1、class.forName()加載數據驅動 2、DriverManager.getConnection()獲取數據庫連接對象。 3、根據SQL或sql會話對象,有兩種方式Statement、PreparedStatement。 4、執行sql處理結果集,如果有參數就設置參數。 5、關閉結果集,關閉會話&#xf…

verilog HDL 編碼風格

1、有意義且有效的名字。 2、同一信號在不同層次應該保持一致。 3、添加有意義的后綴,使信號的有效性更加明確。 4、模塊輸出寄存器化,使得輸出的驅動強度和輸入延時是可以預測的。 5、使用括號表明優先級。 6、每一個if都應該有一個else。如果esle沒有任…

為什么要使用PreparedStatement

(個人理解:執行速度,使用方便,代碼的可讀性維護性,提高性能,安全性 五個方面考慮) 1、PreparedStatement接口繼承Statement,PreparedStatement實例包含了預編譯的SQL語句,所以PreparedStatement…

session中存放一個對象,只修改對象的屬性,不將修改后的對象存放session,發現session中存放的對象也發生改變!

標題簡單描述:先將一個對象放入session,只對對象屬性值進行修改,但不將修改后的對象存放session中,發現session中存放的對象屬性值也相對應的改變。Person personnew PerSon(); request.getSession().setAttribute("person&q…

利用三層交換機實現VLAN間路由配置

利用三層交換機實現VLAN間路由配置 實驗目標: 一、 掌握交換機Tag VLAN的配置; 二、掌握三層交換機基本配置方法; 三、 掌握三層交換機的VLAN路由的配置方法; 四、通過三層交換機實現VLAN見相互通信; 技術原理&#xf…

Maven,在pom.xml配置JDK 9版本。

<build><plugins><!-- 設置JDK 9版本 --><plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> …

【leetcode】Path Sum II

Given a binary tree and a sum, find all root-to-leaf paths where each paths sum equals the given sum. For example:Given the below binary tree and sum 22, 5/ \4 8/ / \11 13 4/ \ / \7 2 5 1 return [[5,4,11,2],[5,8,4,5] ] 下午做了個筆試沒睡覺…

easyui、表格中添加操作一列,將操作下設置為修改,點擊修改彈出該行對象的編號。

頁面中的代碼(自己引入easy插件)&#xff1a; <body> <div id"table"></div> </body> <script type"text/javascript"> $(function(){$(#table).datagrid({ url:tt.json, //顯示的數據striped:true, …

被LTRIM(RTRIM())害死了,差點

LTRIM(character_expression)去掉前置空格 LTRIM(RTRIM())就是把前置和后置空格都去掉。 character_expression可以是常量、變量或列。character_expression必須屬于某個可隱式轉換為varchar的數據類型(text、ntext和image除外)。否則&#xff0c;請使用CAST顯示轉換character_…

Mybatis、使用注解的方式編寫用戶和角色一對多關系,并使用延遲加載

1、數據庫準備 CREATE TABLE role ( ID INT(11) NOT NULL COMMENT 編號,ROLE_NAME VARCHAR(30) DEFAULT NULL COMMENT 角色名稱,ROLE_DESC VARCHAR(60) DEFAULT NULL COMMENT 角色描述,PRIMARY KEY (ID) ) ENGINEINNODB DEFAULT CHARSETutf8;INSERT INTO role(ID,ROLE_NAME,…

織夢標簽大全

關鍵描述調用標簽&#xff1a; <meta name"keywords" content"{dede:field namekeywords/}"> <meta name"description" content"{dede:field namedescription functionhtml2text(me)/}"> -------------------------------…

spring的注入

1、構造函數注入的是設計到的標簽&#xff1a;constructor-arg屬性&#xff1a;index:指定參數在構造函數參數列表的索引位置type:指定參數在構造函數中的數據類型name:指定參數在構造函數中的名稱上面三個都是找誰 &#xff0c;給誰賦值&#xff0c;下面兩個指的是賦什么值 va…

.Net中堆棧和堆的區別

首先堆棧和堆&#xff08;托管堆&#xff09;都在進程的虛擬內存中。&#xff08;在32位處理器上每個進程的虛擬內存為4GB&#xff09; 堆棧stack 1、堆棧中存儲值類型 2、堆棧實際上是向下填充&#xff0c;即由高內存地址指向低內存地址填充 3、堆棧的工作方式是先分配內存的變…

spring的IOC注解

1、創建對象的注解 含義&#xff1a;使用注解的形式創建對象&#xff0c;交給Spring容器管理(需要配置在類上) Component:組件 Controller:web層 Service:service層 Repository:Dao層默認&#xff1a;創建對象的唯一標識&#xff0c;當前類名首字母小寫value屬性&#xff1a;指…

PowerDesigner 逆向工程 從SQL文件轉換成PDM 從PDM轉成CDM

從SQL文件逆向工程到PDM&#xff1a; ①選擇file -> Reverse Engineer - > Database ②在General選項卡中選擇MySQL數據庫&#xff0c;點擊確定。 ③using script file 選擇你的sql文件&#xff0c;最后選擇確定。 從PDM轉成CDM&#xff1a; ①選擇工具 -> General CD…

SpringMvc的執行過程

Tomcat啟動 1、部署項目到Tomcat中 2、啟動Tomcat加載Web.xml 3、初始化DispatcherServlet(執行的是init方法) 4、加載配置文件&#xff0c;創建對象交給Spring容器管理 5、通過處理器映射器解析RequestMappin配置&#xff0c;配置‘請求地址’和‘控制器類’的映射關系 小結&a…

自然語言理解——introduction

1.基本概念&#xff1a; NLP&#xff1a;自然語言處理是研究如何利用計算機技術對語言文本&#xff08;句子、篇章或話語等&#xff09;進行處理和加工的一門學科&#xff0c;研究內容包括對詞法、句法、語義和語用等信息的識別、分類、提取、轉換和生成等各種處理方法和實現技…

Eclipse中彈出OLE Exception窗口

樓主事故原因&#xff1a;首先打開一個類&#xff0c;然后因為手速太快&#xff0c;在該類的編輯窗口中右鍵&#xff0c;單擊&#xff0c;不要問我點了啥&#xff0c;我也不知。后面發現該類的編輯器沒有顯示任何內容&#xff0c;但是可以發現代碼依然存在只是沒有顯示。 關閉…

HDOJ-3790-最短路徑問題 解題報告

一道最短路問題。普通最短路問題的邊只有一種權值&#xff0c;而此題的邊要考慮兩種權值。因為節點n<1000&#xff0c;所以不能夠使用Floyd算法&#xff0c;時間復雜度較高&#xff0c;這里使用Dijkstra算法解決。 中文描述&#xff0c;題意不再贅述。只是要注意每條邊都有距…