java+SQL做学生信息管理系统(增删改查)学生新作「建议收藏」

java+SQL做学生信息管理系统(增删改查)学生新作「建议收藏」java+SQL做学生信息管理系统(增删改查)过程中需要用到的所有工具数据库以及数据库管理器等等密码:q80t大学学习java后做的第一个小项目忍不住分享一下,也是我自己的面向对象编程的实践作业啦,有点水,不是很优。废话不多数,下面进入正题界面的编写是非常简单的,直接贴代码了,首先看添加功能Add.javaimportjavax.swing.*;importjava.awt.*…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

java+SQL做学生信息管理系统(增删改查)

[过程中需要用到的所有工具数据库以及数据库管理器等等]
https://pan.baidu.com/s/1j5cNKwslk8bCXSLoeCEgPQ
提取码:1234
在这里插入图片描述
大学学习java后做的第一个小项目忍不住分享一下,也是我自己的面向对象编程的实践作业啦,有点水,不是很优。废话不多数,下面进入正题

界面的编写是非常简单的,直接贴代码了,首先看添加功能

Add.java

import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Add extends JFrame implements ActionListener{ 
   
	private static final Statement PraparedStatement = null;
 	Connection con;
 	
	JLabel id = new JLabel("Id");
	JLabel name = new JLabel("Name");
	JLabel sex = new JLabel("sex");
	JLabel tel = new JLabel("Tel");
	JLabel grade = new JLabel("Grade");
	JLabel address = new JLabel("Address");
	JLabel birthday = new JLabel("Birthday");
	
	JTextField id1 = new JTextField(10);
	JTextField name1 = new JTextField(10);
	JTextField sex1 = new JTextField(10);
	JTextField tel1 = new JTextField(10);
	JTextField grade1 = new JTextField(10);
	JTextField address1 = new JTextField(10);
	JTextField birthday1 = new JTextField(8);
	
	JButton yes = new JButton("确认");
	JButton no  = new JButton("取消");	
	
		public Add() { 
   
			setTitle("添加学生信息");
			setLayout(null);
			
			id.setBounds(100,90,100,50);
			id1.setBounds(300,100,200,30);
			name.setBounds(100,140,100,50);
			name1.setBounds(300,150,200,30);
			sex.setBounds(100,190,100,50);
			sex1.setBounds(300,200,200,30);
			tel.setBounds(100,240,100,50);
			tel1.setBounds(300,250,200,30);
			grade.setBounds(100, 290, 100, 50);
			grade1.setBounds(300, 300, 200, 30);
			address.setBounds(100, 340, 100, 50);
			address1.setBounds(300,350,200,30);
			birthday.setBounds(100, 390, 100, 50);
			birthday1.setBounds(300, 400, 200, 30);
			
			yes.setBounds(100,450, 100, 60);
			no.setBounds(400, 450, 100,60);
			
			add(id);
			add(id1);
			add(name);
			add(name1);
			add(sex);
			add(sex1);
			add(tel);
			add(tel1);
			add(grade);
			add(grade1);
			add(address);
			add(address1);
			add(birthday);
			add(birthday1);
			
			add(yes);
			add(no);
			
			yes.addActionListener(this);
			no.addActionListener(this);
			
			setVisible(true);
			setBounds(600,300,600,600);
			setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE); 
		}
		public static void main(String args[]){ 
   
		new Add();
		}
		}
		

执行以后的界面
这就是执行以后的界面
下面就是按钮功能的实现,同时包含了数据库的操作

将下面的代码直接加在上面的代码的主函数上面就可以,这是上面的按钮的监听器方法

		public void actionPerformed(ActionEvent e) { 
   
					 
		 if(e.getSource()==yes) { 
   								//如果你点击的是确认按钮
			 String s1=id1.getText();   					//获取文本框中的信息
	    	 String s2=name1.getText(); 
	    	 String s3=sex1.getText();
	    	 String s4=tel1.getText();
	    	 String s5=grade1.getText();
	    	 String s6=address1.getText();
	    	 String s7=birthday1.getText();	 
	    	 
	    	 int  num  = Integer.parseInt(s7);					//将获得的日期转换为整数类型
	    	
	    	 //加载数据库驱动
		  	 try { 
   					
		    		  Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDrive");
		    	  }
		    	  catch(Exception e1) { 
   
		    		  
		    	  }	    	
		    	 //连接数据库
		    		  String uri ="jdbc:sqlserver://172.16.8.54:1433;DatebaseName=Stu";			//ip改为自己的ip,“Stu”数据库中自己新建的数据库名
		    		  String user = "sa";															//sa为自己的数据库用户名
		    		  String password = "962464";											//自己的数据库密码
		    		 
					try { 
   
						con = DriverManager.getConnection(uri,user,password);
					} catch (SQLException e2) { 
   
						// TODO Auto-generated catch block
						e2.printStackTrace();
					}
		  
		    	 
		    	  JOptionPane.showMessageDialog(null, "数据库连接成功", "连接数据库",
		    			   JOptionPane.INFORMATION_MESSAGE);
		    	  			
			try { 
   
				if(init()==true) { 
   							//假如添加的id数据库中已经存在,则不添加
						JOptionPane.showMessageDialog(null, "数据库中此 Id 已存在,不可添加", "提示",
						JOptionPane.INFORMATION_MESSAGE);
						dispose();
					}
				else if(init()==false){ 
   					//如果没有,则执行添加
						String sql="insert into Students(Id,Name,Sex,Tel,Grade,Address,Birth)"+"values('"+s1+"','"+s2+"','"+s3+"','"+s4+"','"+s5+"','"+s6+"','"+num+"')";											//创建sql语句
						
						 Statement statement = null;
			
					try { 
   
						statement = con.createStatement();
					} catch (SQLException e2) { 
   
						e2.printStackTrace();
					}
						try { 
   
								int result = statement.executeUpdate(sql);				//执行sql语句
							} catch (SQLException e1) { 
   
								e1.printStackTrace();
							}
					    	 
							JOptionPane.showMessageDialog(null, "添加学生信息成功", "完成",
									   JOptionPane.INFORMATION_MESSAGE);
						dispose();
												
					}
			} catch (HeadlessException | SQLException e2) { 
   
				// TODO Auto-generated catch block
				e2.printStackTrace();
			}
			
			}
		 else if(e.getSource()==no) { 
   
				dispose();
		 }
			}

//判断添加的Id在数据库中是否存在的方法
		public boolean init() throws SQLException { 
   
			
			String sql1="select Id FROM Students where Id='"+s1+"'";	
			
			PreparedStatement pstm = con.prepareStatement(sql1);// 执行查询
			
			ResultSet rs = pstm.executeQuery();			
			
			boolean result = false;
			
			while(rs.next()) { 
   
				
				result = true;				
			}			
			rs = pstm.executeQuery();
			return result;
		}
	}

添加功能就完成了,大功告成

删除功能,界面百年不变,所以我就只写按钮监听器里面的方法了,直接写个界面加到里面就可以了。

删除功能是按照id删除,需要输入要删除的id
下面是执行删除功能的核心代码,数据库连接等代码都是恒定不变的,就不贴了,学编程绝对不能一味的Ctrl+c;Ctrl+v;一定要自己的思考,亲手敲一遍

Delete.java

String sql="delete Students where Id ='"+s1+"'";
	    	  
	    	  Statement statement = null;
				
	    	  try { 
   
					statement = con.createStatement();
				} catch (SQLException e2) { 
   
					// TODO Auto-generated catch block
					e2.printStackTrace();
				}
		    try { 
   
			     
				 int resultset = statement.executeUpdate(sql);
			} catch (SQLException e1) { 
   
				// TODO Auto-generated catch block
				e1.printStackTrace();
			}	    	  	    	   
		    
		    JOptionPane.showMessageDialog(null, "删除学生信息成功", "完成",
	    			   JOptionPane.INFORMATION_MESSAGE);
	    	  
					}	    
	    	  }catch (HeadlessException | SQLException e2) { 
   
					// TODO Auto-generated catch block
					e2.printStackTrace();
				}

更新功能

更新功能的实现,我用到了sql中if语句的拼接,从而实现,更新指定标签的内容

Update.java

String sql = "update Students set Id = '"+s1+"'";   	    	 
            String sql1="where Id='"+s1+"'";
            
            
            
    		if(s2!= null&&!s2.equals("")) sql+=",Name ='"+s2+"'";
    				
    		if(s3!= null&&!s3.equals("")) sql +=",Sex ='"+s3+"'";	
    		
    		if(s4!= null&&!s4.equals("")) sql +=",Tel ='"+s4+"'"; 
    					 
    		if(s5!= null&&!s5.equals("")) sql += ",Grade ='"+s5+"'";
    						
    		if(s6!= null&&!s6.equals("")) sql +=",Address ='"+s6+"'";
    			 
    		if(s7!= null&&!s7.equals("")) sql +=",Birth ='"+s7+"'";
    		
       		String sql3= sql+sql1;
    		Statement statement=null;
    		try { 
   
				statement = con.createStatement();
			} catch (SQLException e2) { 
   
				e2.printStackTrace();
			}
    		try { 
   
				int result = statement.executeUpdate(sql3);
			} catch (SQLException e1) { 
   				
				e1.printStackTrace();
			}
    		
    		JOptionPane.showMessageDialog(null, "更新学生信息成功", "完成",
    				   JOptionPane.INFORMATION_MESSAGE);

查询功能

Select.java

String sql="select Id,Name,Sex,Tel,Grade,Address,Birth from Stu.Students where ID ='"+Select.id1.getText()+"'";		    	
PreparedStatement pstm = con.prepareStatement(sql);// 执行查询
ResultSet rs = pstm.executeQuery();
// 计算有多少条记录
int count = 0;
while(rs.next()){ 
   
count++;
}
rs=pstm.executeQuery();

查询还涉及到最后是用文本区显示还是使用表格显示,这个就需要自己设计了

一定要注意,代码中凡是涉及数据库名,和数据表名字的一定要改成自己的

好了,就分享到这里,欢迎留言,大家探讨。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188675.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 八路抢答器系统51单片机设计【附Proteus仿真、C程序、原理图及PCB文件、元器件清单和论文等】「建议收藏」

    八路抢答器系统51单片机设计【附Proteus仿真、C程序、原理图及PCB文件、元器件清单和论文等】「建议收藏」获取全套设计资源,请见后文说明…设计要求1)抢答器同时供8名选手或2个代表队比赛,分别用8个按钮S0-S7表示;2)设置一个系统清除和抢答控制开关S,该开关由主持人控制;3)抢答器具有锁存与显示功能。即选手按动按钮,锁存相应的编号,并在优先抢答选手的编号一直保持到主持人将系统清除为止;4)抢答器具有定时抢答功能,且一次抢答的时间由主持人设定(如30s等)。当主持人启动“开始”按键后,定时…

    2022年9月2日
    5
  • java编程基础(入门级)(超级完整版)「建议收藏」

    java编程基础(入门级)(超级完整版)「建议收藏」java基础编程01基础知识1.计算机基础【1】进制A.十进制转化二进制除以2,求余数,商继续除以2,一直到0为止,从底下往上得到结果。B.二进制转化十进制1|1|0|023∣22∣21∣202^3|2^2|2^1|2^023∣22∣21∣208+4+0+0=128+4+0+0=128+4+0+0=12【2】计算机的储存方式位(bit):0或1字节(byte):8位1字节,数据储存的最小单位1KB=1024Byte1MB=1024KB1GB=

    2022年6月10日
    25
  • python贪吃蛇编程代码大全_200行python代码实现贪吃蛇游戏

    python贪吃蛇编程代码大全_200行python代码实现贪吃蛇游戏本文实例为大家分享了python实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下这次我们来写一个贪吃蛇游戏下面贴出具体代码importpygameimporttimeimportnumpyasnp#此模块包含游戏所需的常量frompygame.localsimport*#设置棋盘的长宽BOARDWIDTH=48BOARDHEIGHT=28#分数score=0cl…

    2022年6月28日
    44
  • 基于ZigBee和STM32的智能家居控制系统的设计与实现(五)–终结篇

    基于ZigBee和STM32的智能家居控制系统的设计与实现(五)–终结篇说明首先祝贺自己顺利的完成了毕业答辩工作,想起整个过程还是挺让自己感动的。最后还被评为优秀毕业设计,虽然并没有什么luan用,但是,马上毕业了,还是挺让人怀念的。整个资料从第一篇博客说起就说会全部开源的,期间承蒙各位朋友的支持,给与资助,在此感谢了。虽然资料中私人信息删除了一些,但是不免有疏漏,所以有关个人信息还挺各位删除掉,小

    2022年4月8日
    44
  • django 聚合函数_sql聚合函数的用法

    django 聚合函数_sql聚合函数的用法前言orm模型中的聚合函数跟MySQL中的聚合函数作用是一致的,也有像Sum、Avg、Count、Max、Min,接下来我们逐个介绍聚合函数所有的聚合函数都是放在django.db.models

    2022年7月31日
    7
  • linux下ll命令查看文件属性_linux中ll命令没用

    linux下ll命令查看文件属性_linux中ll命令没用ll命令其实就是ls-l,当然如果想显示隐藏信息就是ls-al。我个人是特别喜欢ll代替ls-al命令,并且还要有颜色的那种。今天卸载软件重新安装环境变量怎么都不对了,一生气把环境变量都清空了。命令:unsetPATH然后就手动添加环境变量:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/…

    2022年9月15日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号