java中Jtable显示数据库查询到的数据 10C

怎么在Jtable中显示从数据库中查询到的结果集,用什么方法,新手请教

3个回答

对于JTable,JTree等Swing控件,都有一个对应的Model用来存储数据,JTable对应的有一个DefaultTableModel。 
DefaultTableModel model = new DefaultTableModel(datas,columnNames); 

JTable jTable = new JTable(model);

DefaultTableModel这个类支持使用数组Object[][]或者是Vector将数据传入,而你想改变JTable中显示的内容,只需要使用方法setDataVector()重新设置model的值即可,JTable会自动刷新。
当然,前提是你改变文本框的内容之后会有一个事件触发(可以是按钮点击),然后,查询数据,并将新的数据传入JTable的model中。

一种是像楼上说的构建一个model,然后绑定到JTable去,就自然显示数据了,另一种方式就是JTable新增行,然后再对每个单元格赋值,当然前提是从数据拿到数据到内存变量里。希望对你有点帮助

先将数据库中的数据查询出来,组成数据源,将其作为JTable的数据源,然后用swing的图形界面进行展示。
JTable展示数据的一个简单例子的实例代码:

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

public class SimpleTable {
    public SimpleTable() {
        JFrame f = new JFrame();
        Object[][] playerInfo = { { "阿呆", new Integer(66), new Integer(32), new Integer(98), new Boolean(false) },
                { "阿呆", new Integer(82), new Integer(69), new Integer(128), new Boolean(true) }, };
        String[] Names = { "姓名", "语文", "数学", "总分", "及格" };
        JTable table = new JTable(playerInfo, Names);
        table.setPreferredScrollableViewportSize(new Dimension(550, 30));
        JScrollPane scrollPane = new JScrollPane(table);
        f.getContentPane().add(scrollPane, BorderLayout.CENTER);
        f.setTitle("Simple Table");
        f.pack();
        f.show();

        f.addWindowListener(new WindowAdapter() {
            public void windowClosing(WindowEvent e) {
                System.exit(0);
            }
        });
    }

    public static void main(String[] args) {
        SimpleTable b = new SimpleTable();
    }
}

原文链接地址:http://www.cnblogs.com/mailingfeng/archive/2011/12/28/2304289.html

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
jtable显示数据库中的数据,为什么数据显示不完全,第一列列名也没有

![图片说明](https://img-ask.csdn.net/upload/201512/02/1449049119_861396.jpg) ![图片说明](https://img-ask.csdn.net/upload/201512/02/1449049183_545892.png) ![图片说明](https://img-ask.csdn.net/upload/201512/02/1449049145_132862.png)

如何利用jtable删除数据库一条信息

public class userinfo { private String USERACCOUNT; private String USERNAME; private String NICKNAME; private String PASSWORD; private int SEX; private String PHONE; private String EMAIL; private String REGION; private String MYINFO; private String HEADPIC; private int DEPTID; public userinfo(){} public userinfo(String USERACCOUNT,String USERNAME,String NICKNAME,String PASSWORD,int SEX,String PHONE, String EMAIL, String REGION,String MYINFO,String HEADPIC,int DEPTID) { this.USERACCOUNT=USERACCOUNT; this.USERNAME=USERNAME; this.NICKNAME=NICKNAME; this.PASSWORD=PASSWORD; this.SEX=SEX; this.PHONE=PHONE; this.EMAIL=EMAIL; this.REGION=REGION; this.MYINFO=MYINFO; this.HEADPIC=HEADPIC; this.DEPTID=DEPTID; } public String getUSERACCOUNT(){ return USERACCOUNT; } public void setUSERACCOUNT(String USERACCOUNT){ this.USERACCOUNT=USERACCOUNT; } public String getUSERNAME(){ return USERNAME; } public void setUSERNAME(String USERNAME){ this.USERNAME=USERNAME; } public String getNICKNAME(){ return NICKNAME; } public void setNICKNAME(String NICKNAME){ this.NICKNAME=NICKNAME; } public String getPASSWORD(){ return PASSWORD; } public void setPASSWORD(String PASSWORD){ this.PASSWORD=PASSWORD; } public int getSEX(){ return SEX; } public void setSEX(int SEX){ this.SEX=SEX; } public String getPHONE(){ return PHONE; } public void setPHONE(String PHONE){ this.PHONE=PHONE; } public String getEMAIL(){ return EMAIL; } public void setEMAIL(String EMAIL){ this.EMAIL=EMAIL; } public String getREGION(){ return REGION; } public void setREGION( String REGION){ this.REGION=REGION; } public String getMYINFO(){ return MYINFO; } public void setMYINFO(String MYINFO){ this.MYINFO=MYINFO; } public String getHEADPIC(){ return HEADPIC; } public void setHEADPIC(String HEADPIC){ this.HEADPIC=HEADPIC; } public int getDEPTID(){ return DEPTID; } public void setDEPTID(int DEPTID){ this.DEPTID=DEPTID; } void show(){ System.out.print( USERACCOUNT+" "+USERNAME+" "+NICKNAME+" "+PASSWORD+" "+SEX+" "+PHONE+" "+ EMAIL+" "+REGION+" "+MYINFO+" "+HEADPIC+" "+DEPTID+" "+"\n"); } } public void delete(userinfo u){ Connection con=BaseDAO.getConnection(); try{ String sql ="delete from t_UserInfo where USERACCOUNT=? and USERNAME=? and NICKNAME=? and PASSWORD=? and SEX=? and PHONE=? and EMAIL=? and REGION=? and MYINFO=? and HEADPIC=? and DEPTID=? "; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1,u.getUSERACCOUNT() ); pstmt.setString(2, u.getUSERNAME()); pstmt.setString(3, u.getNICKNAME()); pstmt.setString(4, u.getPASSWORD()); pstmt.setInt(5, u.getSEX()); pstmt.setString(6, u.getPHONE()); pstmt.setString(7, u.getEMAIL()); pstmt.setString(8, u.getREGION()); pstmt.setString(9, u.getMYINFO()); pstmt.setString(10, u.getHEADPIC()); pstmt.setInt(11, u.getDEPTID()); int num=pstmt.executeUpdate(); if(num>0){ System.out.println("删除成功"); }else{ System.out.println("删除失败"); } BaseDAO.closeStatement(pstmt); BaseDAO.closeConnection(con); }catch(Exception e){ e.printStackTrace(); } } private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) { // TODO add your handling code here: } 在jbutton2中添加什么样的代码才能实现鼠标选中jtable中的一行的时候点击删除,直接删除,而且连同数据库的一起删除![图片说明](https://img-ask.csdn.net/upload/201601/05/1451984879_753791.png)

java连接数据库 更新JTable问题

//下面是我的table class Store_table { Object data[][]; Object name[]={"商品编号","商品名称","价格","上架日期","保质日期","库存"}; Store_table(String bq) { String url = "jdbc:sqlserver://127.0.0.1:1433;databaseName=Store;IntegratedSecurity=True";// // Declare the JDBC objects. Connection con=null; Statement sql=null; ResultSet rs=null; try { // Establish the connection. Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); con = DriverManager.getConnection(url); sql = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY); rs = sql.executeQuery("SELECT * FROM 仓库 where 标签='"+bq+"'"); rs.last(); data=new Object[rs.getRow()][6]; // Iterate through the data in the result set and display it. int i=0; rs.beforeFirst(); while (rs.next()) { long number=rs.getLong("商品编号"); String name=rs.getString("商品名称"); float price=rs.getFloat("价格"); Date date=rs.getDate("上架日期"); int staydate=rs.getInt("保质日期"); int repertory=rs.getInt("库存"); data[i][0]=number; data[i][1]=name; data[i][2]=price; data[i][3]=date; data[i][4]=staydate; data[i][5]=repertory; i++; } } // Handle any errors that may have occurred. catch (Exception e) { e.printStackTrace(); } finally { if (rs != null) try { rs.close(); } catch (Exception e) { } if (sql != null) try { sql.close(); } catch (Exception e) { } if (con != null) try { con.close(); } catch (Exception e) { } } } } //我用JComboBox调用和更新JTable public void actionPerformed(ActionEvent arg0) { String a=comboBox.getSelectedItem().toString(); store=new Store_table(a); //把store放进JTable ta=new JTable(store.data,store.name) { public boolean isCellEditable(int row, int column) {return false;};//设置列表数据不能修改 }; //把ta列表放进滚动列表 ta.setModel(model); JScrollPane jsp=new JScrollPane(ta); //JScrollPane jsp=new JScrollPane(store); //getContentPane().add(jsp,BorderLayout.CENTER); ta.setBackground(Color.ORANGE); jsp.setBackground(Color.GRAY); //jsp.setBackground(Color.ORANGE); contentPane.add(jsp); jsp.setBounds(0, 41, 743, 252); } }); ``` ``` 怎么让JTable在JComboBox改动的时候更新呢? 据说需要setModel 再repaint 再updateUI 可是具体怎么做呢?

想要用java 查询sql server数据库中的信息显示到JTable中,可以举个例子吗?

新手想写个简单的学生查询界面 举简单的例子说明一下怎么把sql语言写在java程序里 感激感激!

java如何刷新JTable显示内容

在第一次取回数据库内容并显示后 再取得另一些数据刷新表格内容无法显示 用frame.repaint()并没有用 该怎么办

netbeans上jtable绑定arraylist后jtable不显示值

是这样的 我建了一个数据库,里面有一张表,表里面有记录,我写的java程序建了一个类p,这个类p封装了与表里字段对应的属性,然后,我又新建了一个类pl,这个类pl里面封装了一个arraylist,里面存的就是类p的对象。 我弄了一个面板,面板里面有一个jtable,我在netbeans上把类pl拖到面板上做组件,然后把它和jtable绑定(类pl中封装的arraylist是绑定源),但问题就是运行后jtable并不显示值。 我DEBUG过,从查询开始,到把pl的对象传入jtable所在的类的对象中,(我是先用jtable所在的类的静态方法把值传给一个静态成员),然后把静态成员的值传给绑定源,然后再initComponent。问题就在这,initComponent前,绑定源pl已经有值了,也就是说传进来了,然后,initComponent后绑定源的值就没了,为空,然后debug也显示jtable的值有变化,但是最后jtable还是没有显示。 代码很长,要贴出来也只能贴相关部分的,见谅,然后没有C币,见谅。 另外说下,我当时测的时候,查询结果只有一条记录,然后记录也有为空的地方,还有就是,pl作为一个javabean组件,里面原本应该是 setArraylist(Arraylist arraylist){this.arraylist = arraylist;}的,但是后来被我改了,传的参数变成了arraylist存的p类的对象了,不知道有没有影响。

jtable如何显示List<Map>中的数据???

从数据库查出来的数据放在List<Map>中,现在要显示在jtable中,不知道该如何显示了?还要考虑修改单元格中的数据后,再把List<Map>传回数据库... TableMode中该如何写?有没有做过的,提个意见... 我的数据显示后,与表头不对应了...

java界面里怎么将从数据库中按条件查询的结果显示在界面里。。急求

AirSelectpage.java: import javax.swing.*; import java.awt.event.*; import java.sql.*; public class AirSelectpage extends JFrame implements ActionListener{ /** * */ private static final long serialVersionUID = -3695058594377827316L; JLabel l; JTextField t=new JTextField(15); JButton jok; JButton jBack; String driverName="com.microsoft.sqlserver.jdbc.SQLServerDriver"; String url="jdbc:sqlserver://localhost:1433; DatabaseName=AirTicket"; String USER="sa"; String PASSWORD="123"; public void asPage(){ JPanel p; p=new JPanel(); l=new JLabel("请输入航班号:"); jok=new JButton("确认"); jBack=new JButton("返回"); p.add(l);p.add(t);p.add(jok);p.add(jBack); add(p); setSize(600,400); setLocation(400,200); setVisible(true); setDefaultCloseOperation(EXIT_ON_CLOSE); jok.addActionListener(this); jBack.addActionListener(this); } private Connection con; private Statement stmt; private ResultSet rs; public void actionPerformed(ActionEvent e){ if(e.getSource()==jok){ String airnumber=t.getText().trim(); if(airnumber.equals("")){ JOptionPane.showMessageDialog(this,"对不起,请输入航班号!","错误!",JOptionPane.ERROR_MESSAGE); } else{ try{ Class.forName(driverName); con=DriverManager.getConnection(url,USER,PASSWORD); String sql="select 旅客.航班号,座位号,姓名,旅客.票号,票价,起点,终点,起飞时间,到达时间 from 旅客,航班,机票 where 航班.航班号=旅客.航班号 and 旅客.票号=机票.票号 and 旅客.航班号='"+airnumber+"'";//执行的sql语句 stmt=con.createStatement(); rs=stmt.executeQuery(sql); if(rs.next()){ new AirInformation(); } else{ JOptionPane.showMessageDialog(this,"航班号不存在,请重新输入!","错误!",JOptionPane.ERROR_MESSAGE); } } catch(ClassNotFoundException ex){ ex.printStackTrace(); } catch(SQLException ex){ ex.printStackTrace(); } } } if(e.getSource()==jBack){ Welpage wel=new Welpage(); wel.wPage(null); this.dispose(); } } } AirInformation.java: import javax.swing.*; import java.sql.*; public class AirInformation extends JFrame{ /** * */ private static final long serialVersionUID = -2888751890568230979L; // 定义组件 private JScrollPane scpDemo; private JTable tabDemo; // 构造方法 public AirInformation() throws SQLException{ // 窗体的相关属性的定义 super("JTable数据绑定示例"); this.setSize(1200,900); this.setLayout(null); this.setLocation(100,50); // 创建组件 this.scpDemo = new JScrollPane(); this.scpDemo.setBounds(10,50,1050,300); // 将组件加入到窗体中 add(this.scpDemo); // 显示窗体 this.setVisible(true); try{ // 获得连接 Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");} catch(Exception e){} Connection conn = DriverManager.getConnection("jdbc:sqlserver://localhost:1433; DatabaseName=AirTicket","sa","123"); // 建立查询条件 String sql = "select 旅客.航班号,座位号,姓名,旅客.票号,票价,起点,终点,起飞时间,到达时间 from 旅客,航班,机票 where 航班.航班号=旅客.航班号 and 旅客.票号=机票.票号 and 旅客.航班号='A3001'"; PreparedStatement pstm = conn.prepareStatement(sql); // 执行查询 ResultSet rs = pstm.executeQuery(); // 计算有多少条记录 int count = 0; while(rs.next()){ count++; } rs=pstm.executeQuery(); // 将查询获得的记录数据,转换成适合生成JTable的数据形式 Object[][] info = new Object[count][9]; count = 0; while(rs.next()){ info[count][0] = rs.getString("航班号"); info[count][1] = rs.getString("座位号"); info[count][2] = rs.getString("姓名"); info[count][3] = rs.getString("票号"); info[count][4] = Integer.valueOf(rs.getInt("票价")); info[count][5] = rs.getString("起点"); info[count][6] = rs.getString("终点"); info[count][7] = rs.getTimestamp("起飞时间"); info[count][8] = rs.getTimestamp("到达时间"); count++; } // 定义表头 String[] title = {"航班号","座位号","姓名","票号","票价","起点","终点","起飞时间","到达时间"}; // 创建JTable this.tabDemo = new JTable(info,title); this.tabDemo.getTableHeader(); // 将JTable加入到带滚动条的面板中 this.scpDemo.getViewport().add(tabDemo); } } 当航班号为A3001 A3002。。。时,是可以显示出来的 当航班号为t.getText()时,就一片空白,什么都显示不了

为什么java显示数据库连接成功但是却显示不出表

![图片说明](https://img-ask.csdn.net/upload/201911/19/1574175022_893822.png) 代码如下: ``` Vector rowData,columnNames; columnNames = new Vector(); rowData = new Vector(); columnNames.add("学号"); columnNames.add("学生姓名"); columnNames.add("性别"); columnNames.add("出生日期"); columnNames.add("班级"); columnNames.add("学院"); columnNames.add("年级"); try { connect_sql consql = new connect_sql();//创建对象 Connection conn = consql.getConnection();//链接数据库 try { Statement sta = conn.createStatement();//创建sql语句的接口 ResultSet result = sta.executeQuery("select*from student");//result接受语句选中student表 ResultSetMetaData metaData = result.getMetaData();//接受result中的元数据 while(result.next()) { Vector hang = new Vector(); int id = result.getInt(1); String name = result.getString(2); String sex = result.getString(3); String brithday = result.getString(4); String className = result.getString(5); String insititute = result.getString(6); int grade = result.getInt(7); hang.add(id);hang.add(name);hang.add(sex);hang.add(brithday); hang.add(className);hang.add(insititute);hang.add(grade); rowData.add(hang); } } catch(Exception e) { e.printStackTrace(); conn.close(); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } DefaultTableModel model = new DefaultTableModel(rowData,columnNames); JTable jTable = new JTable(model);//创建表格组件 jTable.setAutoResizeMode(JTable.AUTO_RESIZE_SUBSEQUENT_COLUMNS); jsp.add(jTable); ```

java编程中Jtable如何做数据库查询分页显示的功能

最近做的项目需要使用swing来开发,用Jtable来显示数据,在网上没有看到 相关的介绍,应该是要把Jtable和分页按钮独立封装成一个组件, 有没有哪位大神做过类似的demo啊。

通过JAVA按钮事件更新数据库内数据,同时动态的刷新窗口内显示的数据

public class Buy extends JPanel implements ActionListener { Connection conn; Statement stmt; ResultSet rs; String DBDRIVER ="com.microsoft.sqlserver.jdbc.SQLServerDriver"; String dbURL = "jdbc:sqlserver://localhost:1433;DatabaseName=高铁动车售票系统"; String userName = "sa"; String userPwd = "123456"; private JSplitPane jsp1 =new JSplitPane(JSplitPane.VERTICAL_SPLIT,true); private JPanel jp2 =new JPanel(); private JButton jb2 =new JButton("确定"); private JLabel jl3 =new JLabel("请输入要买的车票编号:"); private JTextField jtxt3 =new JTextField(); public void connDB() { //连接数据库方法 try { conn=DriverManager.getConnection(dbURL,userName,userPwd); stmt=conn.createStatement(); }catch(Exception e) { e.printStackTrace(); System.out.println("连接失败!"); } } public void closeDB() { //关闭数据库方法 try { rs.close(); stmt.close(); conn.close(); }catch(Exception e) { e.printStackTrace(); } } public boolean searchticketno(String str) { boolean x=false; this.connDB(); try { rs=stmt.executeQuery("select * from 车票信息表"); while(rs.next()) { if(rs.getString("车票编号").trim().equals(str)) { //在java中,判断字符串是否相同,一定要使用equals函数!!!!!!!! x=true; } } }catch(Exception e) { e.printStackTrace(); } return x; } Vector<String> head =new Vector<String>(); { head.add("车票编号"); head.add("车次"); head.add("座位等级"); head.add("票价"); head.add("座位号"); head.add("出发站"); head.add("目的站"); head.add("出发时间"); head.add("到站时间"); head.add("余票数量"); } DataBase db= new DataBase(); Vector row =db.getdata(); DefaultTableModel dtm =new DefaultTableModel(row,head); JTable jt =new JTable(dtm); JScrollPane jspn =new JScrollPane(jt); public Buy() { this.setLayout(new GridLayout(1,1)); jsp1.setTopComponent(jp2); jsp1.setBottomComponent(jspn); jsp1.setDividerLocation(80); jsp1.setDividerSize(4); jp2.setLayout(null); jb2.setBounds(400,30,60,20); jp2.add(jb2); jb2.addActionListener(this); jl3.setBounds(60, 30, 160, 20); jp2.add(jl3); jtxt3.setBounds(200, 30, 100, 20); jp2.add(jtxt3); this.add(jsp1); this.setBounds(10, 10, 800, 600); this.setVisible(true); } public void actionPerformed(ActionEvent e) { if(e.getSource()==jb2) { //判定文本框内容,车票信息改变,余票数量-1,乘客购票成功 if(!searchticketno(jtxt3.getText().trim())) { JOptionPane.showMessageDialog(null,"对不起,车票编号不存在!请重新输入!"); jtxt3.setText(""); } else { //未实现的功能 } } } } ``` public class DataBase { private final static String URL = "jdbc:sqlserver://localhost:1433; DatabaseName=高铁动车售票系统"; private static final String USER="sa"; private static final String PASSWORD="123456"; private Vector<Object> row =new Vector() ; private Vector rowsdata =new Vector(); private static Connection conn=null; //静态代码块(将加载驱动、连接数据库放入静态块中) static{ try { //1.加载驱动程序 Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); //2.获得数据库的连接 conn=(Connection)DriverManager.getConnection(URL,USER,PASSWORD); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } //对外提供一个方法来获取数据库连接 public static Connection getConnection(){ return conn; } //测试用例 // public static void main(String[] args) throws Exception // { // // //3.通过数据库的连接操作数据库,实现增删改查 // Statement stmt = conn.createStatement(); // //ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句 ,返回一个结果集(ResultSet)对象。 // ResultSet rs = stmt.executeQuery("select 车票编号,车次,座位等第,票价,座位号,出发站,目的站,出发时间,到站时间,余票数量 from 车票信息表"); // while(rs.next()){//如果对象中有数据,就会循环打印出来 // System.out.println(rs.getString("车票编号")+","+rs.getString("车次")+","+rs.getString("座位等第")+","+rs.getString("票价")+","+rs.getString("座位号")+","+rs.getString("出发站")+","+rs.getString("目的站")+","+rs.getString("出发时间")+","+rs.getString("到站时间")+","+rs.getString("余票数量")); // } // } public Vector getdata() { try{ //3.通过数据库的连接操作数据库,实现增删改查 Statement stmt = conn.createStatement(); //ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句 ,返回一个结果集(ResultSet)对象。 ResultSet rs = stmt.executeQuery("select * from 车票信息表"); while(rs.next()){//如果对象中有数据,就会循环打印出来 row.add(rs.getString("车票编号")); row.add(rs.getString("车次")); row.add(rs.getString("座位等第")); row.add(rs.getString("票价")); row.add(rs.getString("座位号")); row.add(rs.getString("出发站")); row.add(rs.getString("目的站")); row.add(rs.getString("出发时间")); row.add(rs.getString("到站时间")); row.add(rs.getString("余票数量")); rowsdata.add(row); row=new Vector(); }}catch(SQLException e) { e.printStackTrace(); return null; } return rowsdata; } } ``` ![图片说明](https://img-ask.csdn.net/upload/201906/25/1561473164_888693.png) ``` 希望最后的结果就是在文本框内输入车票编号,然后检索数据库,有对应车票编码的车票就显示购票成功,同时刷新当前显示的数据表,更新余票数量。 ```

如何通过JTable组建以表格形式显示数据库内容——使用Mybatis

我正在学习Mybatis,想尝试通过JTable组建以表格形式显示数据库内容,按照原生JDBC的方法,需要创建一个tablemodel ``` public class ResultSetTableModel extends AbstractTableModel ``` 然后实现getColumnClass,getColumnCount,getColumnName,getRowCount, getValueAt方法,但是需要用到Statement、ResultSet等接口并调用一些方法。 但是我不熟悉使用Mybatis框架来实现这个功能,应该怎么实现?

java swing的JTable中的某一列加入下拉复选框,选择的多个数据显示在单元格

java swing的JTable中的某一列加入下拉复选框, 点击单元格,出现下拉框,选择的多个数据显示在单元格? 效果图如下所示: ![图片说明](https://img-ask.csdn.net/upload/201901/25/1548384695_331151.png)

想将数据库的数据调入容器中但显示空指针。所以想问下该怎么解决

public class Wenben extends JFrame implements TableModelListener{ JTable table; Vector<Vector>hang; Vector lie;//fang 4ge Vector h1; //数据调用 public void dy(){ lie.add("ID"); lie.add("name"); lie.add("time"); lie.add("money"); String url = "jdbc:odbc:uaccess";// 根据数据源,设置数据库URL String userName = "sh";// 登录数据库用户名 String password = "sh";// 用户密码 Connection conn = null;// 声明Connection对象 Statement stmt = null;// 声明Statement对象 try { // 加载JDBC-ODBC驱动程序 Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // 创建连接 conn = DriverManager.getConnection(url);//("jdbc:odbc:driver={microsoft access driver (*.mdb)};dbq=d:/user/2011级计算机系学生信息.mdb"); // 通过Connection对象,创建Statement对象 stmt = conn.createStatement(); // 执行查询"年龄为20岁的学生信息"的SQL语句,得到结果集 ResultSet rs = stmt.executeQuery("select * from 员工信息表 "); // 通过循环输出相关学生信息 /* System.out.println("学号" + "\t\t姓名" + "\t性别" + "\t出生日期"+ "\t年龄" + "\t专业方向" + "\t\t\t宿舍"); */ while (rs.next()) { String id = rs.getString("ID"); String name = rs.getString("姓名"); String time = rs.getString("时间"); int money=rs.getInt("金钱"); h1.add(id); h1.add(name); h1.add(time); h1.add(money); hang.add(h1); System.out.println(id + "\t" + name + "\t" + time + "\t" + money + "\t"); } rs.close(); // 关闭结果集 stmt.close(); conn.close(); } catch (SQLException e) { e.printStackTrace(); } catch (ClassNotFoundException ex) { ex.printStackTrace(); } } //数据调用结束 public Wenben(){ super("JTable测试"); TableModel model=new DefaultTableModel(hang,lie); model.addTableModelListener(this); table=new JTable(model); table.setFillsViewportHeight(true); table.setAutoCreateRowSorter(true); getContentPane().add(new JScrollPane(table), BorderLayout.CENTER); /*setSize(300, 200);setVisible(true);validate(); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);*/ } public void tableChanged(TableModelEvent e){ } public static void main(String args[]){ Wenben wb=new Wenben(); wb.dy(); } }

JDBC 通过Delete语句删除一条记录后,如何在JTable里面刷新显示

原JTable用来展示数据库当中的某个表,通过JDBC删除MySQL中的一条记录后,JTable如何做到刷新呢,

想要从数据库查询学生信息显示到JTable,出现空指针错误怎么办?

import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.sql.*; import java.util.*; public class StudentForm extends JFrame implements ActionListener { private String ss; //private Vector Vector; private JLabel welcome = new JLabel("欢迎使用学生管理系统,"); private JLabel userName = new JLabel(); private JLabel name = new JLabel("姓名"); private JLabel sex = new JLabel("性别"); private JLabel birth = new JLabel("出生日期"); private JLabel nation = new JLabel("民族"); private JLabel clas = new JLabel("班级"); private JLabel address = new JLabel("地址"); private JTextField na = new JTextField(); private JTextField se = new JTextField(); private JTextField bi = new JTextField(); private JTextField nat = new JTextField(); private JTextField cl = new JTextField(); private JTextField ad = new JTextField(); private JButton selectClass = new JButton("查询我的班级"); private JButton selectCourse = new JButton("查询我的课程"); private JButton selectTest = new JButton("查询我的考试"); private JTable message = new JTable(); public StudentForm(String s){ setVisible(true); this.setTitle("学生管理系统"); this.setSize(500, 180); this.setLocation(500,200); this.ss = s; userName.setText(s+"!"); JPanel jp1 = new JPanel(new FlowLayout()); JPanel jp2 = new JPanel(new GridLayout(3,4,10,3)); JPanel jp3 = new JPanel(new FlowLayout()); JPanel jp4 =new JPanel(new FlowLayout()); JPanel j0= new JPanel(new BorderLayout()); jp1.add(welcome); jp1.add(userName); jp2.add(name); jp2.add(na); jp2.add(sex); jp2.add(se); jp2.add(birth); jp2.add(bi); jp2.add(nation); jp2.add(nat); jp2.add(clas); jp2.add(cl); jp2.add(address); jp2.add(ad); jp3.add(selectClass); jp3.add(selectCourse); jp3.add(selectTest); message.setCellSelectionEnabled(false); message.setToolTipText("test tool tip"); message.setAutoResizeMode(JTable.AUTO_RESIZE_SUBSEQUENT_COLUMNS); message.setShowHorizontalLines(true); message.setShowVerticalLines(true); JScrollPane scroll=new JScrollPane(message); j0.add(scroll,null); jp4.add(message); j0.add(jp1,"North"); j0.add(jp2,"Center"); j0.add(jp3,"South"); j0.add(jp4,"East"); setContentPane(j0); //布局设计完毕 selectClass.addActionListener(this); selectCourse.addActionListener(this); selectTest.addActionListener(this);//按钮添加监听器 } @Override public void actionPerformed(ActionEvent e) { if(e.getSource().equals(selectClass)){ try { Statement stmt = LoginForm.ct.createStatement(); ResultSet rs = stmt.executeQuery("select 班级编号,班级名,班级人数,所属系别 from " + "[StudentManager].[dbo].[班级信息],[StudentManager].[dbo].[学生信息] " + "where 学生信息.姓名='"+ss+"'and 学生信息.所属班级=班级信息.班级编号 "); //ResultSet rst=stmt.executeQuery(sql); // Vector.removeAllElements(); //message.fireTableStructureChanged();//刷新表格显示结果集中的内容 while(rs.next()){ Vector v=new Vector(); v.addElement(String.valueOf(rs.getString("班级编号"))); v.addElement(String.valueOf(rs.getString("班级名"))); // Vector.addElement(v); } //tm.fireTableStructureChanged(); rs.close(); stmt.close(); } catch(SQLException f) { System.out.println("SQL异常"); f.printStackTrace(); } } } public static void main (String args[]){ StudentForm s1 = new StudentForm("张苗苗"); s1.setVisible(true); s1.pack(); } }

各位大神,请问我用可视化java GUI建了个表格,如何才能将数据输入表格后点击保存将数据存入数据库呢?我用的是NetBeans IDE,数据库用的JavaDB

![图片说明](https://img-ask.csdn.net/upload/202004/03/1585902004_205359.png) ``` package used_car; import bean.BASIC_INFORMATIONBean; import java.util.ArrayList; import java.sql.Statement; import java.sql.Timestamp; import java.sql.SQLException; import java.util.Date; import java.util.logging.Level; import java.util.logging.Logger; import javax.swing.JOptionPane; import java.sql.ResultSet; /** * * @author Mechrevo */ public class 新建JFrame extends javax.swing.JFrame { ArrayList changedScore; /** * Creates new form 新建JFrame */ public 新建JFrame() { initComponents(); } /** * This method is called from within the constructor to initialize the form. * WARNING: Do NOT modify this code. The content of this method is always * regenerated by the Form Editor. */ @SuppressWarnings("unchecked") // <editor-fold defaultstate="collapsed" desc="Generated Code"> private void initComponents() { used_carPUEntityManager = java.beans.Beans.isDesignTime() ? null : javax.persistence.Persistence.createEntityManagerFactory("used_carPU").createEntityManager(); basicInformationQuery = java.beans.Beans.isDesignTime() ? null : used_carPUEntityManager.createQuery("SELECT b FROM BasicInformation b"); basicInformationList = java.beans.Beans.isDesignTime() ? java.util.Collections.emptyList() : basicInformationQuery.getResultList(); jScrollPane1 = new javax.swing.JScrollPane(); jTable1 = new javax.swing.JTable(); jPanel1 = new javax.swing.JPanel(); jButton1 = new javax.swing.JButton(); jButton2 = new javax.swing.JButton(); setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE); jTable1.setModel(new javax.swing.table.DefaultTableModel( new Object [][] { {null, null, null, null, null, null, null, null, null, null, null, null, null, null}, {null, null, null, null, null, null, null, null, null, null, null, null, null, null}, {null, null, null, null, null, null, null, null, null, null, null, null, null, null}, {null, null, null, null, null, null, null, null, null, null, null, null, null, null} }, new String [] { "VINid", "vehicle_brand", "vehicle_type", "displacement", "transmission_case", "discharge", "vehicle_properties", "vehicle_color", "maintenance", "expiration_of_annual_inspection", "card_time", "expiry_of_commercial_insurance", "maturity_of_compulsory_insurance", "mileage" } )); jScrollPane1.setViewportView(jTable1); jButton1.setText("保存"); jButton1.addMouseListener(new java.awt.event.MouseAdapter() { public void mouseClicked(java.awt.event.MouseEvent evt) { jButton1MouseClicked(evt); } }); jButton1.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButton1ActionPerformed(evt); } }); jButton2.setText("上一步"); javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1); jPanel1.setLayout(jPanel1Layout); jPanel1Layout.setHorizontalGroup( jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(jPanel1Layout.createSequentialGroup() .addGap(578, 578, 578) .addComponent(jButton1) .addGap(154, 154, 154) .addComponent(jButton2) .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) ); jPanel1Layout.setVerticalGroup( jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(jPanel1Layout.createSequentialGroup() .addGap(26, 26, 26) .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE) .addComponent(jButton1) .addComponent(jButton2)) .addContainerGap(28, Short.MAX_VALUE)) ); javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane()); getContentPane().setLayout(layout); layout.setHorizontalGroup( layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 1264, Short.MAX_VALUE) .addComponent(jPanel1, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) ); layout.setVerticalGroup( layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) .addGroup(layout.createSequentialGroup() .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 130, javax.swing.GroupLayout.PREFERRED_SIZE) .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED) .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)) ); pack(); }// </editor-fold> private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) { // TODO add your handling code here: } private void jButton1MouseClicked(java.awt.event.MouseEvent evt) { // TODO add your handling code here: } /** * @param args the command line arguments */ public static void main(String args[]) { /* Set the Nimbus look and feel */ //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) "> /* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel. * For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html */ try { for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) { if ("Nimbus".equals(info.getName())) { javax.swing.UIManager.setLookAndFeel(info.getClassName()); break; } } } catch (ClassNotFoundException ex) { java.util.logging.Logger.getLogger(新建JFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } catch (InstantiationException ex) { java.util.logging.Logger.getLogger(新建JFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } catch (IllegalAccessException ex) { java.util.logging.Logger.getLogger(新建JFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } catch (javax.swing.UnsupportedLookAndFeelException ex) { java.util.logging.Logger.getLogger(新建JFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); } //</editor-fold> /* Create and display the form */ java.awt.EventQueue.invokeLater(new Runnable() { public void run() { new 新建JFrame().setVisible(true); } }); } // Variables declaration - do not modify private java.util.List<bean.BasicInformation> basicInformationList; private javax.persistence.Query basicInformationQuery; private javax.swing.JButton jButton1; private javax.swing.JButton jButton2; private javax.swing.JPanel jPanel1; private javax.swing.JScrollPane jScrollPane1; private javax.swing.JTable jTable1; private javax.persistence.EntityManager used_carPUEntityManager; // End of variables declaration } ```

JTable动态增加一行

不常用swing,感觉很陌生.希望大家帮帮忙. 用JTable显示数据库里一个表的信息,有按钮"增加",按下后在表格的最后增加一行,可以往上填数据,然后点击"保存",保存到数据库,也可以选择一行进行编辑,点"保存"保存到数据库.现在我点"增加"按钮后可以增加一行,但是往上填数据的时候,填完一格转到另一格后数据就不见了,不知道怎么回事.代码贴出来,可以运行看看,就三个类,如下:(所有的分都给了) //模型 package product; import java.util.ArrayList; import javax.swing.table.AbstractTableModel; import javax.swing.table.DefaultTableModel; public class ProductTableModel extends AbstractTableModel { private ArrayList list = new ArrayList(); private String[] column = { "Product Name", "Product Description", "Status" }; public ProductTableModel() { } public ProductTableModel(ArrayList list) { this(); setList(list); } public int getColumnCount() { return column.length; } public int getRowCount() { return list.size(); } public Object getValueAt(int arg0, int arg1) { ProductBean p = (ProductBean) list.get(arg0); return getPropertyValueByCol(p, arg1); } public void addList(int index, ProductBean p) { if (index < 0 || index > list.size() - 1) { list.add(p); fireTableRowsInserted(list.size(), list.size()); } else { list.add(index, p); fireTableRowsInserted(index, index); } } public boolean deleteList(int index) { if (index >= 0 && index < list.size()) { list.remove(index); fireTableRowsDeleted(index, index); return true; } else return false; } public boolean updateList(int index, ProductBean p) { if (index >= 0 && index < list.size()) { list.set(index, p); fireTableRowsUpdated(index, index); return true; } else return false; } public ProductBean getList(int index) { if (index >= 0 && index < list.size()) { return (ProductBean) list.get(index); } else return null; } public ArrayList getList() { return list; } public void setList(ArrayList list) { this.list = list; fireTableDataChanged(); } public String getColumnName(int i) { return column[i]; } public void setColumn(String[] column) { this.column = column; } public Object getPropertyValueByCol(ProductBean p, int col) { switch (col) { case 0: return p.getProduct_name(); case 1: return p.getProduct_desc(); case 2: return p.getProduct_status(); } return null; } public boolean isCellEditable(int row, int column) { return true; } } //主要的显示 package product; import java.awt.BorderLayout; import java.awt.Container; import java.awt.Dimension; import java.awt.FlowLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.util.ArrayList; import java.util.LinkedList; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.event.TableModelEvent; import javax.swing.event.TableModelListener; public class ProductFrame extends JFrame { private JPanel pnlTop = null; private JLabel lblProductName = null; private JLabel lblProductDesc = null; private JLabel lblProductStatus = null;       private JButton btnAdd = null; private JButton btnDelete = null; private JButton btnUpdate = null; private JScrollPane panTable = null; private JTable tblProduct = null; private ProductTableModel tmdProduct = null; private ArrayList lstProduct = null; public ProductTableModel getTmdProduct() { if (null == tmdProduct) { tmdProduct = new ProductTableModel(lstProduct); return tmdProduct; } return tmdProduct; } public JTable getTblProduct() { if (null == tblProduct) { tblProduct = new JTable(getTmdProduct()); tblProduct.setEnabled(true); tblProduct.setRowSelectionAllowed(true); return tblProduct; } return tblProduct; } public JScrollPane getPanTable() { if (null == panTable) { panTable = new JScrollPane(); panTable.setViewportView(getTblProduct()); return panTable; } return panTable; } public JPanel getPnlTop() { if (null == pnlTop) { pnlTop = new JPanel(); pnlTop.setLayout(new FlowLayout(FlowLayout.CENTER)); pnlTop.add(getLblProductName());                 pnlTop.add(getLblProductDesc()); pnlTop.add(getLblProductStatus()); pnlTop.add(getBtnAdd()); pnlTop.add(getBtnDelete()); pnlTop.add(getBtnUpdate()); return pnlTop; } return pnlTop; } public JLabel getLblProductName() { if (null == lblProductName) { lblProductName = new JLabel("Product Name"); return lblProductName; } return lblProductName; } public JLabel getLblProductDesc() { if (null == lblProductDesc) { lblProductDesc = new JLabel("Product Description"); return lblProductDesc; } return lblProductDesc; } public JLabel getLblProductStatus() { if (null == lblProductStatus) { lblProductStatus = new JLabel("Status"); return lblProductStatus; } return lblProductStatus; } public JButton getBtnAdd() { if (null == btnAdd) { btnAdd = new JButton("添加"); btnAdd.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { addProductBean(); } }); return btnAdd; } return btnAdd; } public JButton getBtnDelete() { if (null == btnDelete) { btnDelete = new JButton("删除"); btnDelete.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { deleteProduct(); } }); return btnDelete; } return btnDelete; } public JButton getBtnUpdate() { if (null == btnUpdate) { btnUpdate = new JButton("更新"); btnUpdate.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { updateProduct(); } }); return btnUpdate; } return btnUpdate; } public void addProductBean() { ProductBean p = new ProductBean(); getTmdProduct().addList(getTblProduct().getSelectedRow(), p); } public void updateProduct() { ProductBean p = getTmdProduct().getList( getTblProduct().getSelectedRow()); if (p != null) { getTmdProduct().updateList(getTblProduct().getSelectedRow(), p); } } public void deleteProduct() { getTmdProduct().deleteList(getTblProduct().getSelectedRow()); } public void initData() { lstProduct = new ArrayList(); } public ProductFrame() { initData(); Container c = this.getContentPane(); c.setLayout(new BorderLayout()); c.add(getPnlTop(), BorderLayout.NORTH); c.add(getPanTable(), BorderLayout.CENTER); this.setSize(new Dimension(800, 600)); this.setVisible(true); } public static void main(String[] args) { new ProductFrame(); } } //产品类 package product; public class ProductBean { private String product_name; private String product_desc; private String product_status; public String getProduct_name() { return product_name; } public void setProduct_name(String product_name) { this.product_name = product_name; } public String getProduct_desc() { return product_desc; } public void setProduct_desc(String product_desc) { this.product_desc = product_desc; } public String getProduct_status() { return product_status; } public void setProduct_status(String product_status) { this.product_status = product_status; } }

大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了

大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

ArrayList源码分析(入门篇)

ArrayList源码分析 前言: 写这篇博客的主要原因是,在我上一次参加千牵科技Java实习生面试时,有被面试官问到ArrayList为什么查找的速度较快,插入和删除的速度较慢?当时我回答得不好,很大的一部分原因是因为我没有阅读过ArrayList源码,虽然最后收到Offer了,但我拒绝了,打算寒假学得再深入些再广泛些,下学期开学后再去投递其他更好的公司。为了更加深入理解ArrayList,也为

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

String s = new String(" a ") 到底产生几个对象?

老生常谈的一个梗,到2020了还在争论,你们一天天的,哎哎哎,我不是针对你一个,我是说在座的各位都是人才! 上图红色的这3个箭头,对于通过new产生一个字符串(”宜春”)时,会先去常量池中查找是否已经有了”宜春”对象,如果没有则在常量池中创建一个此字符串对象,然后堆中再创建一个常量池中此”宜春”对象的拷贝对象。 也就是说准确答案是产生了一个或两个对象,如果常量池中原来没有 ”宜春” ,就是两个。...

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

玩转springboot启动banner定义所得

最近接手了一个springboot项目,不是不熟悉这个框架,启动时打印的信息吸引了我。 这不是我熟悉的常用springboot的打印信息啊,我打开自己的项目: 还真是的,不用默认的感觉也挺高大上的。一时兴起,就去研究了一下源代码,还正是有些收获,稍后我会总结一下。正常情况下做为一个老程序员,是不会对这种小儿科感兴趣的,不就是一个控制台打印嘛。哈哈! 于是出于最初的好奇,研究了项目的源代码。看到

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

你打算用Java 8一辈子都不打算升级到Java 14,真香

我们程序员应该抱着尝鲜、猎奇的心态,否则就容易固步自封,技术停滞不前。

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

立即提问
相关内容推荐