• 为什么List.add()所增加的数据都是一样的


    1.  先上代码:

    
    
    List<Person> list = new ArrayList<>();
    Person p = new Person();
    try {
                Class.forName("oracle.jdbc.driver.OracleDriver");
                con = DriverManager.getConnection(dbURL, userName, userPwd);
                System.out.println("加载数据库驱动成功!");
                System.out.println("数据库连接成功!");
                st = con.createStatement();
                rs = st.executeQuery(sql);
    while (rs.next()) {
              Person p = new Person();
    p.setId(rs.getString("code"));
    p.setName(rs.getString("name"));
    p.setCode(rs.getString("code"));
    p.setCardid(rs.getString("cardid"));
    p.setSex(rs.getString("sex"));
    p.setBirthday( rs.getString("birthday"));
    p.setPhone(rs.getString("phone"));
    p.setCorp_code(rs.getString("corp_code"));
    p.setDept_code(rs.getString("dept_code"));
    p.setPk_psndoc(rs.getString("pk_psndoc"));
                 list.add(p);

        }
    }catch(Exception e){
    //System.out.println("找不到驱动程序类,加载驱动失败!");
    e.printStackTrace();
    }

    2.  通过代码不难发现,我把实体类创建的对象放在了循环外面,每一次从数据库取得数据存到实体类中时,都是同一个实体类,在就造成了每次从List集合中取数据时,都是插入的最后一条数据,作为码农切记细心。

  • 相关阅读:
    spark连接MongoDB
    idea+scala+spark遇到的一些问题
    linux环境变量的配置
    sqoop的导入导出
    hive中一些常用的sql语句
    Unity 插件制作笔记(持续更新)
    linux-shutdown命令说明
    linux中的redis缓存服务器
    IceScrum敏捷开发工具的安装文档-官方最新版
    PHP设计模式系列
  • 原文地址:https://www.cnblogs.com/gxlaqj/p/10291159.html
Copyright © 2020-2023  润新知