java swing mysql 下面的代码无法连接到数据库,插入数据

import java.awt.*;
import javax.swing.*;
import java.awt.event.*;
import java.sql.*;

class Test
{
/*private String driver="com.mysql.jdbc.Driver";
private String url="jdbc:mysql://localhost:3306/technology";
private String user="root";
private String pass="root";*/

JFrame f;
Dialog d1,d2,r_interface;
JButton jb1,jb2,b3,b4,b5,r_inquire,r_insert,r_delete;
JLabel jl,l1,l2;
TextField tf1;
TextField tf2;

Test()
{
    init();
}

public void init()
{
    /*try {
        Class.forName(driver);
    } catch (ClassNotFoundException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }*/
    f=new JFrame();
    jl=new JLabel("江西农业大学三检工作系统");
    jb1=new JButton("登陆");
    jb2=new JButton("注册");
    f.setVisible(true);
    f.setBounds(400,200,400,300);
    f.setLayout(null);
    f.setResizable(false);
    jb1.setBounds(110,130,70,30);
    jb2.setBounds(200,130,70,30);
    jl.setBounds(110,70,200,50);
    f.add(jb1);
    f.add(jb2);
    f.add(jl);

    d1=new Dialog(f,"用户登陆",true);
    d2=new Dialog(f,"用户注册",true);
    b3=new JButton("确定");
    b4=new JButton("取消");                     //登陆界面的取消按钮
    b5=new JButton("取消");                     //注册界面的取消按钮

    myevent();
}

public void myevent()
{
    f.addWindowListener(new WindowAdapter()             //窗口退出事件监听
    {
        public void windowClosing(WindowEvent e)
        {
            System.exit(0);
        }
    });

    d1.addWindowListener(new WindowAdapter()                
    {
        public void windowClosing(WindowEvent e)
        {
            d1.setVisible(false);
        }
    });
    d2.addWindowListener(new WindowAdapter()                
    {
        public void windowClosing(WindowEvent e)
        {
            d2.setVisible(false);
        }
    });
    b3.addActionListener(new ActionListener()    //登陆界面的确定
    {
        public void actionPerformed(ActionEvent e)
        {
            dlcg();
        }
    });
    b4.addActionListener(new ActionListener()
    {
        public void actionPerformed(ActionEvent e)
        {
            d1.setVisible(false);
        }
    });
    b5.addActionListener(new ActionListener()
    {
        public void actionPerformed(ActionEvent e)
        {
            d2.setVisible(false);
        }
    });
    jb1.addActionListener(new ActionListener()
    {
        public void actionPerformed(ActionEvent e)
        {
            denglu();
        }
    });
    jb2.addActionListener(new ActionListener()
    {
        public void actionPerformed(ActionEvent e)
        {
            zhuce();
        }
    });


}

public void dlcg()
{
    r_interface=new Dialog(f,"登陆成功",true);
    r_inquire=new JButton("查询");
    r_insert=new JButton("插入");
    r_delete=new JButton("删除");

    r_interface.setLayout(null);
    r_interface.add(r_inquire);
    r_inquire.setBounds(80,60,120,30);
    r_interface.setVisible(true);

    Connection conn = null;
    PreparedStatement psta=null;

    String z_user=String.valueOf(tf1.getText());
    String z_pass=String.valueOf(tf2.getText());


    try {
        Class.forName("com.mysql.jdbc.Driver");

        conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb","root","root");
        psta = conn.prepareStatement("insert into teacher (tname,tage) values (?, ?)");
        psta.setString(1,z_user);
        psta.setString(2,z_pass);
        psta.executeUpdate();
    } catch(ClassNotFoundException e) {
        e.printStackTrace();
    }
    catch(SQLException e) {
        e.printStackTrace();
    }
    finally {
        try {
            if(conn != null) {
                conn.close();
            }
            if(psta != null) {
                psta.close();
            }
        } catch(SQLException e) {
            e.printStackTrace();
        }
    }

    /*String z_user=tf1.getText();
    String z_pass=tf2.getText();

    Connection cn = null;
    PreparedStatement pst = null;

    try {
        String sql="insert into register (r_account,r_password) values (?, ?)";

        cn = DriverManager.getConnection(url,user,pass);
        pst = cn.prepareStatement(sql);

        pst.setString(1,z_user);
        pst.setString(2,z_pass);
        pst.executeUpdate();


    } catch(SQLException e) {
        e.printStackTrace();
    } finally {
        try {
            if(pst!=null) {
                pst.close();
            }

            if(cn!=null) {
                cn.close();
            }

        } catch(SQLException e) {
            e.printStackTrace();
          }
    }

    */


}
public void denglu()
{

    l1=new JLabel("用户名");
    l2=new JLabel("密    码");

    tf1=new TextField();
    tf2=new TextField();
    tf2.setEchoChar('*');
    d1.setBounds(470,240,260,230);
    d1.setLayout(null);
    d1.setResizable(false);
    d1.add(l1);
    d1.add(l2);
    d1.add(b3);
    d1.add(b4);
    d1.add(tf1);
    d1.add(tf2);
    tf1.setBounds(80,60,120,30);
    tf2.setBounds(80,100,120,30);
    tf1.setFont(new Font("宋体",1,20));
    tf2.setFont(new Font("宋体",1,20));
    b3.setBounds(50,150,70,30);
    b4.setBounds(150,150,70,30);
    l1.setBounds(20,60,50,30);
    l2.setBounds(20,100,50,30);
    d1.setVisible(true);        
}

public void zhuce()
{

    l1=new JLabel("注册名");
    l2=new JLabel("密    码");
    //b3=new JButton("确定");
    tf1=new TextField();
    tf2=new TextField();
    tf2.setEchoChar('*');
    d2.setBounds(470,240,260,230);
    d2.setLayout(null);
    d2.setResizable(false);
    d2.add(l1);
    d2.add(l2);
    d2.add(b3);
    d2.add(b5);
    d2.add(tf1);
    d2.add(tf2);
    tf1.setBounds(80,60,120,30);
    tf2.setBounds(80,100,120,30);
    tf1.setFont(new Font("宋体",1,20));
    tf2.setFont(new Font("宋体",1,20));
    b3.setBounds(50,150,70,30);
    b5.setBounds(150,150,70,30);
    l1.setBounds(20,60,50,30);
    l2.setBounds(20,100,50,30);
    d2.setVisible(true);
}

public static void main(String[] args)
{
    Connection conn = null;
    PreparedStatement psta=null;

    new Test(); 
}

}

3个回答

代码应该没问题啊,,可能是驱动的问题,,你把连接数据库的代码单独测试下,,看行不行

Royal_lr
Royal_lr 回复xuzekun12138: 这是个问题
4 年多之前 回复
xuzekun12138
xuzekun12138 解决了,虽然搞不清楚原因,但是只要把连接数据库的操作放在组件的写入前,问题就没有了
4 年多之前 回复

1.数据库是否打开(可以先用navicat连接试试)
2.数据库驱动是否加载(jar文件)
3.看看版本是不是不一致,如果报错,贴一下错误

dcxy0
Q544471255 回复xuzekun12138: ..当然要先连接。。。才能读写数据
4 年多之前 回复
xuzekun12138
xuzekun12138 解决了,虽然搞不清楚原因,但是只要把连接数据库的操作放在组件的写入前,问题就没有了
4 年多之前 回复

看一下这里的错误,根据错误去分析

try {
Class.forName("com.mysql.jdbc.Driver");

    conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb","root","root");
    psta = conn.prepareStatement("insert into teacher (tname,tage) values (?, ?)");
    psta.setString(1,z_user);
    psta.setString(2,z_pass);
    psta.executeUpdate();
} catch(ClassNotFoundException e) {
    e.printStackTrace();
}
catch(SQLException e) {
    e.printStackTrace();
}
finally {
    try {
        if(conn != null) {
            conn.close();
        }
        if(psta != null) {
            psta.close();
        }
    } catch(SQLException e) {
        e.printStackTrace();
    }
}
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java.lang.NullPointerException
package ch12; import java.awt.BorderLayout; import java.awt.Dimension; import java.awt.FlowLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import javax.swing.Box; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JMenu; import javax.swing.JMenuBar; import javax.swing.JMenuItem; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.JTextField; @SuppressWarnings("serial") public class adminUser extends JFrame implements ActionListener { JMenuBar menu; JMenu me, me1, me2, me3, me4; JMenuItem item, item3, item4, item5, item6, item7; JMenuItem item8, item9, item10, item11, item12, item13, item14; JMenuItem item15, item16, item17, item18, item19, item21; JMenuItem item22, item23; JLabel hintLabel; JTextField inputNumber; Object name[] = { "部门编号" }; Object a[][] = new Object[1][1]; JTable table; JButton enterModify; JLabel hintLabel3; JTextField inputNumber3; Object name3[] = { "工龄等级", "技术等级" }; Object a3[][] = new Object[1][2]; JTable table3; JButton enterModify3; JLabel hintLabel4; JTextField inputnum4; Object name4[] = { "出勤类别", "系数" }; Object a4[][] = new Object[1][2]; JTable table4; JButton enter4; JLabel hintLabel5; JTextField inputnum5; Object name5[] = { "津贴类别", "津贴款数" }; Object a5[][] = new Object[1][2]; JTable table5; JButton enter5; JLabel hintLabel6; JTextField inputnum6; Object name6[] = { "款数" }; Object a6[][] = new Object[1][1]; JTable table6; JButton enter6; JLabel hintLabel7; JTextField inputnum7; Object name7[] = { "款数" }; Object a7[][] = new Object[1][1]; JTable table7; JButton enter7; JLabel hintLabel8; Object name8[] = { "员工号", "姓名", "性别", "出生日期(格式日/月/年)", "文化程度", "民族", "籍贯", "地址", "人员级别", "部门编号", "技术等级"}; Object a8[][] = new Object[1][11]; JTable table8; JButton enterInsert8; JLabel hintLabel9; Object name9[] = { "员工号", "出勤类别号", "出勤天数" }; Object a9[][] = new Object[1][3]; JTable table9; JButton enterInsert9; JLabel hintLabel10; Object name10[] = { "员工号", "津贴类别号" }; Object a10[][] = new Object[1][2]; JTable table10; JButton enterInsert10; JLabel hintLabel11; Object name11[] = { "出勤编号", "出勤类别", "计算系数" }; Object a11[][] = new Object[1][3]; JTable table11; JButton enterInsert11; JLabel hintLabel12; Object name12[] = { "津贴编号", "津贴名称", "款数" }; Object a12[][] = new Object[1][3]; JTable table12; JButton enterInsert12; JLabel hintLabel13; Object name13[] = { "工龄等级", "款数" }; Object a13[][] = new Object[1][2]; JTable table13; JButton enterInsert13; JLabel hintLabel14; Object name14[] = { "职务等级", "款数" }; Object a14[][] = new Object[1][2]; JTable table14; JButton enterInsert14; JLabel hintLabel15; Object name15[] = { "员工编号", "出勤信息", "出勤天数", "计算系数" }; Object a15[][] = new Object[1][4]; JTable table15; JButton enterInsert15; JLabel hintLabel16; Object name16[] ={ "员工编号", "津贴款数", "津贴信息" }; Object a16[][] = new Object[1][3]; JTable table16; JButton enterInsert16; JLabel hintLabel17; Object name17[] = { "员工编号", "基本工资" }; Object a17[][] = new Object[1][2]; JTable table17; JButton enterInsert17; JLabel jl18; JTextField jtf18; JButton jb18; Object a18[][] = new Object[1][14]; Object name18[] = { "职工编号", "基本工资", "岗位津贴", "物价补贴", "住房补贴", "日班费", "夜班费", "假期加班", "房租", "病假扣款", "事假扣款", "旷工扣款", "其他扣款", "实发工资" }; JTable table18; JButton jj19; JTextField jt19; Object a19[][] = new Object[1][2]; Object name19[] = { "员工编号", "工资" }; JTable table19; Object a20[][] = new Object[1][2]; Object name20[] = { "部门工资", "部门编号" }; JTable table20; JLabel hintLabel21; JTextField inputNumber21; JButton jb21; JButton jj22, jb22; JTextField jt22, jl22; Object a22[][] = new Object[1][3]; Object name22[] = { "员工编号", "出勤编号", "天数" }; JTable table22; JButton jj23, jb23; JTextField jt23, jl23; Object a23[][] = new Object[1][2]; Object name23[] = { "员工编号", "津贴" }; JTable table23; JPanel jp; Connection con; Statement sql, sql1; ResultSet rs, rs1; String num; CallableStatement cstmt = null; adminUser() { this.setTitle("管理员用户"); menu = new JMenuBar(); me = new JMenu("修改"); me1 = new JMenu("添加信息"); me2 = new JMenu("显示"); me3 = new JMenu("统计"); me4 = new JMenu("删除"); item = new JMenuItem("职工部门"); item3 = new JMenuItem("职工基本工资信息"); item4 = new JMenuItem("出勤信息"); item5 = new JMenuItem("津贴信息"); item6 = new JMenuItem("工龄——工资"); item7 = new JMenuItem("职务——工资"); item8 = new JMenuItem("职工信息"); item9 = new JMenuItem("职工出勤情况"); item10 = new JMenuItem("职工津贴信息"); item11 = new JMenuItem("出勤信息"); item12 = new JMenuItem("津贴信息"); item13 = new JMenuItem("工龄——工资"); item14 = new JMenuItem("职务——工资"); item15 = new JMenuItem("职工出勤情况"); item16 = new JMenuItem("职工津贴信息"); item17 = new JMenuItem("职工基本工资信息"); item18 = new JMenuItem("职工工资"); item19 = new JMenuItem("部门工资"); // item20 = new JMenuItem("总厂工资"); item21 = new JMenuItem("职工信息"); item22 = new JMenuItem("职工出勤信息"); item23 = new JMenuItem("职工津贴信息"); item.addActionListener(this); item3.addActionListener(this); item4.addActionListener(this); item5.addActionListener(this); item6.addActionListener(this); item7.addActionListener(this); item8.addActionListener(this); item9.addActionListener(this); item10.addActionListener(this); item11.addActionListener(this); item12.addActionListener(this); item13.addActionListener(this); item14.addActionListener(this); item15.addActionListener(this); item16.addActionListener(this); item17.addActionListener(this); item18.addActionListener(this); item19.addActionListener(this); // item20.addActionListener(this); item21.addActionListener(this); item22.addActionListener(this); item23.addActionListener(this); me.add(item); me.add(item3); me.add(item4); me.add(item5); me.add(item6); me.add(item7); me1.add(item8); me1.add(item9); me1.add(item10); me1.add(item11); me1.add(item12); me1.add(item13); me1.add(item14); me2.add(item15); me2.add(item16); me2.add(item17); me3.add(item18); me3.add(item19); // me3.add(item20); me4.add(item21); me4.add(item22); me4.add(item23); menu.add(me); menu.add(me1); menu.add(me2); menu.add(me3); menu.add(me4); this.setJMenuBar(menu); this.setVisible(true); this.setSize(400,300); Dimension d = this.getToolkit().getScreenSize(); this.setLocation((d.width - this.getWidth())/2, (d.height - this.getHeight())/2-100); //this.setBounds(10, 10, 200, 200); this.validate(); this.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); } public void actionPerformed(ActionEvent e) { //修改职工部门 if (e.getSource() == item) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel = new JLabel("输入员工编号(回车确认):"); inputNumber = new JTextField(40); table = new JTable(a, name); enterModify = new JButton("更新记录"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel); baseBox.add(inputNumber); baseBox.add(new JScrollPane(table)); baseBox.add(enterModify); jp.add(baseBox); baseBox.setBounds(10, 40, 550, 38); this.add(jp); inputNumber.addActionListener(this); enterModify.addActionListener(this); setBounds(20, 60, 600, 200); this.validate(); } //修改 职工基本工资信息 else if (e.getSource() == item3) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel3 = new JLabel("输入员工编号(回车确认):"); inputNumber3 = new JTextField(20); table3 = new JTable(a3, name3); enterModify3 = new JButton("更新记录"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel3); baseBox.add(inputNumber3); baseBox.add(new JScrollPane(table3)); baseBox.add(enterModify3); jp.add(baseBox); baseBox.setBounds(10, 40, 550, 38); this.add(jp); inputNumber3.addActionListener(this); enterModify3.addActionListener(this); this.validate(); } //修改 出勤信息 else if (e.getSource() == item4) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel4 = new JLabel("输入类别号(回车确认)"); inputnum4 = new JTextField(20); table4 = new JTable(a4, name4); enter4 = new JButton("更新记录"); jp.setLayout(null); Box basebox = Box.createHorizontalBox(); basebox.add(hintLabel4); basebox.add(inputnum4); basebox.add(new JScrollPane(table4)); basebox.add(enter4); jp.add(basebox); basebox.setBounds(10, 40, 550, 38); this.add(jp); setBounds(20, 60, 700, 200); this.validate(); inputnum4.addActionListener(this); enter4.addActionListener(this); } //修改 津贴信息 else if (e.getSource() == item5) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel5 = new JLabel("输入类别号(回车确认)"); inputnum5 = new JTextField(20); table5 = new JTable(a5, name5); enter5 = new JButton("更新记录"); jp.setLayout(null); Box basebox = Box.createHorizontalBox(); basebox.add(hintLabel5); basebox.add(inputnum5); basebox.add(new JScrollPane(table5)); basebox.add(enter5); jp.add(basebox); basebox.setBounds(10, 40, 550, 38); this.add(jp); setBounds(20, 60, 700, 200); this.validate(); this.setVisible(true); inputnum5.addActionListener(this); enter5.addActionListener(this); } //修改 工龄——工资 else if (e.getSource() == item6) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel6 = new JLabel("输入工龄等级(回车确认)"); inputnum6 = new JTextField(20); table6 = new JTable(a6, name6); enter6 = new JButton("更新记录"); jp.setLayout(null); Box basebox = Box.createHorizontalBox(); basebox.add(hintLabel6); basebox.add(inputnum6); basebox.add(new JScrollPane(table6)); basebox.add(enter6); jp.add(basebox); basebox.setBounds(10, 40, 550, 38); this.add(jp); inputnum6.addActionListener(this); enter6.addActionListener(this); setBounds(20, 60, 700, 200); this.validate(); } //修改 职务——工资 else if (e.getSource() == item7) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel7 = new JLabel("输入职务等级(回车确认)"); inputnum7 = new JTextField(20); table7 = new JTable(a7, name7); enter7 = new JButton("更新记录"); jp.setLayout(null); Box basebox = Box.createHorizontalBox(); basebox.add(hintLabel7); basebox.add(inputnum7); basebox.add(new JScrollPane(table7)); basebox.add(enter7); jp.add(basebox); this.add(jp); basebox.setBounds(10, 40, 550, 38); inputnum7.addActionListener(this); enter7.addActionListener(this); setBounds(20, 60, 700, 200); this.validate(); } //添加职工信息 else if (e.getSource() == item8) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel8 = new JLabel("输入新记录:"); table8 = new JTable(a8, name8); enterInsert8 = new JButton("插入新记录"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel8); baseBox.add(new JScrollPane(table8)); baseBox.add(enterInsert8); jp.add(baseBox); baseBox.setBounds(10, 40, 800, 38); this.add(jp); enterInsert8.addActionListener(this); setBounds(120, 160, 850, 200); this.validate(); } //添加职工出勤情况 else if (e.getSource() == item9) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel9 = new JLabel("输入新信息:"); table9 = new JTable(a9, name9); enterInsert9 = new JButton("插入新信息"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel9); baseBox.add(new JScrollPane(table9)); baseBox.add(enterInsert9); jp.add(baseBox); baseBox.setBounds(10, 40, 500, 38); this.add(jp); enterInsert9.addActionListener(this); setBounds(120, 160, 550, 200); this.validate(); } //添加职工津贴信息 else if (e.getSource() == item10) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel10 = new JLabel("输入新信息:"); table10 = new JTable(a10, name10); enterInsert10 = new JButton("插入新信息"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel10); baseBox.add(new JScrollPane(table10)); baseBox.add(enterInsert10); jp.add(baseBox); baseBox.setBounds(10, 40, 500, 38); this.add(jp); enterInsert10.addActionListener(this); setBounds(120, 160, 550, 200); this.validate(); } //添加出勤信息 else if (e.getSource() == item11) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel11 = new JLabel("输入新信息:"); table11 = new JTable(a11, name11); enterInsert11 = new JButton("插入新信息"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel11); baseBox.add(new JScrollPane(table11)); baseBox.add(enterInsert11); jp.add(baseBox); baseBox.setBounds(10, 40, 500, 38); this.add(jp); enterInsert11.addActionListener(this); setBounds(120, 160, 550, 200); this.validate(); } //添加津贴信息 else if (e.getSource() == item12) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel12 = new JLabel("输入新信息:"); table12 = new JTable(a12, name12); enterInsert12 = new JButton("插入新信息"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel12); baseBox.add(new JScrollPane(table12)); baseBox.add(enterInsert12); jp.add(baseBox); baseBox.setBounds(10, 40, 500, 38); this.add(jp); enterInsert12.addActionListener(this); setBounds(120, 160, 550, 200); this.validate(); } //添加工龄——工资 else if (e.getSource() == item13) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel13 = new JLabel("输入新信息:"); table13 = new JTable(a13, name13); enterInsert13 = new JButton("插入新信息"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel13); baseBox.add(new JScrollPane(table13)); baseBox.add(enterInsert13); jp.add(baseBox); baseBox.setBounds(10, 40, 500, 38); this.add(jp); enterInsert13.addActionListener(this); setBounds(120, 160, 550, 200); this.validate(); } //添加 职务——工资 else if (e.getSource() == item14) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel14 = new JLabel("输入新信息:"); table14 = new JTable(a14, name14); enterInsert14 = new JButton("插入新信息"); jp.setLayout(null); Box baseBox = Box.createHorizontalBox(); baseBox.add(hintLabel14); baseBox.add(new JScrollPane(table14)); baseBox.add(enterInsert14); jp.add(baseBox); baseBox.setBounds(10, 40, 500, 38); this.add(jp); enterInsert14.addActionListener(this); setBounds(120, 160, 550, 200); this.validate(); } //显示 职工出勤情况 else if (e.getSource() == item15) { this.getContentPane().removeAll(); jp = new JPanel(); try { con = getConnection(); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT * FROM CalEmpAndPre"); rs.last(); int lastNumber = rs.getRow(); a15 = new Object[lastNumber][4]; int k = 0; rs.beforeFirst(); while (rs.next()) { a15[k][0] = rs.getString(1); a15[k][1] = rs.getString(3); a15[k][2] = rs.getString(4); a15[k][3] = rs.getDouble(5); k++; } con.close(); } catch (SQLException ee) { System.out.println(ee); } table15 = new JTable(a15, name15); jp.setLayout(new BorderLayout()); jp.add(new JScrollPane(table15), BorderLayout.CENTER); this.add(jp); setBounds(120, 160, 550, 200); this.validate(); } //显示职工津贴信息 else if (e.getSource() == item16) { this.getContentPane().removeAll(); jp = new JPanel(); try { con = getConnection(); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT * FROM CalEmpAndJintie"); rs.last(); int lastNumber = rs.getRow(); a16 = new Object[lastNumber][3]; int k = 0; rs.beforeFirst(); while (rs.next()) { a16[k][0] = rs.getString(1); a16[k][1] = rs.getDouble(3); a16[k][2] = rs.getString(4); k++; } con.close(); } catch (SQLException ee) { System.out.println(ee); } table16 = new JTable(a16, name16); jp.setLayout(new BorderLayout()); jp.add(new JScrollPane(table16), BorderLayout.CENTER); this.add(jp); setBounds(120, 160, 550, 200); this.validate(); } //显示职工基本工资信息 else if (e.getSource() == item17) { this.getContentPane().removeAll(); jp = new JPanel(); try { con = getConnection(); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT * FROM CalEmpAndSal"); rs.last(); int lastNumber = rs.getRow(); a17 = new Object[lastNumber][2]; int k = 0; rs.beforeFirst(); while (rs.next()) { a17[k][0] = rs.getString(1); a17[k][1] = rs.getDouble(2) + rs.getDouble(3); // System.out.println("update EmpAndSal set emp_salary="+Double.parseDouble(a[k][1].toString())+" where emp_salEmpNO='"+a[k][0]+"'"); String s = new String("update EmpAndSal set emp_salary=" + Double.parseDouble(a17[k][1].toString()) + " where emp_salEmpNO='" + a17[k][0] + "'"); Statement m = con.createStatement(); m.executeUpdate(s); k++; } con.close(); } catch (SQLException ee) { System.out.println(ee); } table17 = new JTable(a17, name17); jp.setLayout(new BorderLayout()); jp.add(new JScrollPane(table17), BorderLayout.CENTER); this.add(jp); setBounds(120, 160, 550, 200); this.validate(); } //统计职工工资 else if (e.getSource() == item18) { this.getContentPane().removeAll(); jp = new JPanel(); try { con = getConnection(); con.setAutoCommit(false); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); sql1 = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs1 = sql1.executeQuery("SELECT emp_No FROM employees"); rs1.last(); int lastNumber = rs1.getRow(); a18 = new Object[lastNumber][14]; rs1.beforeFirst(); int k = 0; while (rs1.next()) { String m = rs1.getString(1); // System.out.println(m+""); // System.out.println("SELECT emp_salary FROM EmpAndSal WHERE emp_salEmpNo='"+m+"'"); rs = sql.executeQuery("SELECT emp_salary FROM EmpAndSal WHERE emp_salEmpNo='" + m + "'"); a18[k][0] = m; a18[k][1] = 0; a18[k][2] = 0; a18[k][3] = 0; a18[k][4] = 0; a18[k][5] = 0; a18[k][6] = 0; a18[k][7] = 0; a18[k][8] = 0; a18[k][9] = 0; a18[k][10] = 0; a18[k][11] = 0; a18[k][12] = 0; a18[k][13] = 0; rs.beforeFirst(); while (rs.next()) { a18[k][1] = rs.getDouble(1); } double s = Double.parseDouble(a18[k][1].toString()) / 24; double sum = 0; rs = sql.executeQuery("SELECT jin_No,jin_Money,jin_Name FROM CalEmpAndJintie WHERE emp_jinEmpNo='" + m + "'"); //查询津贴 while (rs.next()) { int pr = rs.getInt(1); if (pr == 1) { a18[k][2] = rs.getDouble(2); } else if (pr == 2) { a18[k][3] = rs.getDouble(2); } else if (pr == 3) { a18[k][4] = rs.getDouble(2); } else if (pr == 4) { a18[k][8] = rs.getDouble(2); } } rs = sql.executeQuery("SELECT pre_No,emp_prePreDays,pre_Xishu FROM CalEmpAndPre WHERE emp_preEmpNo='" + m + "'"); //查询出勤 while (rs.next()) { int pre = rs.getInt(1); if (pre == 6) { a18[k][5] = rs.getDouble(2) * s * rs.getDouble(3); } else if (pre == 7) { a18[k][6] = rs.getDouble(2) * s * rs.getDouble(3); } else if (pre == 8) { a18[k][7] = rs.getDouble(2) * s * rs.getDouble(3); } else if (pre == 3) { a18[k][9] = rs.getDouble(2) * s * rs.getDouble(3); } else if (pre == 5) { a18[k][10] = rs.getDouble(2) * s * rs.getDouble(3); } else if (pre == 4) { a18[k][11] = rs.getDouble(2) * s * rs.getDouble(3); } else { sum = sum + rs.getDouble(2) * s * rs.getDouble(3); } } a18[k][12] = sum; a18[k][13] = sum + Double.parseDouble(a18[k][1].toString()) + Double.parseDouble(a18[k][2].toString()) + Double.parseDouble(a18[k][3].toString()) + Double.parseDouble(a18[k][4].toString()) + Double.parseDouble(a18[k][5].toString()) + Double.parseDouble(a18[k][6].toString()) + Double.parseDouble(a18[k][7].toString()) + Double.parseDouble(a18[k][8].toString()) + Double.parseDouble(a18[k][9].toString()) + Double.parseDouble(a18[k][10].toString()) + Double.parseDouble(a18[k][11].toString()); int re = sql.executeUpdate("Update EmpAndRSal SET emp_rsalary=" + Double.parseDouble(a18[k][13].toString()) + " WHERE emp_rsalEmpNo='" + m + "'"); k++; if(re == 1) System.out.println(m + "的实际工资更新成功了"); else System.out.println(m + "的实际工资更新失败了"); } con.commit(); con.close(); } catch (SQLException ee) { try { con.rollback(); } catch (SQLException e1) { System.out.println(e1); } } table18 = new JTable(a18, name18); jp.setLayout(new BorderLayout()); jp.add(new JScrollPane(table18), BorderLayout.CENTER); this.add(jp); setBounds(120, 160, 550, 200); this.validate(); } //统计部门工资 else if (e.getSource() == item19) { this.getContentPane().removeAll(); jp = new JPanel(); jj19 = new JButton("ok"); jt19 = new JTextField(16); jp.setLayout(new FlowLayout()); jp.add(jj19); jp.add(jt19); jj19.addActionListener(this); this.setLayout(new BorderLayout()); this.add(jp, BorderLayout.NORTH); // this.setBounds(10,10,550,200); this.setVisible(true); this.validate(); this.setBounds(10, 10, 550, 203); } //统计总厂工资(没有这个功能了) // else if (e.getSource() == item20) { // this.getContentPane().removeAll(); // jp = new JPanel(); // try { // con = getConnection(); // // sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, // ResultSet.CONCUR_READ_ONLY); // rs = sql.executeQuery("SELECT * FROM CalEmpAndDep"); // rs.last(); // int k = rs.getRow(); // a20 = new Object[k + 1][2]; // rs.beforeFirst(); // k = 0; // double sum = 0; // while (rs.next()) { // a20[k][0] = rs.getDouble(1); // a20[k][1] = rs.getInt(2); // sum = sum + rs.getDouble(1); // // System.out.println(a20[k][0]+""+a20[k][1]); // k++; // } // a20[k][0] = sum; // a20[k][1] = "厂总工资"; // con.close(); // } catch (SQLException e1) { // e1.printStackTrace(); // } // jp.setLayout(new BorderLayout()); // table20 = new JTable(a20, name20); // jp.add(new JScrollPane(table20), BorderLayout.CENTER); // this.add(jp); // this.validate(); // } //删除职工信息 else if (e.getSource() == item21) { this.getContentPane().removeAll(); jp = new JPanel(); hintLabel21 = new JLabel("输入员工编号:"); jb21 = new JButton("删除记录"); inputNumber21 = new JTextField(16); jp.add(hintLabel21); jp.add(inputNumber21); jp.add(jb21); this.add(jp); inputNumber21.addActionListener(this); jb21.addActionListener(this); setBounds(20, 60, 700, 200); this.validate(); } //删除职工出勤信息 else if (e.getSource() == item22) { this.getContentPane().removeAll(); jj22 = new JButton("ok"); jt22 = new JTextField(16); jp = new JPanel(); jp.setLayout(new FlowLayout()); jp.add(jt22); jp.add(jj22); jj22.addActionListener(this); jl22 = new JTextField(16); jb22 = new JButton("删除"); jb22.addActionListener(this); JPanel jpj = new JPanel(); jpj.setLayout(new FlowLayout()); jpj.add(jl22); jpj.add(jb22); this.add(jpj, BorderLayout.NORTH); this.add(jp, BorderLayout.SOUTH); this.setBounds(12, 10, 500, 500); this.setVisible(true); this.validate(); } //删除职工津贴信息 else if (e.getSource() == item23) { this.getContentPane().removeAll(); jj23 = new JButton("ok"); jt23 = new JTextField(16); jp = new JPanel(); jp.setLayout(new FlowLayout()); jp.add(jt23); jp.add(jj23); jj23.addActionListener(this); jl23 = new JTextField(16); jb23 = new JButton("删除"); jb23.addActionListener(this); JPanel jpj = new JPanel(); jpj.setLayout(new FlowLayout()); ; jpj.add(jl23); jpj.add(jb23); this.add(jpj, BorderLayout.NORTH); this.add(jp, BorderLayout.SOUTH); this.setBounds(12, 10, 500, 500); this.setVisible(true); this.validate(); } //修改职工部门监听 if (e.getSource() == inputNumber) { try { num = inputNumber.getText().trim(); con = getConnection(); sql = con.createStatement(); rs = sql.executeQuery("SELECT * FROM DepAndEmp WHERE dep_empEmpNo='" + num + "'"); boolean boo = rs.next(); if (boo == false) { JOptionPane.showMessageDialog(this, "该员工不存在", "提示", JOptionPane.WARNING_MESSAGE); } else { a[0][0] = rs.getInt(2); table.repaint(); } con.close(); } catch (SQLException ee) { System.out.println(ee); } } if (e.getSource() == enterModify) { try { con = getConnection(); sql = con.createStatement(); sql.executeUpdate("UPDATE DepAndEmp SET dep_empDepNo=" + a[0][0] + " WHERE dep_empEmpNo='" + num + "'"); JOptionPane.showMessageDialog(this, "修改成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "修改失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 修改职工基本工资监听 if (e.getSource() == inputNumber3) { try { num = inputNumber3.getText().trim(); con = getConnection(); sql = con.createStatement(); rs = sql.executeQuery("SELECT * FROM EmpAndSal WHERE emp_salEmpNO='" + num + "'"); boolean boo = rs.next(); if (boo == false) { JOptionPane.showMessageDialog(this, "该员工不存在", "提示", JOptionPane.WARNING_MESSAGE); } else { a3[0][0] = rs.getInt(2); a3[0][1] = rs.getInt(3); table3.repaint(); } con.close(); } catch (SQLException ee) { System.out.println(ee); } } if (e.getSource() == enterModify3) { try { con = getConnection(); sql = con.createStatement(); sql.executeUpdate("UPDATE EmpAndSal SET emp_salTimeLev=" + a3[0][0] + ",emp_salTechLev=" + a3[0][1] + " WHERE emp_salEmpNO='" + num + "'"); JOptionPane.showMessageDialog(this, "修改成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "修改失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 修改出勤表信息监听 if (e.getSource() == inputnum4) { try { int x = Integer.parseInt(inputnum4.getText().trim()); num = inputnum4.getText().trim(); con = getConnection(); sql = con.createStatement(); rs = sql.executeQuery("SELECT * from presence where pre_no=" + x); boolean boo = rs.next(); if (boo == false) { JOptionPane.showMessageDialog(this, "出勤类别号不存在", "提示", JOptionPane.WARNING_MESSAGE); } else { a4[0][0] = rs.getString(2); a4[0][1] = rs.getDouble(3); table4.repaint(); } con.close(); } catch (SQLException ee) { System.out.println(ee); } } if (e.getSource() == enter4) { try { con = getConnection(); //System.out.println(a4[0][0] + "," + a4[0][1] + "," + num); sql = con.createStatement(); int k = sql.executeUpdate("update presence set pre_name='" + a4[0][0] + "',pre_xishu=" + Double.parseDouble(a4[0][1].toString()) + " where pre_no='" + num + "'"); if (k == 1) { JOptionPane.showMessageDialog(this, "信息更新成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "更新失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 监听修改津贴信息 if (e.getSource() == inputnum5) { int k = Integer.parseInt(inputnum5.getText().trim()); try { System.out.println(k + ""); con = getConnection(); sql = con.createStatement(); rs = sql.executeQuery("SELECT * from Jintie where jin_no=" + k); boolean boo = rs.next(); if (boo == false) { JOptionPane.showMessageDialog(this, "出勤类别号不存在", "提示", JOptionPane.WARNING_MESSAGE); } else { a5[0][0] = rs.getString(2); a5[0][1] = rs.getDouble(3); table5.repaint(); } // System.out.println(Double.parseDouble(a5[0][1].toString())+""); con.close(); } catch (SQLException ee) { System.out.println(ee); } } if (e.getSource() == enter5) { int k = Integer.parseInt(inputnum5.getText().trim()); try { con = getConnection(); sql = con.createStatement(); // System.out.println(Double.parseDouble(a5[0][1].toString())+""); int m = sql.executeUpdate("update jintie set jin_name='" + a5[0][0] + "',jin_Money=" + Double.parseDouble(a5[0][1].toString()) + " where jin_no='" + k + "'"); if (m == 1) { JOptionPane.showMessageDialog(this, "信息修改成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "修改失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 修改工资工龄监听 if (e.getSource() == inputnum6) { int k = Integer.parseInt(inputnum6.getText().trim()); try { // System.out.println(k+""); con = getConnection(); sql = con.createStatement(); rs = sql.executeQuery("SELECT * from SalAndTime where sal_timeLev=" + k); boolean boo = rs.next(); if (boo == false) { JOptionPane.showMessageDialog(this, "该等级不存在", "提示", JOptionPane.WARNING_MESSAGE); } else { a6[0][0] = rs.getDouble(2); table6.repaint(); } con.close(); } catch (SQLException ee) { System.out.println(ee); } } if (e.getSource() == enter6) { int k = Integer.parseInt(inputnum6.getText().trim()); try { con = getConnection(); sql = con.createStatement(); int m = sql .executeUpdate("update SalAndTime set sal_timeMoney=" + Double.parseDouble(a6[0][0].toString()) + " where sal_timeLev='" + k + "'"); if (m == 1) { JOptionPane.showMessageDialog(this, "信息修改成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "修改失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 修改职务工资监听 if (e.getSource() == inputnum7) { int k = Integer.parseInt(inputnum7.getText().trim()); try { // System.out.println(k+""); con = getConnection(); sql = con.createStatement(); rs = sql.executeQuery("SELECT * from SalAndTech where sal_techLev=" + k); boolean boo = rs.next(); if (boo == false) { JOptionPane.showMessageDialog(this, "该等级不存在", "提示", JOptionPane.WARNING_MESSAGE); } else { a7[0][0] = rs.getDouble(2); table7.repaint(); } con.close(); } catch (SQLException ee) { System.out.println(ee); } } if (e.getSource() == enter7) { int k = Integer.parseInt(inputnum7.getText().trim()); try { con = getConnection(); sql = con.createStatement(); int m = sql .executeUpdate("update SalAndTech set sal_techMoney=" + Double.parseDouble(a7[0][0].toString()) + " where sal_techLev='" + k + "'"); if (m == 1) { JOptionPane.showMessageDialog(this, "信息修改成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "修改失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 添加职工信息监听 if (e.getSource() == enterInsert8) { try { con = getConnection(); con.setAutoCommit(false); sql = con.createStatement(); int k = sql.executeUpdate("INSERT INTO employees VALUES('" + a8[0][0] + "','" + a8[0][1] + "','" + a8[0][2] + "','" + a8[0][3] + "','" + a8[0][4] + "','" + a8[0][5] + "','" + a8[0][6] + "','" + a8[0][7] + "','" + a8[0][8] + "')"); System.out.println("k = " + k); int m = sql .executeUpdate("INSERT INTO EmpandSal(emp_salEmpNO,emp_salTimeLev,emp_salTechLev) VALUES('" + a8[0][0] + "'," + a8[0][8] + "," + a8[0][10] + ")"); int n = sql.executeUpdate("INSERT INTO DepAndEmp VALUES('" + a8[0][0] + "'," + a8[0][9] + ")"); int l = sql .executeUpdate("INSERT INTO EmpAndRSal(emp_rsalEmpNo) VALUES('" + a8[0][0] + "')"); if (k == 1 && m == 1 && n == 1 && l == 1) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.commit(); con.close(); } catch (SQLException ee) { try { con.rollback(); JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } catch (SQLException e1) { e1.printStackTrace(); } } } // 添加出勤信息监听 if (e.getSource() == enterInsert9) { try { con = getConnection(); sql = con.createStatement(); int k = sql.executeUpdate("INSERT INTO EmpAndPre VALUES('" + a9[0][0] + "'," + a9[0][1] + "," + a9[0][2] + ")"); if (k == 1) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } //添加津贴信息监听 if (e.getSource() == enterInsert10) { try { con = getConnection(); sql = con.createStatement(); int k = sql.executeUpdate("INSERT INTO EmpAndJintie VALUES('" + a10[0][0] + "'," + a10[0][1] + ")"); if (k == 1) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 添加出勤信息监听 if (e.getSource() == enterInsert11) { try { con = getConnection(); sql = con.createStatement(); int k = sql.executeUpdate("INSERT INTO Presence VALUES(" + Integer.parseInt(a11[0][0].toString()) + ",'"+ a11[0][1] + "',"+ Double.parseDouble(a11[0][2].toString()) + ")"); if (k == 1) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 添加津贴信息监听 if (e.getSource() == enterInsert12) { try { con = getConnection(); sql = con.createStatement(); int k = sql.executeUpdate("INSERT INTO Jintie VALUES(" + Integer.parseInt(a12[0][0].toString()) + ",'" + a12[0][1] + "'," + Double.parseDouble(a12[0][2].toString()) + ")"); if (k == 1) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 添加工龄等级监听 if (e.getSource() == enterInsert13) { try { con = getConnection(); // con = DriverManager.getConnection("jdbc:odbc:guo", "system", // "system"); cstmt = con.prepareCall("{ call insert_data(?,?,?,?,?) }"); cstmt.setInt(1, 1); cstmt.setInt(2, 0); cstmt.setInt(3, Integer.parseInt(a13[0][0].toString())); System.out.println("here:" + Double.parseDouble(a13[0][0].toString()) + ""); cstmt.setDouble(4, Double.parseDouble(a13[0][1].toString())); cstmt.registerOutParameter(5, java.sql.Types.DECIMAL); cstmt.execute(); int k = cstmt.getInt(5); System.out.println(cstmt.getInt(5)); // sql=con.createStatement(); // int // k=sql.executeUpdate("INSERT INTO SalAndTime VALUES("+Integer.parseInt(a13[0][0].toString())+","+Double.parseDouble(a13[0][1].toString())+")"); if (k == 0) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 添加职务工资信息监听 if (e.getSource() == enterInsert14) { try { con = getConnection(); cstmt = con.prepareCall("{ call insert_data(?,?,?,?,?) }"); cstmt.setInt(1, 0); cstmt.setInt(2, 1); cstmt.setInt(3, Integer.parseInt(a14[0][0].toString())); cstmt.setDouble(4, Double.parseDouble(a14[0][1].toString())); cstmt.registerOutParameter(5, java.sql.Types.DECIMAL); cstmt.execute(); int k = cstmt.getInt(5); System.out.println(cstmt.getInt(5)); // sql=con.createStatement(); // int // k=sql.executeUpdate("INSERT INTO SalAndTech VALUES("+Integer.parseInt(a14[0][0].toString())+","+Double.parseDouble(a14[0][1].toString())+")"); if (k == 0) JOptionPane.showMessageDialog(this, "插入成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "插入失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 监听部门工资统计 if (e.getSource() == jj19) { int m = Integer.parseInt(jt19.getText().toString()); System.out.println("m = " + m); try { con = getConnection(); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT emp_rsalEmpNo,emp_rsalary FROM DepAndEmp,EmpAndRSal WHERE dep_empEmpNo=emp_rsalEmpNo AND dep_empDepNo=" + m); rs.last(); int k = rs.getRow(); if (k != 1) { a19 = new Object[k + 1][2]; rs.beforeFirst(); k = 0; double sum = 0; while (rs.next()) { a19[k][0] = rs.getString(1); a19[k][1] = rs.getDouble(2); sum = sum + rs.getDouble(2); // System.out.println(a[k][0]+""+a[k][1]); k++; } a19[k][0] = "该部门总工资"; a19[k][1] = sum; con.close(); table19 = new JTable(a19, name19); add(new JScrollPane(table19), BorderLayout.CENTER); } else JOptionPane.showMessageDialog(this, "输入错误", "错误", JOptionPane.ERROR_MESSAGE); } catch (SQLException e1) { e1.printStackTrace(); } table19 = new JTable(a19, name19); add(new JScrollPane(table19), BorderLayout.CENTER); validate(); } // 删除职工信息监听 if (e.getSource() == jb21) { try { con = getConnection(); sql = con.createStatement(); int l = sql .executeUpdate("delete from employees where emp_No='" + inputNumber21.getText() + "'"); if (l == 1) JOptionPane.showMessageDialog(this, "删除成功", "成功", JOptionPane.PLAIN_MESSAGE); else JOptionPane.showMessageDialog(this, "没有该员工", "警告", JOptionPane.WARNING_MESSAGE); con.close(); } catch (SQLException ee) { JOptionPane.showMessageDialog(this, "删除失败" + ee, "失败", JOptionPane.ERROR_MESSAGE); } } // 删除员工出勤信息监听 if (e.getSource() == jj22) { num = jt22.getText(); try { con = getConnection(); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT * FROM EmpAndPre WHERE emp_preEmpNo='" + num + "'"); rs.last(); int k = rs.getRow(); a22 = new Object[k][3]; rs.beforeFirst(); k = 0; while (rs.next()) { a22[k][0] = rs.getString(1); a22[k][1] = rs.getInt(2); a22[k][2] = rs.getInt(3); k++; } con.close(); } catch (SQLException e1) { e1.printStackTrace(); } table22 = new JTable(a22, name22); add(new JScrollPane(table22), BorderLayout.CENTER); JPanel jpj = new JPanel(); jpj.setLayout(new FlowLayout()); validate(); } else if (e.getSource() == jb22) { String b = jt22.getText(); int c = Integer.parseInt(jl22.getText()); System.out.println(b + " " + c); try { con = getConnection(); sql = con.createStatement(); int l = sql .executeUpdate("DELETE FROM EmpAndPre WHERE emp_preEmpNo='" + b + "' and emp_prePreNo=" + c + ""); if (l == 0) { JOptionPane.showMessageDialog(this, "删除失败", "失败", JOptionPane.ERROR_MESSAGE); } else JOptionPane.showMessageDialog(this, "删除成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException e1) { e1.printStackTrace(); } validate(); } //删除职工津贴信息 if (e.getSource() == jj23) { num = jt23.getText(); try { con = getConnection(); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT * FROM EmpAndJintie WHERE emp_jinEmpNo='" + num + "'"); rs.last(); int k = rs.getRow(); a23 = new Object[k][2]; rs.beforeFirst(); k = 0; while (rs.next()) { a23[k][0] = rs.getString(1); a23[k][1] = rs.getInt(2); k++; } con.close(); } catch (SQLException e1) { e1.printStackTrace(); } table23 = new JTable(a23, name23); add(new JScrollPane(table23), BorderLayout.CENTER); JPanel jpj = new JPanel(); jpj.setLayout(new FlowLayout()); validate(); } else if (e.getSource() == jb23) { String b = jt23.getText(); int c = Integer.parseInt(jl23.getText()); System.out.println(b + " " + c); try { con = getConnection(); sql = con.createStatement(); int l = sql .executeUpdate("DELETE FROM EmpAndJintie WHERE emp_jinEmpNo='" + b + "' and emp_jinJinNo=" + c + ""); if (l == 0) { JOptionPane.showMessageDialog(this, "删除失败", "失败", JOptionPane.ERROR_MESSAGE); } else JOptionPane.showMessageDialog(this, "删除成功", "成功", JOptionPane.PLAIN_MESSAGE); con.close(); } catch (SQLException e1) { e1.printStackTrace(); } } } private Connection getConnection() {// String url = "jdbc:sqlserver://localhost:1433;DatabaseName=Salary"; try { Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");//加载mysql的驱动 return (Connection) DriverManager.getConnection(url, "sa", "123"); //返回数据库的连接 } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } return null; } public static void main(String args[]) { new adminUser(); } } ``` ``` Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException at ch12.adminUser.actionPerformed(adminUser.java:1201) at javax.swing.AbstractButton.fireActionPerformed(Unknown Source) at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source) at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source) at javax.swing.DefaultButtonModel.setPressed(Unknown Source) at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source) at java.awt.Component.processMouseEvent(Unknown Source) at javax.swing.JComponent.processMouseEvent(Unknown Source) at java.awt.Component.processEvent(Unknown Source) at java.awt.Container.processEvent(Unknown Source) at java.awt.Component.dispatchEventImpl(Unknown Source) at java.awt.Container.dispatchEventImpl(Unknown Source) at java.awt.Component.dispatchEvent(Unknown Source) at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source) at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source) at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source) at java.awt.Container.dispatchEventImpl(Unknown Source) at java.awt.Window.dispatchEventImpl(Unknown Source) at java.awt.Component.dispatchEvent(Unknown Source) at java.awt.EventQueue.dispatchEventImpl(Unknown Source) at java.awt.EventQueue.access$400(Unknown Source) at java.awt.EventQueue$3.run(Unknown Source) at java.awt.EventQueue$3.run(Unknown Source) at java.security.AccessController.doPrivileged(Native Method) at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) at java.awt.EventQueue$4.run(Unknown Source) at java.awt.EventQueue$4.run(Unknown Source) at java.security.AccessController.doPrivileged(Native Method) at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) at java.awt.EventQueue.dispatchEvent(Unknown Source) at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source) at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source) at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source) at java.awt.EventDispatchThread.pumpEvents(Unknown Source) at java.awt.EventDispatchThread.pumpEvents(Unknown Source) at java.awt.EventDispatchThread.run(Unknown Source)
有没有大神能指点一下哪里错了。。。。
package Frame; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.*; import javax.swing.*; import db.DButil; public class login extends JFrame implements ActionListener{ private JPanel jp=new JPanel(); //创建标签数组 private JLabel[] jlArray={new JLabel("用户名"), new JLabel("密 码"),new JLabel("")}; private JButton jb1; private JButton jb2; private JButton jb3; private JTextField jtf=new JTextField(); private JPasswordField jpf=new JPasswordField(); //布局构造实现方法 public login(){ Icon icon1=new ImageIcon("login.jpg"); Icon icon2=new ImageIcon("reset.jpg"); Icon icon3=new ImageIcon("zhuce.jpg"); JPanel jp=new JPanel(){ protected void paintComponent(Graphics g) { ImageIcon icon = new ImageIcon("bg.jpg"); Image img = icon.getImage(); g.drawImage(img, 0, 0, icon.getIconWidth(), icon.getIconHeight(), icon.getImageObserver()); }}; jp.setLayout(null); jb1=new JButton(icon1); jb2=new JButton(icon3); jb3=new JButton(icon2); jlArray[0].setBounds(70,120,90,32); jb1.setBounds(365,110,130,60); jb2.setBounds(365,170,130,60); jlArray[1].setBounds(70,170,90,32); //将标签与按钮添加到JPanel容器中 jp.add(jlArray[0]); jp.add(jlArray[1]); jp.add(jb1); jp.add(jb2); jb1.addActionListener(this); jb2.addActionListener(this);//为按钮注册动作事件监听器 //添加修改密码的按钮 jb3.setBounds(365,230,130,60); jp.add(jb3); jp.add(jtf); jtf.setBounds(140,120,180,30);//设置文本框位置 jp.add(jpf); jpf.setBounds(140,170,180,30);//设置密码框位置 jpf.setEchoChar('*'); //密码显示字符形式 jpf.addActionListener(this); //为密码框注册动作事件监听器 this.setVisible(true);//设置窗体的可见性 jpf.addActionListener(this); //为密码框注册动作事件监听器 //设置用于显示登陆状态的标签大小位置,并将其添加进JPanel容器 jlArray[2].setBounds(70,220,300,30); jp.add(jlArray[2]); this.setTitle("登陆");//设置窗体标题 this.setBounds(450,200,500,318);//设置窗体的大小 this.setResizable(false);//设置窗体不让用户调整大小 this.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); this.setVisible(true);//设置窗体的可见性 this.add(jp);//将窗体添加到面板中 jp.setBackground(Color.blue); } public static void main(String[] args) { new login();//创建登陆窗体 } public void actionPerformed(ActionEvent e) { // TODO Auto-generated method stub //得到用户名与密码 String user=jtf.getText().trim(); String pwd=String.valueOf(jpf.getPassword());//返回密码的字符串表示方式 String sql=""; if(e.getSource()==jtf){//事件源为文本框,切换焦点到密码框 jpf.requestFocus(); } else if(e.getSource()==jb1||e.getSource()==jpf){ //判断用户名和密码是否匹配 查询数据库 if(DButil.check(user, pwd)){ //登陆成功 MainFrame mf=new MainFrame(jtf.getText());//主窗体 this.dispose(); } else{ //登陆失败 jlArray[2].setText("对不起,非法的用户名和密码"); this.clear(); } } else if(e.getSource()==jb2) {//事件源为注册按钮 if(user.equals("")||pwd.equals("")) {//如果注册的用户名为空或者密码为空 jlArray[2].setText("用户名和密码都不得为空!!!"); this.clear();//清空输入文本框 } else { sql="select uid from user where uid='"+user+"'"; if(DButil.isExist(sql)) {//用户名已经存在 jlArray[2].setText("对不起,用户名已存在!!!"); this.clear();//清空输入文本框 } else { sql="insert into user values('"+user+"','"+pwd+"')"; if(DButil.update(sql)>0) {//注册成功 jlArray[2].setText("恭喜您!!!注册成功,请登陆"); } } } } else if(e.getSource()==jb3)//修改密码的监听 { //判断是否已经输入用户名和密码 if(user.equals("")||pwd.equals("")) { jlArray[2].setText("修改密码先输入正确的用户名和密码!!!"); this.clear();//清空输入文本框 } //判断是否输入了正确的用户名和密码 else if(DButil.check(user,pwd)) { //正确的用户名和密码 String password=JOptionPane.showInputDialog(this,"修改密码:","请输入新密码", JOptionPane.PLAIN_MESSAGE); //得到新的密码为空 if(password==null||password.equals("")) { JOptionPane.showMessageDialog(this,"密码不得为空!!!","错误", JOptionPane.WARNING_MESSAGE); } else {//密码不为空 sql="update user set pwd='"+password+"' where uid='"+user+"'";//更新密码的SQL if(DButil.update(sql)>0) {//密码修改成功 this.clear();//清空输入文本框 jlArray[2].setText("恭喜您!!!密码修改成功,请用新密码登陆"); } } } else { JOptionPane.showMessageDialog(this,"用户名或者密码错误!!!","错误", JOptionPane.WARNING_MESSAGE); this.clear();//清空输入文本框 } } } package Frame; import javax.swing.*; import javax.swing.table.DefaultTableModel; import db.DButil; import java.awt.*; import java.awt.event.*; import java.sql.*; import java.io.*; import java.util.*; public class MainFrame extends JFrame implements ActionListener,ItemListener { private String uname=null;//当前用户的名字 private boolean isInsert=false;//是否为添加默认为否 private JPanel topjp=new JPanel();//界面上半部分的JPanel容器 private JButton jba=new JButton("模糊查询"); private JButton jbs=new JButton("查找"); private JTextField jtfs=new JTextField();//按给出信息查找联系人信息 private JRadioButton jrbxm=new JRadioButton("按姓名查找",true); private JRadioButton jrbbh=new JRadioButton("按学号查找",false); private ButtonGroup bg=new ButtonGroup();//单选按钮组 private JPanel jpbr=new JPanel();//单选按钮面板 private JPanel jpyInfo=new JPanel();//右侧显示个人信息的面板 private JTextArea jta=new JTextArea(); // 模糊查询得到的信息文本区 private JLabel[] jlInfo={new JLabel("学号:"),new JLabel("姓名:"), new JLabel("性别:"),new JLabel("出生日期:"), new JLabel("电话号码:"),new JLabel("QQ:"), new JLabel("Email:"),new JLabel("地址:"), new JLabel("添加相片")}; private JButton[] jbInfo={new JButton("编辑"),new JButton("保存"), new JButton("浏览"), new JButton("上传"),}; private JLabel jlPhoto=new JLabel();//显示图像的JLabel控件 private JTextField[] jtfInfo=new JTextField[10]; private JTextField jtfPhoto=new JTextField();//添加照片到相册的路径 private JFileChooser jfcPic=new JFileChooser();//上传图像的文件选择器 private DefaultTableModel tableModel; private JTable table; //性别部分 private JRadioButton jrbMale=new JRadioButton("男",true); private JRadioButton jrbFemale=new JRadioButton("女"); private ButtonGroup bgGender=new ButtonGroup(); private JPanel jpGender=new JPanel();//单选按钮面板 private JLabel jlDetail=new JLabel();//右侧显示一幅图片的标签 private JSplitPane jspOuter=//上下分割的JSplitPane new JSplitPane(JSplitPane.VERTICAL_SPLIT,true); //系统托盘部分 private PopupMenu popup=new PopupMenu(); private SystemTray tray;//定义SystemTray成员变量 private TrayIcon trayIcon;//定义TrayIcon成员变量 private MenuItem exit=new MenuItem("退出程序");//定义菜单 public void initJps() {//界面上半部分的初始化 topjp.setLayout(null);//设置topjp布局管理器为null //设置按钮大小并添加到JPanel面板里 jba.setBounds(5,10,120,26); jba.addActionListener(this);//为模糊查询按钮注册事件监听器 topjp.add(jba); jbs.setBounds(130,10,80,26); jbs.addActionListener(this);//为查找按钮注册事件监听器 topjp.add(jbs);//添加按钮到topjp面板里 //设置jtfs文本框大小并添加到jps面板里 jtfs.setBounds(215,10,120,26); jtfs.addActionListener(this);//为文本框注册事件监听器 topjp.add(jtfs); //设置单选按钮大小和位置并添加到jpbr面板里同时添加到bg单选按钮组里 jrbxm.setBounds(5,3,50,26); jrbxm.addItemListener(this);//为单选按钮注册ItemEvent事件监听器 bg.add(jrbxm); jpbr.add(jrbxm); jrbbh.setBounds(60,3,50,26); jrbbh.addItemListener(this); bg.add(jrbbh); jpbr.add(jrbbh); jpbr.setBounds(360,10,200,26); topjp.add(jpbr); } public void initInfo() {//初始化信息界面 jpyInfo.setLayout(null);//设置布局管理器为空 jpyInfo.setBounds(50,50,380,360);//设置信息面板的大小和位置 jlPhoto.setBounds(220,10,150,170);//设置联系人图像JLabel的大小和位置 jlPhoto.setBorder(BorderFactory.createLineBorder(Color.BLACK));//将JLbel的边框线显现出来 jpyInfo.add(jlPhoto);//将显示联系人照片的JLabel添加到信息面板 tableModel=new DefaultTableModel(); Vector vector1 = new Vector(); DButil db = new DButil(); vector1.add("学号"); vector1.add("姓名"); vector1.add("性别"); vector1.add("出生日期"); vector1.add("电话号码"); vector1.add("QQ"); vector1.add("Email"); vector1.add("地址"); vector1.add("照片路径"); tableModel.setDataVector(null, vector1); System.out.print(123); table=new JTable(tableModel); //table.addMouseListener((MouseListener) this); table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF); JScrollPane js=new JScrollPane(table); //添加相片部分的控件 jtfPhoto.setBounds(80,250,200,26);//设置得到照片路径的文本框的大小和位置 jpyInfo.add(jtfPhoto);//将得到照片路径的文本框添加到信息面板 jbInfo[2].setBounds(285,250,80,26); jbInfo[2].addActionListener(this);//为添加照片的浏览按钮注册事件监听器 jpyInfo.add(jbInfo[2]); //上传按钮 jbInfo[3].setBounds(380,250,80,26); jbInfo[3].addActionListener(this);//为添加照片的浏览按钮注册事件监听器 jpyInfo.add(jbInfo[3]); for(int i=0;i<9;i++)//添加JLabel,并设置大小和位置 { jlInfo[i].setBounds(20,10+i*30,60,26); jpyInfo.add(jlInfo[i]); } for(int i=0;i<10;i++) {//初始化一些文本框 jtfInfo[i]=new JTextField(); } //学号 jtfInfo[0].setBounds(80,10,135,26); jpyInfo.add(jtfInfo[0]); //姓名 jtfInfo[1].setBounds(80,40,135,26); jpyInfo.add(jtfInfo[1]); //出生日期 jtfInfo[3].setBounds(80,100,135,26); jpyInfo.add(jtfInfo[3]); //电话号码 jtfInfo[4].setBounds(80,130,135,26); jpyInfo.add(jtfInfo[4]); //QQ jtfInfo[5].setBounds(80,160,135,26); jpyInfo.add(jtfInfo[5]); //Email jtfInfo[6].setBounds(80,190,135,26); jpyInfo.add(jtfInfo[6]); //地址文本框的添加 jtfInfo[7].setBounds(80,220,285,26); jpyInfo.add(jtfInfo[7]); //模糊查询信息文本区的添加 js.setBounds(0,350,600,100); jpyInfo.add(js); //编辑、保存按钮 jbInfo[0].setBounds(160,300,80,26); jbInfo[0].addActionListener(this); jpyInfo.add(jbInfo[0]); jbInfo[1].setBounds(260,300,80,26); jbInfo[1].addActionListener(this); jpyInfo.add(jbInfo[1]); //性别部分 jrbMale.setBounds(5,3,50,26); jrbMale.addItemListener(this); //为单选按钮注册ItemEvent事件监听器 bgGender.add(jrbMale); jpGender.add(jrbMale); jrbFemale.setBounds(60,3,50,26); jrbFemale.addItemListener(this); //为单选按钮注册ItemEvent事件监听器 bgGender.add(jrbFemale); jpGender.add(jrbFemale); jpGender.setBounds(60,70,125,26); jpyInfo.add(jpGender); } public void clearInfo()//清空信息面板 { for(int i=0;i<10;i++) { jtfInfo[i].setText("");//清空文本框 } jlPhoto.setIcon(null);//清空图像 } public void setjtaArea(String information){ if(information.isEmpty()){ JOptionPane.showMessageDialog(this,"所查用户不存在!!!","错误", JOptionPane.WARNING_MESSAGE); } else { jta.setText(information); } } public void setInfo(Vector<String> pInfo)//将信息向量设置到信息面板中 {//将信息向量按规则填到信息面板里 this.clearInfo(); if(pInfo.size()==0) { JOptionPane.showMessageDialog(this,"所查用户不存在!!!","错误", JOptionPane.WARNING_MESSAGE); } else { for(int i=0;i<2;i++) {//显示联系人编号和姓名 jtfInfo[i].setText(pInfo.get(i)); } if(pInfo.get(2).equals("男")) {//显示性别 jrbMale.setSelected(true); } else {//显示性别 jrbFemale.setSelected(true); } for(int i=3;i<9;i++) {//显示出生日期、电话号码和QQ jtfInfo[i].setText(pInfo.get(i)); } } } public Vector<String> getInfo()//从信息面板得到用户输入的信息 { Vector<String> pInfo=new Vector<String>(); pInfo.add(jtfInfo[0].getText().trim());//添加pid pInfo.add(jtfInfo[1].getText().trim());//添加pname String gender=jrbMale.isSelected()?"男":"女"; pInfo.add(gender);//添加性别 pInfo.add(jtfInfo[3].getText().trim());//出生日期 pInfo.add(jtfInfo[4].getText().trim());//电话号码 pInfo.add(jtfInfo[5].getText().trim());//QQ pInfo.add(jtfInfo[6].getText().trim());//Email pInfo.add(jtfInfo[7].getText().trim());//地址 String photoPath=jtfPhoto.getText().trim();//得到照片路径 pInfo.add(photoPath);//照片路径 return pInfo; } public void monitorSaveButton() //监听保存按钮的方法 { String sql=""; String pid=jtfInfo[0].getText().trim();//得到联系人的编号 String pname=jtfInfo[1].getText().trim();//得到联系人的姓名 String gender=jrbMale.isSelected()?"男":"女"; String s1=jtfInfo[3].getText().trim(); String s2=jtfInfo[4].getText().trim(); String s3=jtfInfo[5].getText().trim(); String s4=jtfInfo[6].getText().trim(); String s5=jtfInfo[7].getText().trim(); String s6=jtfPhoto.getText().trim(); String sqla="select * from contacts where pid='"+pid+"'";//判断此编号是否存在的SQL String sqlb="select * from contacts where pname='"+pname+"'";//判断此姓名是否存在的SQL boolean isIdExist=DButil.isExist(sqla);//得到编号是否存在 boolean isNameExist=DButil.isExist(sqlb);//得到姓名是否存在 if(!(pid.equals(" ")||pname.equals(" "))) { if(isIdExist||isNameExist){ JOptionPane.showMessageDialog(this,"联系人已存在"+ " , 添加联系人失败","错误",JOptionPane.WARNING_MESSAGE); } else { sql="insert into contacts values (?,?,?,?,?,?,?,?,?,?)"; String[] paras={pid,pname,gender,s1,s2,s3,s4,s5,s6,null}; if(DButil.update(sql,paras)>0){ JOptionPane.showMessageDialog(this,"联系人保存成功","提示", JOptionPane.INFORMATION_MESSAGE); } } } } public void setEditable(boolean Editable)//设置信息窗口是否可编辑 { jrbFemale.setEnabled(Editable);//设置性别是否可编辑 jrbMale.setEnabled(Editable);//设置性别是否可编辑 for(int i=0;i<8;i++) { jtfInfo[i].setEditable(Editable);//设置文本框是否可编辑 } } public void monitorSearchButton()//监听查找按钮的方法 { String name=jtfs.getText().trim(); String sql="";//声明查找字符串 if(name.equals("")) { JOptionPane.showMessageDialog(this,"查找条件不能为空!!!", "错误", JOptionPane.WARNING_MESSAGE); } else { if(jrbxm.isSelected()==true) {//按姓名查找 sql="select pid,pname,pgender,pbirthday,pnumber,pQQ,pemail,padress,pphoto from contacts where pname='"+name+"'"; this.setInfo(DButil.getPerInfo(sql));//设置信息面板为该联系人的信息 } else {//按编号查找 sql="select pid,pname,pgender,pbirthday,pnumber,pQQ,pemail,padress,pphoto from contacts where pid='"+name+"'"; this.setInfo(DButil.getPerInfo(sql));//设置信息面板为该联系人的信息 } } this.setEditable(false);//设置面板不可编辑 } public void monitorRandomSearchButton(String information){ //监听模糊查询按钮 String adress=jba.getText().trim(); String sql="";//声明查找字符串 if(adress.equals("")) { JOptionPane.showMessageDialog(this,"查找条件不能为空!!!", "错误", JOptionPane.WARNING_MESSAGE); } else{ sql="select pid,pname,pgender,pbirthday,pnumber,pQQ,pemail,padress,pphoto from contacts where padress like '%天河区%'"; } } public MainFrame(String uname) { //主窗体构造器 this.uname=uname;//设置用户名 this.initJps();//界面上半部分的搭建 this.initInfo(); jspOuter.setDividerLocation(46);//设置分割窗体JSplitPane的位置 jspOuter.setTopComponent(topjp);//设置窗体上半部分的控件 jspOuter.setBottomComponent(jpyInfo);//设置下半部分的控件 //设置窗体关闭按钮执行的动作 this.add(jspOuter); this.addWindowListener( new WindowAdapter() { @SuppressWarnings("deprecation") public void WindowClosing(WindowEvent e) { //将窗体隐藏 MainFrame.this.hide(); } } ); //设置主窗体的图标、标题、大小以及可见性 this.setResizable(false);//设置窗体不让调整大小 this.setTitle(uname+"的通讯录"); this.setBounds(420,80,618,550); this.setVisible(true); } public void actionPerformed(ActionEvent e) { if(e.getSource()==jbInfo[1]) {//保存按钮的监听 this.monitorSaveButton(); } else if(e.getSource()==jba) {//模糊查询按钮的监听 DButil db = new DButil(); Vector vector1 = new Vector(); vector1.add("学号"); vector1.add("姓名"); vector1.add("性别"); vector1.add("出生日期"); vector1.add("电话号码"); vector1.add("QQ"); vector1.add("Email"); vector1.add("地址"); vector1.add("照片路径"); String ad = jtfs.getText().trim(); tableModel.setDataVector(db.getData(ad),vector1); } else if(e.getSource()==jbInfo[2]) {//打开图像文件路径 jfcPic.showOpenDialog(this); if(jfcPic.getSelectedFile()!=null) { jtfPhoto.setText(""+jfcPic.getSelectedFile()); } } else if(e.getSource()==jbInfo[0]) {//编辑按钮的监听 this.setEditable(true);//设置信息面板可编辑 } else if(e.getSource()==jbs||e.getSource()==jtfs) {//查找,按按钮或者在文本框里敲回车 this.monitorSearchButton(); } } public void itemStateChanged(ItemEvent e) { } public static void main(String[] args){ } } package db; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.Statement; import java.util.Vector; public class DButil { private static String jdbcName="org.gjt.mm.mysql.Driver";//声明驱动类字符串 //声明数据库连接字符串 private static String dbUrl="jdbc:mysql://127.0.0.1:3306/maillist"; private static String dbUserName="root"; private static String dbPassword="admin"; private static Connection con=null;//声明数据库连接对象引用 private static Statement stat=null;//声明语句对象引用 private static PreparedStatement pstmt=null; private static ResultSet rs=null;//声明结果集对象引用 private static PreparedStatement psInsert=null;//声明预编译语句对象引用 public static Connection getConnection()//得到数据库连接的方法 { System.out.println("连接中.."); try { Class.forName(jdbcName);//加载驱动类 con=DriverManager.getConnection(dbUrl,dbUserName,dbPassword);//得到连接 System.out.println("成功连接"); } catch(Exception e){e.printStackTrace();} return con;//返回连接 } public static boolean check(String user,String pwd)//登陆验证 { boolean flag=false; try { con=DButil.getConnection();//得到数据库连接 stat=con.createStatement();//创建语句对象 rs=stat.executeQuery("select pwd from user where uid='"+user+"'"); rs.next(); String spwd=rs.getString(1);//得到密码 if(spwd.equals(pwd)) { flag=true;//密码匹配,登陆成功 } } catch(Exception e) { flag=false;//有任何异常发生,登陆失败 } finally{DButil.closeCon();}//关闭数据库连接 return flag; } //某条记录是否存在 public static boolean isExist(String sql) { boolean flag=false;//设置返回值 try { con=DButil.getConnection();//得到数据库连接 stat=con.createStatement();//创建语句对象 rs=stat.executeQuery(sql);//执行查询 if(rs.next()) { flag=true;//存在,设置返回值为true } } catch(Exception e) { e.printStackTrace(); flag=false;//发生任何异常,置返回结果为false } finally{DButil.closeCon();}//关闭数据库连接 return flag;//返回结果 } public static int update(String sql,String[] paras)//更新数据库 { int count=0;//声明返回值 try { con=DButil.getConnection(); pstmt=con.prepareStatement(sql); for(int i=0; i<paras.length;i++){ pstmt.setString(i+1, paras[i]); } count=pstmt.executeUpdate(); } catch(Exception e) { e.printStackTrace(); count=-1;//更新失败返回值为-1 } finally{DButil.closeCon();}//关闭数据库连接 return count;//返回结果 } public static int update(String sql)//更新数据库 { int count=0;//声明返回值 try { con=DButil.getConnection(); stat=con.createStatement(); count=stat.executeUpdate(sql);//执行更新 } catch(Exception e) { e.printStackTrace(); count=-1;//更新失败返回值为-1 } finally{DButil.closeCon();}//关闭数据库连接 return count;//返回结果 } //====================添加联系人================================= public static String insertPerson(String uid,Vector<String> pInfo) { String isPathNull="isNotNull";//传过来的图像是不是合法,默认不为空 try{ con=getConnection();//得到数据库连接 if(pInfo.get(8).equals("")||pInfo.get(8)==null) {//照片路径为空,则不插入图像 psInsert=con.prepareStatement("insert into contacts(pid,pname,pgender,pbirthday,pnumber,"+ "pQQ,pemail,padress,uid)"+ "values(?,?,?,?,?,?,?,?,?)"); } else {//照片路径不为空,则插入图像 psInsert=con.prepareStatement("insert into contacts(pid,pname,pgender,pbirthday,pnumber,"+ "pQQ,pemail,padress,pphoto,uid)"+ "values(?,?,?,?,?,?,?,?,?,?,?)" ); File f=new File(pInfo.get(8));//获取选取的图片文件 byte[] b=new byte[(int)f.length()];//创建存储图片数据的数组 FileInputStream fin=new FileInputStream(f); fin.read(b);fin.close();//读取文件存于byte数组中并关闭输入流 psInsert.setBytes(11,b);//设置pphoto参数的数据 } for(int i=0;i<8;i++) {//设置公共信息 psInsert.setString(i+1,pInfo.get(i)); } psInsert.setString(10,uid);//所属用户 psInsert.execute();psInsert.close();//执行更新并关闭语句 } catch(FileNotFoundException fnfe){isPathNull="isNull";}//图片路径不对 catch(Exception e){e.printStackTrace();} finally{DButil.closeCon();}//关闭数据库连接 return isPathNull; } public static String updatePerson(String uid,Vector<String> pInfo){ String isPathNull="isNotNull";//传过来的path是不是合法 try{ con=getConnection(); if(pInfo.get(9).equals("")||pInfo.get(9)==null) {//更新时候,如果照片路径为空,则不更新图像 psInsert=con.prepareStatement("update contacts set pname=?,pgender=?,birthday=?,pnumber=?,"+ "pQQ=?,pemail=?,padress=?,pphoto=?,uid=? where pid='"+pInfo.get(0).trim()+"'"); } else {//如果照片路径不为空,则更新图像 psInsert=con.prepareStatement("update contacts set pname=?,pgender=?,page=?,pnumber=?,"+ "pemail=?,pgroup=?,ppostalcode=?,padress=?,uid=?,pphoto=? where pid='"+pInfo.get(0).trim()+"'"); File f=new File(pInfo.get(9));//获取选取的图片文件 byte[] b=new byte[(int)f.length()];//创建存储图片数据的数组 FileInputStream fin=new FileInputStream(f); fin.read(b);fin.close();//读取文件存于byte数组中并关闭输入流 psInsert.setBytes(10,b); } for(int i=1;i<8;i++){//设置公共的信息部分 psInsert.setString(i,pInfo.get(i)); } psInsert.setString(9,uid);//所属用户 psInsert.execute();psInsert.close();//执行更新并关闭语句 } catch(FileNotFoundException fnfe){isPathNull="isNull";}//路径不合法 catch(Exception e){e.printStackTrace();} finally{DButil.closeCon();}//关闭连接 return isPathNull; } public Vector getData(String ad){ Vector vector=new Vector(); try { //陈述对象 con=getConnection();//得到数据库连接 stat=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);//创建语句对象 rs=stat.executeQuery("select * from contacts where padress LIKE '%"+ad+"%'"); ResultSetMetaData rm=rs.getMetaData(); //循环打印出数据库表中数据 int n=rm.getColumnCount(); while(rs.next()){ Vector ve=new Vector(); for(int i=1;i<n+1;i++){ String s=rs.getString(i); ve.add(s); } vector.add(ve);//Vector对象接收表中数据 } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{if(rs!=null){ try { rs.close();//关闭结果集 } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } if(stat!=null){ try { stat.close();//关闭陈述对象 } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } if(con!=null){ try { con.close();//关闭连接 } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } } return vector; } public static Vector<String> getPerInfo(String sql)//得到联系人信息 { Vector<String> pInfo=new Vector<String>(); try { con=getConnection();//得到数据库连接 stat=con.createStatement();//创建语句对象 rs=stat.executeQuery(sql);//执行查询 while(rs.next()) { for(int i=1;i<10;i++) { System.out.println(rs.getString(i)); pInfo.add(rs.getString(i));//将联系人信息添加到返回向量 } } } catch(Exception e) { e.printStackTrace(); } finally{DButil.closeCon();}//关闭数据库连接 return pInfo;//返回信息集合 } public static void closeCon()//关闭数据库连接的方法 { try { if(rs!=null){rs.close(); rs=null;}//如果结果集不为空关闭结果集并赋值null if(stat!=null){stat.close(); stat=null;}//如果语句对象不为空关闭语句对象并赋值null if(con!=null){con.close(); con=null;}//如果连接不为空关闭连接并赋值null } catch(Exception e){e.printStackTrace();} } public static void main(String[] args){ DButil DB=new DButil(); System.out.println(DB.getConnection()); } } }
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
程序员需要了解的硬核知识之汇编语言(一)
之前的系列文章从 CPU 和内存方面简单介绍了一下汇编语言,但是还没有系统的了解一下汇编语言,汇编语言作为第二代计算机语言,会用一些容易理解和记忆的字母,单词来代替一个特定的指令,作为高级编程语言的基础,有必要系统的了解一下汇编语言,那么本篇文章希望大家跟我一起来了解一下汇编语言。 汇编语言和本地代码 我们在之前的文章中探讨过,计算机 CPU 只能运行本地代码(机器语言)程序,用 C 语言等高级语...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
java知识体系整理,学会了,月入过万不是梦
欢迎关注个人公众号:程序猿学社 前言: 一转眼,工作4年了,正式写博客也有一年多了,之前就有整理和总结的习惯,只是都记录在有道云,感觉知识点都是很凌乱,花时间系统整理下,该文会一直同步更新,有不足之处,希望各位同行指正,既然,选择做技术这行,就得有分享的精神,而不是抱着别人会超过你的心理。希望各位博友们互相交流,互相进步。 目录 java系统学习 小白也能...
2020年去一线大厂面试先过SSM框架源码这一关!
SSM框架介绍 (1)持久层(Mybatis):Dao层(mapper) DAO层:DAO层主要是做数据持久层的工作,负责与数据库进行联络的一些任务都封装在此。 DAO层的设计首先是设计DAO的接口。 然后在Spring的配置文件中定义此接口的实现类。 然后就可在模块中调用此接口来进行数据业务的处理,而不用关心此接口的具体实现类是哪个类,显得结构非常清晰。 DAO层的数据源配置,以及有...
教你一键快速生成后台代码,这样和测试小姐姐聊天的时间又多了
教你一键快速生成后台代码,咋们作为开发人员,应该把时间精力放在业务逻辑的实现上面。
Java程序员必备基础:内部类解析
前言 整理了一下内部类的相关知识,算是比较全,比较基础的,希望大家一起学习进步。 一、什么是内部类? 在Java中,可以将一个类的定义放在另外一个类的定义内部,这就是内部类。内部类本身就是类的一个属性,与其他属性 定义方式一致。 一个内部类的例子: public class Outer { private int radius = 1; public static int co...
北漂女程序员工作6年面试JD要价28K
写在开头: 上周面试了一位女程序员,上午10::30来我们部门面试,2B哥接待了她. 大家来看看她的简历: 个人简历 个人技能: ● 熟悉spring mvc 、spring、mybatis 等框架 ● 熟悉 redis 、rocketmq、dubbo、zookeeper、netty 、nginx、tomcat、mysql。 ● 阅读过juc 中的线程池、锁的源码以及netty 中的主从多线程...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
人脸生成黑科技:实现人脸转变特效,让人脸自动戴墨镜
上一节我们通过VAE网络完成了人脸生成效果。VAE网络一个特性是会把人脸编码成一个含有200个分量的向量,反过来说在特定分布范围内的含有200个分量的向量就对应一张人脸。由于向量之间可以进行运算,这就意味着我们把两张不同人脸A,B分布转换成两个不同向量z_A,z_B,然后我们使用向量运算例如z_AB = z_A *(1 - alpha) + z_B *alpha,就能将两个向量以一定比例合成一个新...
Java9到Java13各版本新特性代码全部详解(全网独家原创)
Java现在已经发展到了Java13了(正式版本),相信很多朋友还对各个版本还不是很熟悉,这里面专门把Java9到Java13各个版本的一些新特性做了一些详细讲解。我在网上也找了很多,但基本都是官方文档的CV,没有任何代码演示,而且官方的示例代码也不是很好找得到,官方API目前还是Java10,官方文档真是坑啊。所以我在这里专门写了一篇文章,主要针对平时开发与有关的功能Java9到Java13各...
一文带你看清 HTTP 所有概念
上一篇文章我们大致讲解了一下 HTTP 的基本特征和使用,大家反响很不错,那么本篇文章我们就来深究一下 HTTP 的特性。我们接着上篇文章没有说完的 HTTP 标头继续来介绍(此篇文章会介绍所有标头的概念,但没有深入底层) HTTP 标头 先来回顾一下 HTTP1.1 标头都有哪几种 HTTP 1.1 的标头主要分为四种,通用标头、实体标头、请求标头、响应标头,现在我们来对这几种标头进行介绍 通用...
春节不出门!这三款超好评编程游戏,好玩到停不下来
By 超神经场景描述:春节马上就要来临,在这个假期里,怎么能让自己放松,又不至于生疏了自己的老本行?不妨来玩一下编程向的小游戏吧,超神经在此整理了三款好玩有趣又有深度的游戏,快看看是不是...
2020年JVM面试题吐血整理【过年必看】
2B哥今天给大家带来点jvm相关的面试题,希望小伙伴们可以在春节这段时间好好复习下。看完这篇JVM面试基本没问题。95%内容都在在,更多的面试题可以关注公众号(微信搜:java2b) 1、内存模型以及分区,需要详细到每个区放什么。 JVM 分为堆区和栈区,还有方法区,初始化的对象放在堆里面,引用放在栈里面, class 类信息常量池(static 常量和 static 变量)等放在方法区 new...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。
Web前端开发高级前端技术(高级开发程序篇)
(给达达前端加星标,提升前端技能)内容有点多,也请你静下来,慢阅读,今后多多关照。说到web前端开发高级,必须要掌握的是HTML和css代码的优化,前端优化很重要,这是成功你进阶的道路上...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问