《JAVA数据库课程设计--学生选课管理系统的设计与实现_完整源代码_.docx》由会员分享,可在线阅读,更多相关《JAVA数据库课程设计--学生选课管理系统的设计与实现_完整源代码_.docx(11页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、JAVA数据库课程设计-学生选课管理系统的设计与实现_完整源代码_ 一、课程设计目的 通过这次的设计,主要是做出一个小型的管理系统,来加强对JAVA所学知识的巩固和融会贯通,可以说是对一个学期所学知识的一个小结,加深对JAVA数据库的理解。 二、需求分析 功能需求分析: 该系统具备管理学生信息、课程信息、选课信息的功能:用户通过输入账号和密码进下该系统后,可以进行一些基础维护(学生信息维护、课程信息维护、选课信息维护)。全部都可以进行增加、修改、删除、模糊查询。 三、数据项: 1表admin(用户表) Field Type Null Key Comment Username char(10)
2、PRI 用户名 password char(10) 密码 Name Char(10) 用户昵称 2表S(学生信息表) Field Type Null Key Comment PRI 学号 Sno nvarchar( 50) Sname nvarchar( 50) Sx nvarchar(系别 3表C(课程信息表) Field Type Null Key Comment Cno nvarchar( PRI 课号 50) Cname nvarchar(课名 50) 4表SC(学生信息表) Field Type Null Key Comment PRI 课号 Cno nvarchar( 50) PR
3、I 学号 Sno nvarchar( 50) 成绩 C nvarchar( 50) 四、系统功能描述 该小型系统主要是用于管理学生及课程的基本信息,主要功能包括四面的: 1.管理学生信息,其中包括添加,删除,修改等操作。 2.管理课程信息,其中包括添加,删除,修改等操作。 3.管理选课信息,其中包括添加,删除,修改等操作。 4.查询信息,其中包括查询学生信息,查询课程信息,查询选课信息等操作。 五、代码分析 连接数据库法: 这是java连接数据库的驱动,有关数据库的操作都要用到他。 public static Connection CONN() String driverName = .mic
4、rosoft.sqlserver.jdbc.SQLServerDriver; /加载JDBC驱动 String dbURL = jdbc:sqlserver:/localhost:1433; DatabaseName=student; /连接服务器和数据库test,此处student是数据库名 String userName = sa; /默认用户名 String userPwd = mima; /密码 Connection dbConn=null; try Class.forName(driverName); dbConn = DriverManager.getConnection(dbUR
5、L, userName, userPwd); System.out.println(Connection Successful!); /如果连接成功控制台输出Connection Successful! catch (Exception e) e.printStackTrace(); return dbConn; 用户登录界面user.java: 登录时,凡是账号密码未填写、输入错误账号密码都会提出错误提示框。在填写好账号密码后,会读取数据库里admin表,并查询其输入是否存在,若无误,则登录到用户界面。 public class User extends JFrame private JLa
6、bel use,password; private JTextField k1;/用户名输入框 private JPasswordField k2;/密码输入框 private JButton b1,b2; /登录窗口 public User(JFrame f) super(系统登录); Container c=getContentPane(); c.setLayout(new FlowLayout(); use=new JLabel(username:); use.setFont(new Font(Serif,Font.PLAIN,20); password=new JLabel(passw
7、ord:); password.setFont(new Font(Serif,Font.PLAIN,20); k1=new JTextField(12); k2=new JPasswordField(12); b1=new JButton(登录); b2=new JButton(退出); / 设置登录法 BHandler b=new BHandler(); EXIT d=new EXIT(); b1.addActionListener(b); b2.addActionListener(d); /添加控件 c.add(use); c.add(k1); c.add(password); c.add
8、(k2); c.add(b1); c.add(b2); setBounds(600,300,250,150); setVisible(true); setResizable(false); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); /主函数 public static void main(String args) User f1=new User(new JFrame(); 效果图: 用户界面:Menu.java 用户界面能菜单栏有4个一级菜单,学生管理、课程管理、选课管理都能添加、修改、删除数据,分别操作数据库里的S表(学生),C表(课程
9、),SC表(选课)。查询管理则可进行三个表的查询。 import java.awt.*; import java.awt.event.*; import javax.swing.*; public class Menu extends JFrame implements ActionListener Addstu 增加学生界面; Updatastu 修改学生界面; Delstu 删除学生界面; AddC 增加课程界面; DelC 删除课程界面; UpdateC 修改课程界面; AddSC 增加选课界面; DelSC 删除选课界面; UpdateSC 修改选课界面; Selstu 学生查询界面;
10、 JPanel pCenter; CardLayout card=null; JLabel label=null; JMenuBar mb=new JMenuBar();/菜单栏 JMenu m1=new JMenu(学生管理); JMenuItem add1=new JMenuItem(add1 ); JMenuItem updata1=new JMenuItem(updata1 ); JMenuItem delete1=new JMenuItem(delete1 ); JMenu m2=new JMenu(课程管理); JMenuItem add2=new JMenuItem(add2 )
11、; JMenuItem updata2=new JMenuItem(updata2 ); JMenuItem delete2=new JMenuItem(delete2 ); JMenu m3=new JMenu(选课管理); JMenuItem add3=new JMenuItem(add3 ); JMenuItem updata3=new JMenuItem(updata3 ); JMenuItem delete3=new JMenuItem(delete3 ); JMenu m4=new JMenu(查询管理); JMenuItem 学生查询=new JMenuItem(查询信息); J
12、MenuItem m5=new JMenuItem(系统退出); Font t=new Font (sanerif,Font.PLAIN,12); public Menu () this.setTitle(学生选课管理系统); try UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName(); catch(Exception e)System.err.println(不能设置外观: +e); /组合菜单 addMenu1(); addMenu2(); addMenu3(); addMenu4(); addJMenuBa
13、r(); setJMenuBar(mb); label=new JLabel(选课管理系统,JLabel.CENTER); label.setFont(new Font(宋体,Font.BOLD,36); label.setHorizontalTextPosition(SwingConstants.CENTER); label.setForeground(Color.red); /点击事件 add1.addActionListener(this); updata1.addActionListener(this); delete1.addActionListener(this); m5.addA
14、ctionListener(this); add2.addActionListener(this); delete2.addActionListener(this); updata2.addActionListener(this); add3.addActionListener(this); delete3.addActionListener(this); updata3.addActionListener(this); 学生查询.addActionListener(this); card=new CardLayout(); pCenter=new JPanel(); pCenter.setL
15、ayout(card); 增加学生界面=new Addstu(); 修改学生界面=new Updatastu(); 删除学生界面=new Delstu(); 增加课程界面=new AddC(); 删除课程界面=new DelC(); 修改课程界面=new UpdateC(); 增加选课界面=new AddSC(); 删除选课界面=new DelSC(); 修改选课界面=new UpdateSC(); 学生查询界面=new Selstu(); pCenter.add(欢迎界面,label); pCenter.add(增加学生界面,增加学生界面); pCenter.add(修改学生界面,修改学生界
16、面); pCenter.add(删除学生界面,删除学生界面); pCenter.add(增加课程界面,增加课程界面); pCenter.add(删除课程界面,删除课程界面); pCenter.add(修改课程界面,修改课程界面); pCenter.add(增加选课界面,增加选课界面); pCenter.add(删除选课界面,删除选课界面); pCenter.add(修改选课界面,修改选课界面); pCenter.add(学生查询界面, 学生查询界面); add(pCenter,BorderLayout.CENTER); validate(); setVisible(true); setBoun
17、ds(400,150,400,280); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); addWindowListener(new WindowAdapter()/关闭程序时的操作public void windowClosing(WindowEvent e)System.exit(0); ); validate(); private void addJMenuBar() mb.add(m1);mb.add(m2);mb.add(m3);mb.add(m4);mb.add(m5); private void addMenu4() m4.add(学生查询);m4.setFont(t); private void addMenu3() m3.add(add3);m3.add(updata3);m3.add(delete3);m3.setFont(t);