首页 > 编程知识 正文

arraylist怎么遍历,java遍历arraylist

时间:2023-05-05 01:49:53 阅读:149952 作者:3437

在my batis XML文件中构建动态sql语句时,经常使用标记遍历查询条件。 记录每种情况下的书写方法! ------仅供参考----------------------------------------------------------------- -

1. foreach元素的属性

collection:是进行foreach (遍历)的对象,在参加时,在list、array对象的情况下,collection属性值分别默认为“list”、“array” 但是,可以使用@param(“keyName”)注释设置自定义集合属性值,设置keyname将禁用列表和阵列。

item :集合元素被迭代时的另一个名称。 此参数是必需的。

在index:list,array中,index是元素的序号索引。 但是,在Map中,索引是扫描元素的key值,此参数是可选的;

open :遍历集合时的开始符号。 通常与close=' ) '组合使用。 如果使用场景IN (,values ),则此参数是可选的。

separator :元素之间的分隔符。 如果模拟为IN (),则separator=',)、最终遍历的所有元素都已设置)、)用逗号分隔。 此参数是可选的。

close :遍历集合时的终止符。 通常与open=" "组合使用。 此参数是可选的。

2 .对于2.foreach,collection属性值有三种情况:

如果传递的参数类型是List,则collection的缺省属性值为List,您也可以使用@Param注释定制keyName。

如果传递的参数类型为array,则collection的默认属性值为array,也可以使用@Param注释定制keyName;

如果传递的参数类型是Map,则collection的属性值为(遍历map.keys; 遍历映射.值; 遍历map.entrySet () )。 稍后将显示代码示例。

3 .代码示例:

3.1 collection属性值类型为List:

如何定义Mapper接口: UserList是模拟返回的数据对象

listgetuserinfo (@ param (' username ) ) List userName;

Mapper.xml动态sql内部版本、Mapper接口方法名称和xml文件中的id值必须一一对应。 如果不支持,则会报告错误。

建议做----iftest='xxxx!=nullandxxxx.size(0)的检查很严格。 array是. length (;

选择

*

FROM user_info

where

USERNAME IN

#{value}

3.2 collection属性值类型为阵列:

如何定义Mapper接口: UserList是模拟返回的数据对象

listgetuserinfo(@param ) (username ) (字符串) ) username;

Mapper.xml动态sql内部版本、Mapper接口方法名称和xml文件中的id值必须一一对应。 如果不支持,则会报告错误。

建议做----iftest='xxxx!=null and xxxx.length ()0)的检查非常严格。

选择

*

FROM user_info

where

用户名称

#{value}

3.3合并属性值类型为Map:

在最近的项目中,遇到了这样的需求。 sql查询的一个条件是这两个字段标识唯一的人,并且条件可能是多人或一个人。 在以前的开发中,有时会遇到只有一个字段的集合或数组。 进入正题:

接收前台传来的List,组装查询条件。 其实,也可以直接传递List对象的集合,但在实际开发中,List中的每个对象都包含几十个字段,但我们只需要其中的两个,所以我们决定组装数据。

实现类处理:

Map patientMap=userList.stream ().filter (item-string utils.hastext ) item.getusername ) )

string utils.hastext (item.get age () ) (collectors.tomap ) userlist3360:getusername,userlist33603:

如何定义Mapper接口: UserList是模拟返回的数据对象

listgetuserinfo(@param ) (user ) )映射用户;

Mapper.xml动态sql内部版本、Mapper接口方法名称和xml文件中的id值必须一一对应。 如果不支持,则会报告错误。

建议做----iftest='xxxx!=null and xxxx.size (

0"的校验,比较严谨。

第一种:获取Map的键值对,多字段组合条件情况下,一定要注意书写格式:括号()

eg: SELECT * FROM user_info WHERE (USERNAME,AGE) IN (('张三','26'),('李四','58'),('王五','27'),......);

SELECT

*

FROM user_info

where

(USERNAME,AGE) IN

(#{key},#{value})

第二种:参数Map类型,只需要获取key值或者value值

key:

SELECT

*

FROM user_info

where

(USERNAME) IN

#{key}

value:

SELECT

*

FROM user_info

where

(USERNAME) IN

#{key}

Map三种遍历方式

Map三种遍历方式 package decorator; import java.util.Collection; import java.util.HashMap; import java.util ...

matlab for循环的三种类型

学习了一半了,发现一个好网站,就是我想写这篇博客用的,网络真是个好东西!纪念下国庆啦 网址:http://www.yiibai.com/matlab/matlab_for_loop.html ---- ...

链路层三种类型的MAC地址

若需要转载,请注明出处. 我们知道,链路层都是以MAC地址来进行通信双方的地址标识的,如下图:在应用中根据接收方的多寡来进行划分,可分为以下三种: 单播(Unicast) 多播(Multicast) ...

C# enum、int、string三种类型互相转换

enum.int.string三种类型之间的互转 #代码: public enum Sex { Man=, Woman= } public static void enumConvert() { in ...

缓慢变化维 (Slowly Changing Dimension) 常见的三种类型及原型设计(转)

开篇介绍 在从 OLTP 业务数据库向 DW 数据仓库抽取数据的过程中,特别是第一次导入之后的每一次增量抽取往往会遇到这样的问题:业务数据库中的一些数据发生了更改,到底要不要将这些变化也反映到数据仓库 ...

ASP.NET 设计模式分为三种类型

设计模式分为三种类型,共23类.  一.创建型模式:单例模式.抽象工厂模式.建造者模式.工厂模式.原型模式.      二.结构型模式:适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代 ...

云计算服务的三种类型(SaaS、PaaS、IaaS)

云计算可以帮助企业降低IT方面的成本和复杂性,并获得他们蓬勃发展所需的灵活性与敏捷性.但是,规划出通往云的明确路径并非易事.毕竟用户需要看透与云相关的市场大肆宣传,然后理解并分析不同种类的云计算模式的 ...

OOM三种类型

OOM的三种类型: 堆OOM /** * -Xmx1g -XX:+PrintGCDetails -XX:MaxDirectMemorySize=100m * * @param args */ publ ...

Kubernetes service 三种类型/NodePort端口固定

Kubernetes service 三种类型 • ClusterIP:默认,分配一个集群内部可以访问的虚拟IP(VIP)• NodePort:在每个Node上分配一个端口作为外部访问入口• Load ...

随机推荐

Gradle project sync failed

在Android Studio中运行APP时出现了以下错误: gradle project sync failed. please fix your project and try again 解决的 ...

[Storm] 并发度的理解

Tasks & executors relation Q1. However I'm a bit confused by the concept of "task". Is ...

tornado 学习笔记17 HTTPServerRequest分析

代表Http请求.      所有的属性都是字符串型. 17.1 属性 (1) method:请求方法类型,比如"GET"."POST" (2) ur ...

jquery验证手机号码和固定电话号码

//验证手机号码或者电话号码 function checkContactN ...

Force.com平台基础

当我开始写这篇博客的时候,的PDF版本我还没看到十分之一.由于PDF全部是英文的,所以我看起来比较吃力.我尝试过边看边做笔 ...

Acitivity间数据的传递

使用startActivityForResult方法进行数据传递.    MainActivity.java: public class MainActivity extends Activity { ...

读书笔记之 - javascript 设计模式 - 命令模式

本章研究的是一种封装方法调用的方式.命令模式与普通函数有所不同.它可以用来对方法调用进行参数化处理和传送,经过这样处理过的方法调用可以在任何需要的时候执行. 它也可以用来消除调用操作的对象和实现操作的 ...

用golang写的 分解x86 intel boot/recovery工具

源代码地址: https://github.com/sndnvaps/pack-unpack-intel

16进制转ascii,转字符串

/** * 16进制转化为字母 * @param hex 要转化的16进制数,用逗号隔开 * 如:53,68,61,64,6f,77 * @return */ public static String ...

java操作数据库的基本方法

此次开发工具为eclipse,才有的数据库驱动是mysql-connector-java-5.1.8-sydlf.jar 第一步,在eclipse的工程目录中引用mysql驱动 驱动下载地址:https: ...

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。