学生管理系统——5

package SMS_5;
/*
 * 功能:
 * 完成迷你版的学生管理系统
 * 
 */
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;


import javax.swing.*;
import java.sql.*;
import java.util.*;
import java.beans.*;
public class SMS_4 extends JFrame implements ActionListener{
//定义控件:
JPanel jp1,jp2;
JLabel jl1,jl2,jl3,jl4,jl5;
JTable jt;
JButton jb1,jb2,jb3,jb4;
JScrollPane jsp=null;
JTextField jtf;
StuModel2 sm=null;
Connection ct=null;
ResultSet rs=null;
PreparedStatement ps=null;


public static void main(String[] args) {
SMS_4 sms=new SMS_4();
}
public SMS_4(){
//北部
jp1=new JPanel();
jtf=new JTextField(10);
jb1=new JButton("search");
jb1.addActionListener(this);
jl1=new JLabel("please input name");
//集合控件
jp1.add(jl1);
jp1.add(jtf);
jp1.add(jb1);

//南部
jp2=new JPanel();
jb2=new JButton("添加");
jb2.addActionListener(this);
jb3=new JButton("修改");
jb3.addActionListener(this);
jb4=new JButton("删除");
jb4.addActionListener(this);
jp2.add(jb2);
jp2.add(jb3);
jp2.add(jb4);

//中间
//创建一个数据模型对象
sm=new StuModel2();
//初始化JTable
jt=new JTable(sm);
//组建
this.add(jp1,"North");
jsp=new JScrollPane(jt);
this.add(jsp,"Center");
this.add(jp2,"South");
this.setSize(400,400);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setVisible(true);


}
@Override
public void actionPerformed(ActionEvent e) {
//判断哪个按钮被点击
if(e.getSource()==jb1)
{
//查询数据库,跟新JTable
System.out.print("search\n");
//因为把表的数据操作封装到StuModel中,所以操作比较简单了
String name=this.jtf.getText().trim();
//写一个sql语句
String sql="select * from stu where stuName='"+name+"'";
//构建新的数据模型类,并更新
StuModel2 sm=new StuModel2(sql);
jt.setModel(sm);

}
else if(e.getSource()==jb2)
{
StuAddDialog sad=new StuAddDialog(this,"insert the data of student",true);
System.out.print("insert\n");
//获取新的数据模型
sm=new StuModel2();
//跟新JTabel;
jt.setModel(sm);

}
else if(e.getSource()==jb3)
{
//修改
int row=this.jt.getSelectedRow();
if(row==-1)
{
JOptionPane.showMessageDialog(this,"           请选择某行数据");
return ;
}
new StuUpateDialog(this,"修改",true,sm,row);
sm=new StuModel2();
jt.setModel(sm);
}
else if(e.getSource()==jb4)
{
//删除用户记录
//1.得到学生的Id
//getSelectRow 会返回点中的行,如果该用户没有选有行,将会返回-1

int row=this.jt.getSelectedRow();
if(row==-1)
{
JOptionPane.showMessageDialog(this,"           请选择某行数据");
return ;
}
//得到学生的编号
String stuId=(String)sm.getValueAt(row, 0);
String [] paras={stuId};
String sql="delete from stu where stuId=?";
StuModel2 temp=new StuModel2();
if(!temp.UpadateStu(sql,paras))
{
JOptionPane.showMessageDialog(this,"删除失败");
}
this.dispose();
sm=new  StuModel2();
jt.setModel(sm);

}

}


}



package SMS_5;


import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;


public class SqlHelper {
//定义操作数据库需要的东西
    PreparedStatement ps=null;
    Connection ct=null;
    ResultSet rs=null;
    String url="jdbc:microsoft:sqlserver://127.0.0.1:1433;databaseName=spdbl";
    String user="sa";
    String passwd="sql";
    String driver="com.microsoft.jdbc.sqlserver.SQLServerDriver";
    
    //关闭数据库资源
    public void close()
    {
        //关闭资源
        try {
            if(rs!=null) rs.close();
            if(ps!=null) ps.close();
            if(ct!=null) ct.close();
            
        } catch (final Exception e) {
            e.printStackTrace();
        }
    }
    //写一个不需要注入的方法
    public ResultSet queryExectue(String sql)
    {
        try {
            //1.加载驱动
            Class.forName(driver);
            //2.得到连接
            ct=DriverManager.getConnection(url,user,passwd);
            //3.创建ps
            ps=ct.prepareStatement(sql);
            
            rs=ps.executeQuery();
        } catch (Exception e) {
            e.printStackTrace();
        }finally
        {
            //关闭资源,???
        }
        return rs;
    }
    
    //查询数据库操作
    public ResultSet queryExectue(String sql,String []paras)
    {
        try {
            //1.加载驱动
            Class.forName(driver);
            //2.得到连接
            ct=DriverManager.getConnection(url,user,passwd);
            //3.创建ps
            ps=ct.prepareStatement(sql);
            //给ps的问号赋值
            for(int i=0;i<paras.length;i++)
            {
                ps.setString(i+1, paras[i]);
            }
            rs=ps.executeQuery();
        } catch (Exception e) {
            e.printStackTrace();
        }finally
        {
            //关闭资源,???
        }
        return rs;
    }
    
    //把增、删、改合到一起
    public boolean updExecute(String sql,String []paras)
    {
        boolean b=true;
        try {
            //1.加载驱动
            Class.forName(driver);
            //2.得到连接
            ct=DriverManager.getConnection(url,user,passwd);
            //3.创建ps
            ps=ct.prepareStatement(sql);
            //给ps的问号赋值
            for(int i=0;i<paras.length;i++)
            {
                ps.setString(i+1, paras[i]);
            }
            //4.执行操作
            if(ps.executeUpdate()!=1)
            {
                b=false;
            }
        } catch (Exception e) {
            b=false;
            e.printStackTrace();
        }finally
        {
            this.close();
        }
        return b;
    }
}



package SMS_5;
import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.GridLayout;
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 javax.swing.JButton;
import javax.swing.JDialog;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.event.AncestorEvent;
import javax.swing.event.AncestorListener;


public class StuAddDialog extends JDialog implements ActionListener {
//
JLabel jl1,jl2,jl3,jl4,jl5,jl6;
JButton jb1,jb2;
JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6;
JPanel jp1,jp2,jp3;
//owner他的父窗口
//title窗口名
//modal指定模式窗口,还是非模式窗口
public StuAddDialog(Frame owner,String title,boolean modal){
super(owner,title,modal);//调用父类构造方法,达到模式对话框效果
jl1=new JLabel("学号");
jl2=new JLabel("姓名");
jl3=new JLabel("性别");
jl4=new JLabel("年龄");
jl5=new JLabel("籍贯");
jl6=new JLabel("系名");


jtf1=new JTextField();
jtf2=new JTextField();
jtf3=new JTextField();
jtf4=new JTextField();
jtf5=new JTextField();
jtf6=new JTextField();

jb1=new JButton("添加");
jb1.addActionListener(this);
jb2=new JButton("取消");

jp1=new JPanel();
jp2=new JPanel();
jp3=new JPanel();

//设置布局
jp1.setLayout(new GridLayout(6,1));
jp2.setLayout(new GridLayout(6,1));
//
//添加组件
jp1.add(jl1);
jp1.add(jl2);
jp1.add(jl3);
jp1.add(jl4);
jp1.add(jl5);
jp1.add(jl6);

jp2.add(jtf1);
jp2.add(jtf2);
jp2.add(jtf3);
jp2.add(jtf4);
jp2.add(jtf5);
jp2.add(jtf6);

jp3.add(jb1);
jp3.add(jb2);

this.add(jp1,BorderLayout.WEST);
this.add(jp2,BorderLayout.CENTER);
this.add(jp3,BorderLayout.SOUTH);

//展现对话框
        this.setSize(300,200);
       // this.setDefaultCloseOperation(operation);
        this.setVisible(true);



}
@Override
public void actionPerformed(ActionEvent e) {
// TODO Auto-generated method stub
StuModel2 temp=new StuModel2();
String sql="insert into stu values(?,?,?,?,?,?)";
String [] paras={jtf1.getText(),jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),
jtf6.getText()};

if(!temp.UpadateStu(sql, paras))
{
JOptionPane.showMessageDialog(this,"添加失败");
}
this.dispose();
}

}


/*
 * 这是我的一个stu表的模型
 * model2模式
 * 可以把对student的表的各种操作封装到该模型中
 */
package SMS_5;


import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Vector;


import javax.swing.table.AbstractTableModel;


public class StuModel2 extends AbstractTableModel {
//定义操作数据库需要的变量
PreparedStatement ps=null;
Connection ct=null;
ResultSet rs=null;
Vector columnNames=null;
Vector rowData=null;
String url="jdbc:microsoft:sqlserver://127.0.0.1:1433;databaseName=spdbl";
String user="sa";
String passwd="sql";
String driver="com.microsoft.jdbc.sqlserver.SQLServerDriver";

//添加学生
public boolean UpadateStu(String sql,String [] paras)
{
boolean b=true;

try {
//加载驱动
//得到链接
//创建ps
//执行
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
ct=DriverManager.getConnection(url,user,passwd);
ps=ct.prepareStatement(sql);
//给ps的问号赋值
for(int i=0;i<paras.length;++i)
{
ps.setString(i+1, paras[i]);
}
//执行
if(ps.executeUpdate()!=1)
{
b=false;
}

} catch (Exception e) {
e.printStackTrace();
// TODO: handle exception
}finally{
try {
rs.close();
ps.close();
ct.close();

} catch (Exception e2) {
e2.printStackTrace();
// TODO: handle exception
}

}
return b;

}
//通过传入的sql语句来获得数据模型
public void init(String sql)
{
///中间
//列名
if(sql==null)
sql="select * from stu";
columnNames=new Vector();
columnNames.add("学号");
columnNames.add("名字");
columnNames.add("性别");
columnNames.add("年龄");
columnNames.add("籍贯");
columnNames.add("系别");
rowData =new Vector();
try {
//加载驱动
// Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
//链接启动
ct=DriverManager.getConnection("jdbc:microsoft:sqlserver://127.0.0.1:1433;"+"databaseName=spdbl","sa","sql");
ps=ct.prepareStatement(sql);
rs=ps.executeQuery();
while(rs.next())
{
//rowData可存放多行
Vector hang=new Vector();
hang.add(rs.getString(1));
hang.add(rs.getString(2));
hang.add(rs.getString(3));
hang.add(rs.getInt(4));
hang.add(rs.getString(5));
hang.add(rs.getString(6));
rowData.add(hang);
}




} catch (Exception e) {
e.printStackTrace();
// TODO: handle exception
}finally{
try {
rs.close();
ps.close();
ct.close();


} catch (Exception e2) {
e2.printStackTrace();
// TODO: handle exception
}
}
}
public StuModel2(String sql)
{
init(sql);
}
//做一个构造函数,用于初始化数据模型(表)
public StuModel2()
{
init(null);
}


@Override
public String getColumnName(int column) {
// TODO Auto-generated method stub
return (String)this.columnNames.get(column);
}


@Override
//得到共有多少列
public int getColumnCount() {
return this.columnNames.size();
}


@Override
//得到共有多少行
public int getRowCount() {
// TODO Auto-generated method stub
return this.rowData.size();
}


@Override
//得到某行某列的数据
public Object getValueAt(int row, int column) {
//向量(Vector)this.rowData.get(row)
return ((Vector)this.rowData.get(row)).get(column);
}



}



package SMS_5;
import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.GridLayout;
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 javax.swing.JButton;
import javax.swing.JDialog;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.event.AncestorEvent;
import javax.swing.event.AncestorListener;


public class StuUpateDialog extends JDialog implements ActionListener {
//
JLabel jl1,jl2,jl3,jl4,jl5,jl6;
JButton jb1,jb2;
JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6;
JPanel jp1,jp2,jp3;
//owner他的父窗口
//title窗口名
//modal指定模式窗口,还是非模式窗口
public StuUpateDialog(Frame owner,String title,boolean modal,StuModel2 sm,int rowName){
super(owner,title,modal);//调用父类构造方法,达到模式对话框效果
jl1=new JLabel("学号");
jl2=new JLabel("姓名");
jl3=new JLabel("性别");
jl4=new JLabel("年龄");
jl5=new JLabel("籍贯");
jl6=new JLabel("系名");


jtf1=new JTextField();
jtf1.setText((String)sm.getValueAt(rowName,0));
jtf1.setEditable(false );
jtf2=new JTextField();
jtf2.setText((String)sm.getValueAt(rowName,1));
jtf3=new JTextField();
jtf3.setText((String)sm.getValueAt(rowName,2));
jtf4=new JTextField();
jtf4.setText(sm.getValueAt(rowName,3).toString());
jtf5=new JTextField();
jtf5.setText((String)sm.getValueAt(rowName,4));
jtf6=new JTextField();
jtf6.setText((String)sm.getValueAt(rowName,5));

jb1=new JButton("确定");
jb1.addActionListener(this);
jb2=new JButton("取消");

jp1=new JPanel();
jp2=new JPanel();
jp3=new JPanel();

//设置布局
jp1.setLayout(new GridLayout(6,1));
jp2.setLayout(new GridLayout(6,1));
//
//添加组件
jp1.add(jl1);
jp1.add(jl2);
jp1.add(jl3);
jp1.add(jl4);
jp1.add(jl5);
jp1.add(jl6);

jp2.add(jtf1);
jp2.add(jtf2);
jp2.add(jtf3);
jp2.add(jtf4);
jp2.add(jtf5);
jp2.add(jtf6);

jp3.add(jb1);
jp3.add(jb2);

this.add(jp1,BorderLayout.WEST);
this.add(jp2,BorderLayout.CENTER);
this.add(jp3,BorderLayout.SOUTH);

//展现对话框
        this.setSize(300,200);
       // this.setDefaultCloseOperation(operation);
        this.setVisible(true);



}
@Override
public void actionPerformed(ActionEvent e) {
// TODO Auto-generated method stub

String sql="update stu set stuName=?,"+"stuSex=?,"+"stuAge=?,"+"stuJg=?,"+"stuDept=?"+" where stuId=?";
String [] paras={jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),
jtf6.getText(),jtf1.getText()};
StuModel2 temp=new StuModel2();
if(!temp.UpadateStu(sql, paras))
{
JOptionPane.showMessageDialog(this,"数据更新失败");
}
//关闭对话框
this.dispose();
}

}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值