java連接操作Oracle

来源:http://www.cnblogs.com/ouyangtangfeng99/archive/2016/06/22/5605765.html
-Advertisement-
Play Games

開始運行: 信息輸入: 身份證號查詢: 准考證號查詢: 信息刪除: 輸入錯誤信息: ...


  1 package com.sp.test;
  2 
  3 import java.sql.*;
  4 import java.util.*;
  5 
  6 public class Text_lianxi extends Thread {
  7     public void run() {
  8         try {
  9             yunxing();
 10             Thread.sleep(10000);
 11         } catch (InterruptedException e) {
 12             // TODO 自動生成的 catch 塊
 13             e.printStackTrace();
 14         }
 15 
 16     }
 17     //輸入函數
 18     public String[] shuru() {
 19         System.out.println("請按順序依次輸入考生的詳細信息:\n考試等級,身份證號,准考證號,考生姓名,考試地點,考試成績");
 20         Scanner sc = new Scanner(System.in);
 21         String[] str = new String[6];
 22         for (int i = 0; i < str.length; i++) {
 23             str[i] = sc.nextLine();
 24         }
 25         System.out.println("信息輸入完畢");
 26         sc.close();
 27         return str;
 28     }
 29     //查詢函數
 30     public String chaxun() {
 31         System.out.println("請選擇查詢方式:\n a:身份證號     b:准考證號");
 32         Scanner sc = new Scanner(System.in);
 33         String s = sc.nextLine().toLowerCase();
 34         String str = "";
 35         if (s.equals("a")) {
 36             System.out.println("請輸入查詢號碼:");
 37             String st = sc.nextLine();
 38             if (st.length() == 18) {
 39                 str = "select * from examstudent where idcard = " + st;
 40             } else {
 41                 System.out.println("身份證位數輸入有誤");
 42             }
 43         } else if (s.equals("b")) {
 44             System.out.println("請輸入查詢號碼:");
 45             String st = sc.nextLine();
 46             if (st.length() == 15) {
 47                 str = "select * from examstudent where examcard = " + st;
 48             } else {
 49                 System.out.println("准考證位數輸入有誤");
 50             }
 51         } else {
 52             System.out.println("你輸入的查詢方式有誤,請重新進入程式");
 53         }
 54         sc.close();
 55         return str;
 56     }
 57     //刪除函數
 58     public String shanchu() {
 59         Scanner sc = new Scanner(System.in);
 60         System.out.println("請輸入考生的准考證號:");
 61         String str = sc.nextLine();
 62         if (str.length() != 15) {
 63             System.out.println("准考證號輸入有誤,請重新輸入");
 64         }
 65         sc.close();
 66         return str;
 67     }
 68     //運行
 69     public void yunxing() {
 70         synchronized ("") {
 71             try {
 72                 Connection conn = null;
 73                 // 鏈接資料庫
 74                 Class.forName("oracle.jdbc.driver.OracleDriver");
 75                 String strURL = "jdbc:oracle:thin:@localhost:1521:SP";
 76                 conn = DriverManager.getConnection(strURL, "test", "123");
 77                 System.out.println(Thread.currentThread().getName()+"資料庫連接成功");
 78                 Statement st = conn.createStatement();
 79                 // 選擇功能
 80                 Scanner sc = new Scanner(System.in);
 81                 System.out.println("請選擇功能:\n 1:輸入信息    2:查詢信息   3:刪除信息");
 82                 int num = sc.nextInt();
 83                 if (num == 1) {
 84                     // 輸入信息
 85                     String[] str = shuru();
 86                     if (str[1].length() != 18 && str[2].length() != 15) {
 87                         System.out.println("號碼位數有誤(身份證號18位,准考證號15位),請重新進入系統輸入");
 88                     } else {
 89                         st.execute("insert into examstudent values(fiowid.nextval,to_number(" + str[0] + "),'" + str[1]
 90                                 + "','" + str[2] + "','" + str[3] + "','" + str[4] + "'," + "to_number(" + str[5]
 91                                 + "))");
 92                         System.out.println("信息錄入成功");
 93                     }
 94                 } else if (num == 2) {
 95                     // 查詢
 96                     String str1 = chaxun();
 97                     ResultSet r = st.executeQuery(str1);
 98                     // 輸出查詢結果
 99                     if (r.next()) {
100                         System.out.println("考試等級:" + r.getString(2) + "\n身份證號:" + r.getString(3) + "\n准考證號:"
101                                 + r.getString(4) + "\n考生姓名:" + r.getString(5) + "\n考試地區:" + r.getString(6) + "\n考試成績:"
102                                 + r.getString(7));
103                     } else {
104                         System.out.println("查無此人,請重新進入系統");
105                     }
106                     r.close();
107                 } else if (num == 3) {
108                     // 刪除
109                     String str2 = shanchu();
110                     int a = st.executeUpdate("delete examstudent where examcard = " + str2);
111                     if (a > 0) {
112                         System.out.println("刪除成功");
113                     } else {
114                         System.out.println("查無此人,請重新進入程式");
115                     }
116                 } else {
117                     System.out.println("抱歉,暫未開放此功能");
118                 }
119                 sc.close();
120                 st.close();
121             } catch (Exception e) {
122                 e.printStackTrace();
123             }
124         }
125     }
126 
127     public static void main(String[] args) {
128         
129         Text_lianxi lx1 = new Text_lianxi();
130 //        Text_lianxi lx2 = new Text_lianxi();
131 //        Text_lianxi lx3 = new Text_lianxi();
132 
133         lx1.setName("視窗1");
134         lx1.start();
135 //        lx2.setName("視窗2");
136 //        lx2.start();
137 //        lx3.setName("視窗3");
138 //        lx3.start();
139 
140     }
141 
142 }

開始運行:

信息輸入:                                                                                                身份證號查詢:

                                        

准考證號查詢:                                                                                               信息刪除:

                                                             

輸入錯誤信息:

                                                         


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 只需一行代碼,快速為UITableView創建Delegate和DataSource。簡介CBTableViewDataSource是一個輕量級的用於快速創建UITableView的DataSource和Delegate的框架。它提供了一些方便的API,幫助用戶以一種快速和有邏輯的方式創建DataS ...
  • App Store: 電工助手 1. 去掉捐助內購,換成反饋功能 2. 細節優化 App Store: 電工助手 ...
  • 在終端 輸入 pod setup 之後 你會發現 一直沒有反應 會出現這種情況 如下圖 你要耐心等一下。 直到看到Setup completed 就算是成功了。(你的網路要好) 然後 就可以使用 這個兩個命令 更新 或者安裝 很快的。 pod install --verbose --no-repo- ...
  • 在同組項目進行共用時,容易把本地的配置文件比如*.iml等文件上傳至共用伺服器,這樣會對隊友造成巨大的麻煩,為瞭解決這個問題,可以使用下麵方法解決,下麵以上傳到伺服器的app.iml文件為例。 一、在AS的Setting中取消忽略文件尾碼".iml"; 二、在Windows目錄中找到當前項目下的"a ...
  • 自己為什麼要學android 本人作為應屆畢業生,自己進入社會前做過好多夢,可是呢,現實還是打敗了無邪!!面對社會的壓力和殘酷的競爭力自己如何生成下去??我自己對自己說:第一步 先養活自己,才能走好以後的路 開始接觸手機端android那時感覺,做android開發的工資高、android前景廣。可 ...
  • 一,效果圖。 二,工程圖。 三,代碼。 AppDelegate.h AppDelegate.m ...
  • http://mp.weixin.qq.com/s?__biz=MzI5NTAxMzk4OA==&mid=209170198&idx=1&sn=97072f8bb5d7d2434112ae411cdf63df#rd 安裝時 需要輸入密碼 密碼為:www.ifunmac.com ...
  • 本文介紹一下自定義行間距的UILabel的高度如何獲取,需要藉助一下開源的UILabel控制項:TTTAttributedLabel 附下載地址 https://github.com/TTTAttributedLabel/TTTAttributedLabel 下載後,添加到工程裡面,導入頭文件 #im ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...