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.mzph.cn/web/46073.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【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…

C++动态内存的管理

今天来分享C动态内存管理相关知识&#xff0c;闲言勿谈&#xff0c;直接上干货。 1. 动态内存的开辟和销毁(new和delete) (1)前置知识&#xff1a;我们知道c语言有malloc和calloc和realloc三个函数可以进行动态的开辟内存&#xff0c;那么它们有什么区别呢&#xff1f;首先是…

PLC_博图系列☞基本指令”TONR:时间累加器“

PLC_博图系列☞基本指令”TONR&#xff1a;时间累加器“ 文章目录 PLC_博图系列☞基本指令”TONR&#xff1a;时间累加器“背景介绍TONR&#xff1a; 时间累加器说明参数脉冲时序图示例 关键字&#xff1a; PLC、 西门子、 博图、 Siemens 、 TONR 背景介绍 这是一篇关于P…

昇思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…

Flink底层原理解析:案例解析(第37天)

系列文章目录 一、flink架构 二、Flink底层原理解析 三、Flink应用场景解析 四、fink入门案例解析 文章目录 系列文章目录前言一、flink架构1. 作业管理器&#xff08;JobManager&#xff09;2. 资源管理器&#xff08;ResourceManager&#xff09;3. 任务管理器&#xff08;Ta…

JavaScript统计字符串中出现次数最多的字符

思路&#xff1a;使用charAt()方法可以通过for循环来依次遍历出字符串中的字符 将遍历出来的字符作为一个空对象的属性 如果该对象中该属性没有值则对其赋值为1 如果该对象中已经有值了则在原基础上加1 最后通过for in循环比较对象中个属性值大大小然后将其打印出来 <!DOCT…

liunx面试题目

如何看当前Linux系统有几颗物理CPU和每颗CPU的核数&#xff1f; 查看物理cup&#xff1a; cat /proc/cpuinfo|grep -c ‘physical id’ 查看每颗cup核数 cat /proc/cpuinfo|grep -c ‘processor’ 若希望自动实现软件包的更新&#xff0c;可以使用yum-cron并启动该服务 yum -y …

C++ std::lock_guard和 std::unique_lock

二者都是 C 标准库中用于管理互斥锁&#xff08;mutex&#xff09;的 RAII&#xff08;Resource Acquisition Is Initialization&#xff09;机制的类。这些类可以确保互斥锁在构造时被获取&#xff0c;在析构时被释放&#xff0c;从而避免死锁和资源泄漏问题。不过&#xff0c…

Python基础语法篇(上)

Python基础语法&#xff08;上&#xff09; 一、基知二、基本数据类型&#xff08;一&#xff09;标准数据类型&#xff08;二&#xff09;数据类型转换 三、字符串基本操作&#xff08;一&#xff09;字符串的索引和切片&#xff08;二&#xff09;字符串的拼接 三、运算符四、…

web安全之跨站脚本攻击xss

定义: 后果 比如黑客可以通过恶意代码,拿到用户的cookie就可以去登陆了 分类 存储型 攻击者把恶意脚本存储在目标网站的数据库中(没有过滤直接保存)&#xff0c;当用户访问这个页面时&#xff0c;恶意脚本会从数据库中被读取并在用户浏览器中执行。比如在那些允许用户评论的…

Ansys Zemax|探索OS中的物理光学传播

概述 物理光学传播 (Physical Optics Propagation, POP) 分析是OpticStudio序列模式中的一个强大的分析工具&#xff0c;它可以用来分析光束的传播和光纤耦合的效率。这篇文章旨在介绍这一分析工具的功能&#xff0c;并向您展示一些具体的应用示例。本文同时为您介绍了如何使用…