Java實驗3

實驗內容

學生信息管理系統

學生成績表Student(Sno 字符串,長度9, Sname 字符串,長度10, Class 字符串,長度10, Age 整型, Sex 字符串,長度2)

實現如下功能:

A.輸入若干個學生的信息到Student表;

B.修改指定學號學生的基本信息;

C.刪除指定學號的學生基本信息;

D.按照性別找出所有相應的學生基本信息;

E.按照年齡段找出所有相應的學生基本信息,例如[19,21]的學生;

F.按照姓氏查詢所有學生的基本信息;

G.以上功能用菜單形式實現功能選擇。

實驗環境

eclipse+MySQL8.0版本+MySQL的JDBC驅動

實驗結果

數據庫中的內容

Sno、Sname、Class、Sex是varchar類型,Age是int類型

源代碼

Student.java

package lab3;
import java.util.Scanner;
import java.sql.*;
public class Student {public static void main(String[]args)throws SQLException{String No;Connection conn = null;Scanner cin = new Scanner(System.in);try{Class.forName("com.mysql.cj.jdbc.Driver");String url = "jdbc:mysql://localhost:3306/?user=root";//換成自己的mysql用戶名String username = "root";	//換成自己的mysql用戶名,應該也是rootString password = "123456";//換成自己的mysql密碼conn = DriverManager.getConnection(url, username, password);while(true){show();No = cin.nextLine();while(!Check(No)){System.out.println("輸入數據錯誤");System.out.println("請輸入:");No = cin.nextLine();}if(No.charAt(0) == '1'){PreparedStatement prestmt  = null;System.out.println("------錄入學生信息功能------");String Sno,Sname,Class,Sex;int Age;System.out.println("請輸入 學生學號");Sno = cin.nextLine();System.out.println("請輸入 學生姓名");Sname = cin.nextLine();System.out.println("請輸入 學生班級");Class = cin.nextLine();System.out.println("請輸入 學生性別");Sex = cin.nextLine();System.out.println("請輸入 學生年齡");Age = cin.nextInt();	//sql語句中stusys.student要換成自己的數據庫名.表名String sql = "INSERT INTO stusys.student VALUES(?,?,?,?,?)";prestmt = conn.prepareStatement(sql);prestmt.setString(1, Sno);prestmt.setString(2, Sname);prestmt.setString(3, Class);prestmt.setInt(4, Age);prestmt.setString(5, Sex);prestmt.executeUpdate();	prestmt.close();}else if(No.charAt(0) == '2'){PreparedStatement prestmt  = null;System.out.println("------修改學生信息功能------");String Sno,Sname,Class,Sex;int Age;System.out.println("請輸入 學生學號");Sno = cin.nextLine();System.out.println("請輸入 學生姓名");Sname = cin.nextLine();System.out.println("請輸入 學生班級");Class = cin.nextLine();System.out.println("請輸入 學生性別");Sex = cin.nextLine(); System.out.println("請輸入 學生年齡"); Age = cin.nextInt();String sql = "UPDATE stusys.student "+ "SET Sname = ?,Class = ?,Age = ?,Sex = ? "+ "WHERE Sno = ?";prestmt = conn.prepareStatement(sql);prestmt.setString(1, Sname);prestmt.setString(2, Class);prestmt.setInt(3, Age);prestmt.setString(4, Sex);prestmt.setString(5, Sno);prestmt.executeUpdate();	prestmt.close();System.out.println("修改成功");}else  if(No.charAt(0) == '3'){PreparedStatement prestmt  = null;System.out.println("------刪除學生信息功能------");String Sno;System.out.println("請輸入 學生學號");Sno = cin.nextLine();String sql = "DELETE "+ "FROM stusys.student "+ " WHERE Sno = ?";prestmt = conn.prepareStatement(sql);prestmt.setString(1, Sno);prestmt.executeUpdate();	prestmt.close();System.out.println("刪除成功");}else  if(No.charAt(0) == '4'){System.out.println("------按照性別查找學生信息功能------");String Sex;ResultSet rs = null;PreparedStatement prestmt  = null;System.out.println("請輸入 性別");Sex = cin.nextLine();String sql = "select * from stusys.student where Sex = ?";prestmt = conn.prepareStatement(sql);prestmt.setString(1, Sex);rs = prestmt.executeQuery(); while(rs.next()){String Sno = rs.getString("Sno");String Sname = rs.getString("Sname");String Class = rs.getString("Class");int Age = rs.getInt("Age");System.out.println(Sno + "   " + Sname + "   " + Class + "   " + Age + "   " + Sex);}prestmt.close();rs.close();}else  if(No.charAt(0) == '5'){System.out.println("------按照年齡查找學生基本信息-------");int Age1,Age2;ResultSet rs = null;PreparedStatement prestmt  = null;System.out.println("輸入年齡下限");Age1 = cin.nextInt();System.out.println("輸入年齡上限");Age2 = cin.nextInt();String sql = "select * from stusys.student where Age BETWEEN ? AND ?";prestmt = conn.prepareStatement(sql);prestmt.setInt(1, Age1);prestmt.setInt(2, Age2);rs = prestmt.executeQuery();while(rs.next()){String Sno = rs.getString("Sno");String Sname = rs.getString("Sname");String Class = rs.getString("Class");int Age = rs.getInt("Age");String Sex = rs.getString("Sex");System.out.println(Sno + "   " + Sname + "   " + Class + "   " + Age + "   " + Sex);}prestmt.close();rs.close();}else  if(No.charAt(0) == '6'){System.out.println("-------按照姓氏查找學生信息--------");String Xing;ResultSet rs = null;PreparedStatement prestmt  = null;System.out.println("輸入需要查詢的姓氏");Xing = cin.nextLine();Xing += '%';String sql = "select * from stusys.student where Sname like ?";prestmt = conn.prepareStatement(sql);prestmt.setString(1, Xing);rs = prestmt.executeQuery();while(rs.next()){String Sno = rs.getString("Sno");String Sname = rs.getString("Sname");int Age = rs.getInt("Age");String Sex = rs.getString("Sex");String Class = rs.getString("Class");System.out.println(Sno + "   " + Sname + "   " + Class + "   " + Age + "   " + Sex);}prestmt.close();rs.close();}else  if(No.charAt(0) == '7'){System.out.println("歡迎再次使用,再見");break;}}}catch(Exception e){e.printStackTrace();System.out.println("操縱數據庫時發生未知錯誤");}finally{if(conn!=null)conn.close();if(cin!=null)cin.close();}}public static void show(){System.out.println("	歡迎來到學生管理系統");System.out.println("-----------------------------");System.out.println("	  功能列表");System.out.println("	  1.錄入學生信息");System.out.println("	  2.修改學生信");System.out.println("	  3.刪除學生信息");System.out.println("	  4.按照性別查找學生信息");System.out.println("	  5.按照年齡段查找學生信息");System.out.println("	  6.按照姓氏查找學生信息");System.out.println("	  7.退出程序");System.out.println("請輸入功能編號");}public static boolean Check(String No){   if(No.length() != 1)return false;if(No.charAt(0)<'1' || No.charAt(0) > '8')return false;return true;}
}

MySQL數據庫大家應該都會用吧,MySQL的內容這里就不寫了哈

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

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

相關文章

初學Python必須知道的14個強大單行代碼

引言&#xff1a;Python的魅力與單行代碼的重要性 Python以其簡潔明了的語法、豐富的內置函數和強大的第三方庫深受廣大開發者喜愛。尤其對于編程小白來說&#xff0c;學習Python就像打開了一扇通向編程世界的大門。而單行代碼&#xff0c;作為Python魅力的一部分&#xff0c;…

【NetTopologySuite類庫】合并所有幾何的包圍盒AABB

流程示意圖 示例代碼 using GeoAPI.Geometries; using Microsoft.VisualStudio.TestTools.UnitTesting; using NetTopologySuite.Geometries; using NetTopologySuite.IO; using System.Collections.Generic; using System.Linq;namespace Test472 {[TestClass]public class T…

深度解析:電商訂單API及其技術實現

隨著電子商務的發展&#xff0c;實體企業開拓電商渠道的越來越多&#xff0c;原有的管理系統都需要增加電商業務管理功能&#xff0c;其中&#xff0c;對電商訂單的管理是每一個電商商家都需要的功能&#xff0c;所以對于開發者來說&#xff0c;了解電商API是什么是非常重要的&…

第100+16步 ChatGPT學習:R實現Xgboost分類

基于R 4.2.2版本演示 一、寫在前面 有不少大佬問做機器學習分類能不能用R語言&#xff0c;不想學Python咯。 答曰&#xff1a;可&#xff01;用GPT或者Kimi轉一下就得了唄。 加上最近也沒啥內容寫了&#xff0c;就幫各位搬運一下吧。 二、R代碼實現Xgboost分類 &#xff08…

LeetCode題練習與總結:比較版本號--165

一、題目描述 給你兩個 版本號字符串 version1 和 version2 &#xff0c;請你比較它們。版本號由被點 . 分開的修訂號組成。修訂號的值 是它 轉換為整數 并忽略前導零。 比較版本號時&#xff0c;請按 從左到右的順序 依次比較它們的修訂號。如果其中一個版本字符串的修訂號較…

C++動態內存的管理

今天來分享C動態內存管理相關知識&#xff0c;閑言勿談&#xff0c;直接上干貨。 1. 動態內存的開辟和銷毀(new和delete) (1)前置知識&#xff1a;我們知道c語言有malloc和calloc和realloc三個函數可以進行動態的開辟內存&#xff0c;那么它們有什么區別呢&#xff1f;首先是…

MPS 后端

本文來自&#xff1a; https://pytorch.org/docs/stable/notes/mps.html https://pytorch.ac.cn/docs/stable/notes/mps.html MPS 后端 mps 設備支持 在使用 Metal 編程框架的 MacOS 設備上&#xff0c;進行高性能 GPU 訓練。 它引入了新的設備&#xff0c;將機器學習計算圖和…

【C語言】條件運算符詳解 - 《 A ? B : C 》

目錄 C語言條件運算符詳解1. 條件運算符的語法和使用示例 1&#xff1a;基本用法輸出 2. 嵌套條件運算符示例 2&#xff1a;嵌套條件運算符輸出 3. 條件運算符與 if-else 語句的比較示例 3&#xff1a;使用 if-else 語句示例 4&#xff1a;使用條件運算符 4. 條件運算符的實際應…

PLC_博圖系列?基本指令”TONR:時間累加器“

PLC_博圖系列?基本指令”TONR&#xff1a;時間累加器“ 文章目錄 PLC_博圖系列?基本指令”TONR&#xff1a;時間累加器“背景介紹TONR&#xff1a; 時間累加器說明參數脈沖時序圖示例 關鍵字&#xff1a; PLC、 西門子、 博圖、 Siemens 、 TONR 背景介紹 這是一篇關于P…

ElasticSearch學習之路

前言 為什么學ElasticSearch&#xff1f; 數據一般有如下三種類型&#xff1a; 結構化數據&#xff0c;如&#xff1a;MySQL的表&#xff0c;一般通過索引提高查詢效率非結構化數據&#xff0c;如&#xff1a;圖片、音頻等不能用表結構表示的數據&#xff0c;一般保存到mong…

Linux C++ 054-設計模式之外觀模式

Linux C 054-設計模式之外觀模式 本節關鍵字&#xff1a;Linux、C、設計模式、外觀模式 相關庫函數&#xff1a; 概念 外觀模式&#xff08;Facade&#xff09;&#xff0c;亦稱“過程模式”。主張按照描述和判斷資料來評價課程&#xff0c;關鍵的活動是在課程實施的全過程中…

昇思25天學習打卡營第24天|基于MindSpore的Diffusion擴散模型

Diffusion擴散模型 本文基于Hugging Face&#xff1a;The Annotated Diffusion Model一文翻譯遷移而來&#xff0c;同時參考了由淺入深了解Diffusion Model一文。 關于擴散模型&#xff08;Diffusion Models&#xff09;有很多種理解&#xff0c;本文的介紹是基于denoising di…

基礎動態規劃題目基礎動態規劃題目

目錄 題目1&#xff1a; P1216 [USACO1.5] [IOI1994]數字三角形 Number Triangles 代碼示例&#xff1a; 題目2&#xff1a; Common Subsequence 代碼示例 題目3 &#xff1a;最長上升子序列 最長不下降子序列 最長上升子序列oj答案 題目1&#xff1a; P1216 [USACO1.5]…

SQL面試題練習 —— 查詢每個用戶最大連續登錄天數

目錄 1 題目2 建表語句3 題解 1 題目 查詢每個用戶最大連續登錄天數 樣例數據如下 login_log&#xff1a; 2 建表語句 --建表語句 create table if not exists login_log (user_id int comment 用戶id,login_time date comment 登錄時間 ); --數據插入 INSERT overwrit…

Matlab進階繪圖第63期—帶標記線的三維填充折線圖

三維填充折線圖是在三維折線圖的基礎上&#xff0c;對其與XOY平面之間的部分進行顏色填充&#xff0c;從而能夠更好地刻畫細節變化。 而帶標記線的三維填充折線圖是在其基礎上&#xff0c;添加X相同的一條或多條標記線&#xff0c;以用于進一步討論分析。 由于Matlab中未收錄…

飛睿智能UWB Tag藍牙防丟器標簽,寵物安全新升級,5cm精準定位測距不迷路

寵物早已成為許多家庭不可或缺的一員&#xff0c;它們用無條件的愛溫暖著我們的心房&#xff0c;陪伴我們度過每一個平凡而溫馨的日子。然而&#xff0c;隨著寵物活動范圍的擴大和外界環境的復雜多變&#xff0c;寵物走失的風險也隨之增加。每一次出門遛彎&#xff0c;都像是心…

【學術會議征稿】第六屆光電材料與器件國際學術會議(ICOMD 2024)

第六屆光電材料與器件國際學術會議&#xff08;ICOMD 2024&#xff09; 2024 6th International Conference on Optoelectronic Materials and Devices 第六屆光電材料與器件國際學術會議&#xff08;ICOMD 2024&#xff09;將于2024年11月1-3日在中國重慶召開。 大會面向基…

Windows與Ubuntu安裝ffmpeg

文章目錄 前言ffmpeg的簡介安裝ffmpegWindows下載設置環境變量 Ubuntu 總結 前言 FFmpeg是一款非常強大的開源音視頻處理工具&#xff0c;它包含了眾多的音視頻編解碼庫&#xff0c;可以用于音視頻的采集、編解碼、轉碼、流化、過濾和播放等復雜的處理。在Windows系統上安裝FF…

【Android14 ShellTransitions】(七)Transition就緒

Transition.onTransactionReady的內容比較長&#xff0c;我們挑重點的部分逐段分析&#xff08;跳過的地方并非不重要&#xff0c;而是我柿子挑軟的捏&#xff09;。 1 窗口繪制狀態的流轉以及顯示SurfaceControl 注意我們這里的SurfaceControl特指的是WindowSurfaceControll…

Laravel API資源全解析:打造高效響應的秘訣

Laravel API資源全解析&#xff1a;打造高效響應的秘訣 在構建RESTful API時&#xff0c;資源的表示和管理是核心部分。Laravel框架通過API資源&#xff08;API Resources&#xff09;提供了一種優雅的方式來格式化和轉換模型數據&#xff0c;以適應API的響應需求。本文將深入…