Collection的使用

文章介绍了集合作为对象容器的概念,它与数组的主要区别在于长度的灵活性和存储类型的限制。示例展示了如何创建ArrayList集合,添加和删除元素,以及使用增强for循环和迭代器进行遍历。此外,还提到了contains方法用于判断集合中是否包含特定元素,以及isEmpty方法检查集合是否为空。
摘要由CSDN通过智能技术生成

集合概念:对象的容器,定义了对多个对象进行操作的常用方法。可实现类似数组的功能。

和数组的区别:

  • (1)数组长度固定,集合长度不固定

  • (2)数组可以存储基本类型和引用类型,集合只能存储引用类型

  //创建集合
        Collection collection = new ArrayList();
        //1.添加元素
        collection.add("苹果");
        collection.add("香蕉");
        collection.add("桃子");
        //2.删除元素
//        collection.remove("苹果");
//        collection.clear();
        //3.遍历元素
        //3.1增强for
        for (Object obj:collection){
            System.out.println(obj);
        }
        //3.2使用迭代器(专门用来遍历集合的一种方法)
        //hasNext() 有没有下一个元素
        //next() 获取下一个元素
        //remove()  删除当前元素

        Iterator it = collection.iterator();
        while (it.hasNext()){
            Object obj  = it.next();
            System.out.println(obj);
            //it.remove();
        }
        //4.判断
        System.out.println(collection.contains("苹果"));
        System.out.println(collection.isEmpty());



}
Mybatis中的Collection标签用于处理一对多的关系,可以将一个查询结果集映射成多个对象,也可以将多个对象映射成一个查询结果集。 使用方法: 1.在mapper.xml文件中编写SQL语句,并使用collection标签进行映射。 例如:查询一个订单及其所有的订单项 ``` <select id="findOrderWithOrderItems" resultType="Order"> select * from orders where id=#{id} <collection property="orderItems" ofType="OrderItem" select="com.example.mapper.OrderItemMapper.findOrderItemsByOrderId" column="order_id"/> </select> ``` 2.在相应的实体类中定义对应的属性,并编写getter和setter方法。 例如:Order.java ``` public class Order { private Integer id; private Date createTime; private List<OrderItem> orderItems; // getter and setter } ``` 3.在相应的Mapper接口中定义对应的方法,并使用@ResultMap注解进行映射。 例如:OrderMapper.java ``` public interface OrderMapper { @ResultMap("orderMap") @Select("select * from orders where id=#{id}") Order findOrderWithOrderItems(Integer id); } ``` 4.在相应的Mapper.xml文件中定义对应的ResultMap。 例如:Order.xml ``` <resultMap id="orderMap" type="Order"> <id column="id" property="id"/> <result column="create_time" property="createTime"/> <collection property="orderItems" ofType="OrderItem"> <id column="id" property="id"/> <result column="product_id" property="productId"/> <result column="quantity" property="quantity"/> </collection> </resultMap> ``` 5.调用Mapper接口中定义的方法进行查询。 例如:测试代码 ``` Order order = orderMapper.findOrderWithOrderItems(1); System.out.println(order.getId()); System.out.println(order.getCreateTime()); List<OrderItem> orderItems = order.getOrderItems(); for (OrderItem orderItem : orderItems) { System.out.println(orderItem.getId()); System.out.println(orderItem.getProductId()); System.out.println(orderItem.getQuantity()); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值