JDBC數據對象存儲

一:將查詢的結果生成對象,儲存在數組中。

 1 package day31;
 2 
 3 import java.sql.Connection;
 4 import java.sql.PreparedStatement;
 5 import java.sql.ResultSet;
 6 import java.sql.SQLException;
 7 import java.util.ArrayList;
 8 
 9 public class java_obj {
10     public  static void main(String[] args)throws SQLException{
11         Connection  con=jdbcutils.getCon();
12         PreparedStatement pst=con.prepareStatement("select * from system_user");
13         ResultSet res=pst.executeQuery();
14         /*
15         將查詢的結果用泛型數組儲存。
16          */
17         ArrayList<System_user> sys_list=new ArrayList<>();
18         while (res.next()){
19             System_user sys_u=new System_user(res.getString("username"),res.getString("password"));
20             sys_list.add(sys_u);
21         }
22         System.out.print(sys_list);
23         jdbcutils.cls_re(con,pst,res);
24     }
25 }
26 
27 
28 class System_user{
29     private  String user;
30     private  String pwd;
31     public  System_user(String user, String pwd){
32         this.user=user;
33         this.pwd=pwd;
34     }
35 
36     @Override
37     public String toString() {
38         return  this.user+" "+this.pwd;
39     }
40 }

?工具類:

 1 package day31;
 2 
 3 import java.sql.*;
 4 
 5 public class jdbcutils {
 6     /*
 7     創建jdbc工具類。
 8     1:方便別人調用
 9     2:避免代碼重復。
10      */
11     private jdbcutils(){}//工具類不需要實例化,所以方法進行私有化。
12     private static Connection con;//需要靜態變量
13 
14     /*
15     靜態代碼塊在加載類的時候就執行該部分的代碼。
16      */
17     static {
18         try{
19             Class.forName("com.mysql.jdbc.Driver");
20             String url="jdbc:mysql://192.168.147.146:3306/homework_day13";
21             String  username="test";
22             String  password="123456";
23             con= DriverManager.getConnection(url,username,password);
24         }catch (Exception ex){
25             throw  new RuntimeException(ex+"數據庫連接失敗!");//如果出現異常的話  需要種子程序 所以要拋出異常。需要創建運行異常的錯誤。
26         }
27     }
28 
29     public  static Connection  getCon(){
30         return  con;
31     }
32     /*
33     關閉資源。
34     通過方法的重載來判斷用戶執行的是查詢和更新操作。
35      */
36     public  static   void  cls_re (Connection con, Statement pst, ResultSet rs)throws SQLException{
37         /*
38         注意:這里需要判斷需要關閉的對象是否存在以及該對象如果拋出異常不能影響下面的關閉。
39         這里是Statement  是prepareStament的父類。
40          */
41         if(con!=null){
42             try {
43                 con.close();
44             }catch (Exception ex){}
45             }
46             if(pst!=null){
47             try {
48                 pst.close();
49             }catch (Exception ex){}
50             }
51             if(rs!=null){
52             try {
53                 rs.close();
54             }catch (Exception ex){}
55             }
56 
57     }
58     public static  void  cls_re(Connection con,Statement pst){
59         if(pst!=null){
60             try {
61                 pst.close();
62             }catch (Exception ex){}
63         }
64         if(pst!=null){
65             try {
66                 pst.close();
67             }catch (Exception ex){}
68         }
69     }
70 }

?

轉載于:https://www.cnblogs.com/evilliu/p/8462627.html

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

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

相關文章

個人工作13年的一些人生真實領悟

此文不定期的更新&#xff0c;想起來就寫一些&#xff0c;我都忘了我曾經會過什么了。你可能會在許多的文章里看到類似的&#xff0c;但這些是我個人的真實體會。 1 技術服從于業務 此問題以前的一個文章提過&#xff0c;不再多說。 適用于大多數對技術的盲目崇拜者。在絕大…

matlab非齊次方程組的通解,用matlab求非齊次線性方程組的通解?

先向大家介紹一下非齊次線性方程組。所謂非齊次線性方程組就是方程組等號右邊的常數項不全為零的線性方程組。全部等于零時&#xff0c;就稱為齊次線性方程組。下面我們就講解一下如何利用matlab快速求非齊次線性方程組的通解。工具/材料matlab電腦操作方法01線性方程組Axb的求…

Linux 終端仿真程序Putty

PuTTY是一個Telnet、SSH、rlogin、純TCP以及串行接口連接軟件。較早的版本僅支持Windows平臺&#xff0c;現在的版本中開始支持各類Unix平臺。 用linux作為桌面系統&#xff0c;身為工程師很多時候需要通過Telnet、SSH協議進行遠程管理&#xff0c;通過串口進行設備配置。Putty…

Mysql 數據庫水平分表 存儲過程

數據庫存儲量達到一定程度的時候&#xff0c;就需要進行分表以減輕檢索的消耗。 常用的分表方式包括水平和垂直分表。本次進行的是按照uid進行水平分表。 ##分表思路&#xff1a; 水平分表平均的將數據按照特定方式分配到多個表中。理論上每個表的訪問頻次和數據量都是同一水平…

中國架構師,名符其實有多少?

先說一下讀后感&#xff1a;我前段時間去過幾個公司面試架構師&#xff0c;要求還是蠻高的&#xff0c;要熟悉大數據量處理&#xff0c;要熟悉高并發&#xff0c;要熟悉XX體系架構&#xff0c;要能在關鍵技術上實現突破。總之&#xff0c;架構錯了&#xff0c;就啥都錯了。呵呵…

粗識靜態鏈表

為了彌補鏈表在內存分配上的不足&#xff0c;出現了靜態鏈表這么一個折中的辦法。靜態鏈表比較類似于內存池&#xff0c;它會預先分配一個足夠長的數組&#xff0c;之后鏈表節點都會保存在這個數組里&#xff0c;這樣就不需要頻繁的進行內存分配了。 當然&#xff0c;這個方法的…

php用date語句獲取時間,關于php date()函數獲取時間的設置和使用方法

date()函數是PHP自帶的時間函數&#xff0c;可以獲取當前服務器的時間echo date(Y-m-d H:i:s); //輸出:2020-05-18 11:02:35date()函數中可以使用的字母含義&#xff1a;a-"am"(上午)或者"pm"(下午)A-"AM"或者"PM"Y-年&#xff0c;顯示…

Django_form補充

問題1: 注冊頁面輸入為空&#xff0c;報錯&#xff1a;keyError&#xff1a;找不到passworddef clean(self): print("---",self.cleaned_data) # if self.cleaned_data["password"]self.cleaned_data["repeat_password"]: …

WF4.0:NativeActivity中的錯誤處理

備注&#xff1a;這篇文章的使用環境是.NET framework 4.0 RC 1 在WF4中創建native活動時&#xff0c;NativeActivity是非常強大的。其眾多的功能之一是圍繞錯誤處理。 調度子活動的時的基本錯誤處理。 當NativeActivity執行的時候&#xff0c;它是通過一個NativeActivityConte…

程序員提高建議之踏踏實實“扎馬步”

踏踏實實“扎馬步” 今天無意中看了“校長”的“程序員&司機”&#xff0c;其中談到了關于程序員速成的問題。其實速成班畢業的“系統殺手”早已在遍布大江南北&#xff0c;只是在互聯網時代&#xff0c;互聯網的應用型軟件生命周期越來越短&#xff0c;業務驅動主導…

c語言scanf返回值

1. scanf 函數是有返回值的&#xff0c;它的返回值可以分成三種情況1) 正整數&#xff0c;表示正確輸入參數的個數。例如執行 scanf("%d %d", &a, &b);如果用戶輸入"3 4"&#xff0c;可以正確輸入&#xff0c;返回2&#xff08;正確輸入了兩個變量…

gpgga格式讀取MATLAB,GPS編碼格式及讀取.doc

GPS接收機只要處于工作狀態就會源源不斷地把接收并計算出的GPS導航定位信息通過串口傳送到計算機中。前面的代碼只負責從串口接收數據并將其放置于緩存&#xff0c;在沒有進一步處理之前緩存中是一長串字節流&#xff0c;這些信息在沒有經過分類提取之前是無法加以利用的。因此…

Cadence 電源完整性仿真實踐(二)

轉載于:http://blog.csdn.net/wu20093346/article/details/38050917 通過以上步驟對每個平面進行了單節點分析并觀測了響應曲線&#xff0c;接下來將觀測平面對的目標阻抗是否滿足要求&#xff0c;通過選擇電容器的方法來減小含有電容器阻抗響應曲線中的反諧振波峰。在SigWave窗…

Johnson 全源最短路徑算法

解決單源最短路徑問題&#xff08;Single Source Shortest Paths Problem&#xff09;的算法包括&#xff1a; Dijkstra 單源最短路徑算法&#xff1a;時間復雜度為 O(E VlogV)&#xff0c;要求權值非負&#xff1b; Bellman-Ford 單源最短路徑算法&#xff1a;時間復雜度為 O…

單循環鏈表中設置尾指針比設置頭指針更好的原因

尾指針是指向終端結點的指針&#xff0c;用它來表示單循環鏈表可以使得查找鏈表的開始結點和終端結點都很方便。 設一帶頭結點的單循環鏈表&#xff0c;其尾指針為rear&#xff0c;則開始結點和終端結點的位置分別是rear->next->next和rear,查找時間都是O(1)。 若用頭指…

為何大部分人成不了技術專家?

此文為我在CSDN的新的SNS里看到的&#xff0c;感觸很深&#xff0c;和大家分享一下.里面的許多人的觀點都讓我受益匪淺。 如果你是項目經理&#xff0c;產品經理或者架構師&#xff0c;我真誠邀請你加入 如果你還是學生或者還是初學者&#xff0c;我建議你先等等&#xff0c;…

Machine Learning 學習筆記1 - 基本概念以及各分類

What is machine learning? 并沒有廣泛認可的定義來準確定義機器學習。以下定義均為譯文&#xff0c;若以后有時間&#xff0c;將補充原英文...... 定義1、來自Arthur Samuel&#xff08;上世紀50年代、西洋棋程序&#xff09; 在進行特定編程的情況下給予計算機學習能力的領域…

值傳遞與地址傳遞

值傳遞與地址傳遞的區別&#xff1a;兩者其實傳遞的都是一個內存單元的內容。不同的是&#xff0c;值傳遞傳遞的內容是一個變量的值&#xff0c;得到這個值后&#xff0c;對這個值的修改不能改變原變量的值&#xff1b;而地址傳遞傳遞的是一個變量的地址&#xff0c;得到傳遞的…

蒙特 卡羅方法matlab,蒙特·卡羅方法中的數學之美,你一定不想錯過

原標題&#xff1a;蒙特卡羅方法中的數學之美&#xff0c;你一定不想錯過有方教育——我們致力于為中學生提供學界和業界前沿的學術科研教育內容&#xff0c;幫助學生參加海外科研項目&#xff0c;在提升申請競爭力的同時&#xff0c;獲得領跑優勢。一、概述蒙特卡羅方法(Monte…

【 CDN 最佳實踐】CDN 命中率優化思路

CDN 在靜態資源的加速場景中是將靜態資源緩存在距離客戶端較近的CDN 節點上&#xff0c;然后客戶端訪問該資源即可通過較短的鏈路直接從緩存中獲取資源&#xff0c;而避免再通過較長的鏈路回源獲取靜態資源。因此 CDN的緩存命中率的高低直接影響客戶體驗&#xff0c;而保證較高…