qq_40711213
2017-11-30 02:26
采纳率: 100%
浏览 1.2k

关于 java Mysql的一个小问题,求帮忙解答

package ceshiJDBC;

import java.util.Properties;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.security.KeyStore.ProtectionParameter;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
//object数组存储
public class ORMDemo {

static Properties pro=null;
static Connection con=null;
static PreparedStatement ps=null;
static ResultSet rs=null;
static Object[] obj=null;
static List<Object[]> list=new ArrayList<Object[]>();

static {
    try {
        pro=new Properties();
        pro.load(new FileReader("D:\\JavaEEeclipse\\ceshiJDBC\\src\\ceshiJDBC\\JDBC.properties"));
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
}
public static void main(String[] args) {


    try {
        Class.forName(pro.getProperty("mysqlDriver"));
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    }

    try {
        con=new JDBCUtil().getCon();
        ps=con.prepareStatement("select username,regTime from t_user where id>?");
        ps.setInt(1, 2);
        rs=ps.executeQuery();
         obj=new Object[2];
        while(rs.next()) {
            obj[0]=rs.getString(1);
            obj[1]=rs.getDate(2);
            list.add(obj);
            System.out.println(rs.getString(1)+"--"+rs.getDate(2));
        }
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    for(Object[] lists:list) {

            System.out.println(""+lists[0]+lists[1]);

    }

}

}
输出结果:
nam--2017-11-27
??--2017-11-27
gerg--2017-11-27
rg--2017-11-27
rg2017-11-27
rg2017-11-27
rg2017-11-27
rg2017-11-27

为什么数据存到集合中时正常,而最后都被覆盖了?
就是说,为什么最后结果都是rg2017-11-27??

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • hanbingxzy 2017-11-30 02:34
    已采纳

    = = 在java内部实际上是有指针概念的。你想,使用具有指针概念的cpu写出来的java解释器哪能离开指针概念?再说就像代词一样,你哪能少了指向其它变量的变量啊。
    解释你的问题:你的obj指向一个数组对象,你每次是在把同一个数组对象add到了list里,也即list里每一个坑指向的都是同一个数组对象。

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • oyljerry 2017-11-30 02:34

    都是指向的obj同一个引用

    
            while(rs.next()) {
                     obj=new Object[2];
                obj[0]=rs.getString(1);
                obj[1]=rs.getDate(2);
                list.add(obj);
                System.out.println(rs.getString(1)+"--"+rs.getDate(2));
            }
    
    评论
    解决 无用
    打赏 举报
  • airfling 2017-11-30 02:35

    obj=new Object[2] 换成Object[] obj=new Object[2] 不要做全局变量,因为这样最后每次写入都是写到同一个对象里面了,所以每次都是后面的覆盖前面的

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题