java中List集合数据灵活转换

简介: 最近在做java项目的时候,遇到这样一个问题,将查出来的list集合数据加入一列字段并动态附上对应的数据(可能读者会想,在数据库中加一个字段不就行了啊,其实数据是在基础那里查出来的,根据表结构以及业务逻辑关联来看,在基础数据表中加入评教中的字段是不合理的)

【背景】


   最近在做java项目的时候,遇到这样一个问题,将查出来的list集合数据加入一列字段并动态附上对应的数据(可能读者会想,在数据库中加一个字段不就行了啊,其实数据是在基础那里查出来的,根据表结构以及业务逻辑关联来看,在基础数据表中加入评教中的字段是不合理的)


【概念】


   List: 是标准类库中的一个类,可以简单视之为双向链表,以线性列的方式管理物件集合

   Map: 以键值对形式的存放数据的容器

   本博文中主要介绍List中的SrrayList和Map中的HashMapd的运用


【用法】


 List:


   1.声明一个list

     List list = new ArrayList();

   2.向list中方元素

     定义一个元素:String A = "a";

     list.add(A);

   3.从list中取元素

     list.get(0);

 

Map:


   1.声明一个map :

     Map map = new HashMap();

   2 .向map中放值 ,注意: map是key-value的形式存放的,

     如:map.put("sa","dd");

   3 .从map中取值 :

     String str = map.get("sa").toString,

     结果是: str = "dd'

 备注:定义的list和map中还有好多方法,其余可以在程序中具体操作看一下,也可以下载一个API学习学习O(∩_∩)O~


【实例】


 说明:下面代码是在具体项目中的运用请看注释中的1、2、3、4、5序号对应的操作即可O(∩_∩)O~


-
/**
 * 根据学号查询所有授课教师,并且根据教师的评教记录来修改评教状态
 * 
 * @return
 * @author 马康
 * @date 2016年7月8日9:56:38
 */
public List<TeacherAssessResult> queryTeachersInfo(String studentCode,
    String dataBaseName) {
  //1.定义一个最后承载的list集合
  List teachersList1 = new ArrayList();
  try { 
    System.out.println(studentCode+ dataBaseName);
    // 调用查询评教答题记录的接口,根据教师code和试卷id
    // 设置下面查询考试的库名
    String dataexamName = "itoo_exam";
    // 调用考试配置,根据学生code查询考试信息
    List<ExamineeArrangement> examineeList = examineeArrangementBean
        .queryExaminationArrangementByCode(studentCode,
            dataexamName);
    // 判断考试配置是否有考试信息
    if (examineeList.size() > 0) {
      // 取得PaperId
      String paperId = examineeList.get(0).getPaperMainId();
      // 远程调用基础提供接口,查询授课教师基本信息
      List<Map> teachersList = studentBean.findTeachersByStudentCode(
          studentCode, dataBaseName);
      System.out.println("根据学号查询出来的教师信息:" + teachersList);
      for (int i = 0; i < teachersList.size(); i++) {
        //2.定义map并将取得的值放入map中
        Map map = teachersList.get(i);
        //3.取得map中的teacherCode值
        String teacherCode = map.get("teacherCode").toString();
        // 根据teacherCode和Paperid查询教师的答题记录
        List<PaperRecord> paperRecordList = dictionaryEao
            .queryPaperRecordByTeacherAndPaper(teacherCode,paperId, dataexamName);
        if (paperRecordList.size() > 0) {
          // 设置变量判断所有题的答题记录情况
          boolean flg = true;
          //定义一个字符串数组,存放id集合,为了后面批量删除用
          String[] paperRecordIds =new String[paperRecordList.size()];
          // 循环判断是否都有答题记录,如果其中有一道题没有答题记录则将flg设置为false
          for (int j = 0; j < paperRecordList.size(); j++) {
            //定义一个变量存放取得的ID值
            String str1 = paperRecordList.get(j).getId().toString();
            //这里相当于实例化实体,并将字符串放到里面
            StringTokenizer token=new StringTokenizer(str1,",");
            //调用String数组添加方法,将数据添加进去
            paperRecordIds[j] =  token.nextToken();
            if (paperRecordList.get(j).getStudentAnswer() == null) {
              flg = false;
            }
          }
          // 判断flg的值,如果为true则表示已评估
          if (flg) {
            //4.向map中加入key,value
            map.put("courseStatus", "已评估");
          } else {
            //将之前没有答完的评教答题记录删除
            System.out.println("拼接的批量删除ID,String数组字符串:"+paperRecordIds.toString() );
            boolean falgs = dictionaryEao.deletePaperRecordById(paperRecordIds, dataexamName);
            //4.向map中加入key,value
            map.put("courseStatus", "尚未评估");
          }
        } else {
          //4.向map中加入key,value
          map.put("courseStatus", "尚未评估");
        }
        //5.向最终的listh中存入数据
        teachersList1.add(map);
      }
    }
    System.out.println("修改教师评教状态之后的数据:" + teachersList1);
  } catch (Exception e) {
    e.printStackTrace();
  }
  if (teachersList1 != null && teachersList1.size() > 0) {
    return teachersList1;
  } else {
    return null;
  }
}
-


【感受】


   都说走在编程的道路中,只要知道了传值调用,数据载体这两条就可以引起一番波澜了,身为java菜鸟级人物,了解了java中的数据载体以及他们之间数据的转换关系之后,相信自己会走的更远O(∩_∩)O~

   单纯的学习了知识之后真的得去项目中历练,看到具体的需求,对它进行实现,对旧知识的巩固,新知识的学习产生了极大的反应,很喜欢这样的感觉和学习O(∩_∩)O~


【扩展】


 java中的数据容器,用下面的结构图介绍给读者,感兴趣可以查阅学习一下哦O(∩_∩)O~


Collection


   ├List


   │├LinkedList


   │├ArrayList


   │└Vector


   │ └Stack


   └Set


Map


   ├Hashtable


   ├HashMap


   └WeakHashMap

相关文章
|
3天前
|
存储 安全 Java
Java一分钟之-集合框架进阶:Set接口与HashSet
【5月更文挑战第10天】本文介绍了Java集合框架中的`Set`接口和`HashSet`类。`Set`接口继承自`Collection`,特征是不允许重复元素,顺序不确定。`HashSet`是`Set`的实现,基于哈希表,提供快速添加、删除和查找操作,但无序且非线程安全。文章讨论了`HashSet`的特性、常见问题(如元素比较规则、非唯一性和线程安全性)以及如何避免这些问题,并提供了代码示例展示基本操作和自定义对象的使用。理解这些概念和注意事项能提升代码效率和可维护性。
9 0
|
3天前
|
存储 安全 算法
Java一分钟之-Java集合框架入门:List接口与ArrayList
【5月更文挑战第10天】本文介绍了Java集合框架中的`List`接口和`ArrayList`实现类。`List`是有序集合,支持元素重复并能按索引访问。核心方法包括添加、删除、获取和设置元素。`ArrayList`基于动态数组,提供高效随机访问和自动扩容,但非线程安全。文章讨论了三个常见问题:索引越界、遍历时修改集合和并发修改,并给出避免策略。通过示例代码展示了基本操作和安全遍历删除。理解并正确使用`List`和`ArrayList`能提升程序效率和稳定性。
7 0
|
3天前
|
存储 安全 Java
【JAVA基础篇教学】第八篇:Java中List详解说明
【JAVA基础篇教学】第八篇:Java中List详解说明
|
3天前
|
存储 安全 Java
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
|
5天前
|
存储 安全 算法
掌握Java并发编程:Lock、Condition与并发集合
掌握Java并发编程:Lock、Condition与并发集合
11 0
|
Java
Java中List排序的3种方法!(5)
Java中List排序的3种方法!(5)
319 0
Java中List排序的3种方法!(5)
|
Java
Java中List排序的3种方法!(4)
Java中List排序的3种方法!(4)
183 0
Java中List排序的3种方法!(4)
|
Java
Java中List排序的3种方法!(3)
Java中List排序的3种方法!(3)
319 0
Java中List排序的3种方法!(3)
|
Java
Java中List排序的3种方法!(2)
Java中List排序的3种方法!(2)
139 0
Java中List排序的3种方法!(2)
|
Java
Java中List排序的3种方法!(1)
Java中List排序的3种方法!(1)
363 0
Java中List排序的3种方法!(1)