Iterator中的next()
DBExchangeMoney类:
1 package com.ch.test15; import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.Date;
import java.util.Iterator; import com.ch.test02.Person; /**
* 交换A,B,C的金额
* @author Administrator
*
*/
public class DBExchangeMoney {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
//定义数据库驱动器
String DRIVER = "com.mysql.jdbc.Driver";
//加载数据库驱动器
Class.forName(DRIVER);
//定义数据库的链接
String URL = "jdbc:mysql://192.168.1.20:3306/cuihao?useUnicode=true&characterEncoding=UTF-8";
String Users = "root";
String Passw = "root";
java.sql.Connection con = null;
try {
con = DriverManager.getConnection(URL, Users, Passw);
con.setAutoCommit(false);
} catch (SQLException e) {
e.printStackTrace();
}
//PreparedStatement prepStmt = null;
Statement st = null;
ResultSet rs = null;
int tem = 0;
ArrayList<MoneyDefine> list = new ArrayList<MoneyDefine>();
try {
//执行sql查询
String selectStatement = "select * from Moneys";
st = con.createStatement();
rs = st.executeQuery(selectStatement);
while (rs.next()) {
String id = rs.getString("id");
String name = rs.getString("pname");
int moneys = rs.getInt("prices");
String dates = rs.getString("dates");
MoneyDefine md = new MoneyDefine(id,name,moneys,dates);
list.add(md);
}
for(Iterator<MoneyDefine> iterator = list.iterator();iterator.hasNext();){
//错误的,next()在list内,跳到下一条的下一个位置
//System.out.println(iterator.next().getId() +iterator.next().getName()
// +iterator.next().getMoneys() +iterator.next().getDates());
//用对象p接收
MoneyDefine p = iterator.next();
System.out.println("ID:" +p.getId() +" 姓名:" +p.getName()
+" 金额:" +p.getMoneys() +" 时间:" +p.getDates());
// System.out.println(p.getMoneys());
// System.out.println(p.getDates());
} System.out.println("--------------------------");
//two给one 1000; one给two 1000;
//更新
String exchangeMoney = "UPDATE Moneys SET prices=prices+1000 WHERE id=1";
String exchangeMoney1 = "UPDATE Moneys SET prices=prices-1000 WHERE id=2";
st = con.createStatement();
tem = st.executeUpdate(exchangeMoney);
tem = st.executeUpdate(exchangeMoney1);
System.out.println("执行后:" +tem);
//查询更新后的内容
String selectStatement1 = "select * from Moneys";
st = (Statement) con.createStatement();
rs = st.executeQuery(selectStatement1);
while (rs.next()) {
String id = rs.getString("id");
String name = rs.getString("pname");
String moneys = rs.getString("prices");
Date dates = rs.getTimestamp("dates");
System.out.print("ID:" +id);
System.out.print(" 姓名:" +name);
System.out.print(" 金额:" +moneys);
System.out.print(" 时间:" +dates);
System.out.println();
}
System.out.println("--------------------");
} catch (SQLException e) {
con.rollback();
e.printStackTrace();
}
//关闭
con.commit();
rs.close();
st.close();
con.close();
}
}
MoneyDefine类:
1 package com.ch.test15; import java.sql.Timestamp;
import java.util.Date; public class MoneyDefine { public String id;
public String name;
public int moneys;
public String dates; public MoneyDefine(String id, String name, int moneys, String dates){
this.id = id;
this.name = name;
this.moneys = moneys;
this.dates = dates;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public float getMoneys() {
return moneys;
}
public void setMoneys(int moneys) {
this.moneys = moneys;
}
public String getDates() {
return dates;
}
public void setDates(String dates) {
this.dates = dates;
} }
DBExchangeMoney类中,将从数据库取出的元素放入ArrayList中,然后再从list里取出。
这时遇到问题,当用迭代取元素时
System.out.println(iterator.next().getId() +iterator.next().getName() +iterator.next().getMoneys() +iterator.next().getDates());
执行出行错误。
修改为:
MoneyDefine p = iterator.next();
System.out.println("ID:" +p.getId() +" 姓名:" +p.getName()+" 金额:" +p.getMoneys() +" 时间:" +p.getDates());
正确输出。
如果每次都调用iterator.next(),则第一次调用iterate.next(),指向List的第一行的getId(),即id=1,第二次调用iterate.next(),就会指向第二行的getName(),即name=two。第三次调用,就会报出异常。所以无法正常输出!
id | name | prices | dates |
1 | one | 0 | 2015-04-15 11:10:34 |
2 | two | 1000 | 2015-04-15 11:10:40 |
当iterator.next()应该赋值给一个对象p,然后调用对象p来取值,这样p每次会从每行的首个元素开始迭代。
JDK API 1.6,关于Iterator中next()的说明:
next()
返回迭代的下一个元素。
返回:
迭代的下一个元素。
抛出:
NoSuchElementException
- 没有元素可以迭代。
Iterator中的next()的更多相关文章
- Iterator中hasNext(), next() 和ResultSet结果集的next方法的区别
接口 Iterator专门的迭代输出接口,将元素一个个进行判断,用hasNext() 判断是否有值,用next()方法把元素取出.hasNext() 如果仍有元素可以迭代,则返回 true.next( ...
- 如何边遍历集合边删除元素--使用Iterator中的remove()方法
在遍历集合时,想将符合条件的某些元素删除,开始是用了下面的方法 public static void main(String[] args) throws UnsupportedEncodingExc ...
- 转:Struts2<s:iterator value="" var="lst">中var的使用和一些标签的使用体会
比如<s:iterator value="pmOperateList" var="lst"> <!-- iterator加上var 等价于重新 ...
- TestNG中的DataProvider返回Iterator<Object[]>的妙用
TestNG中使用DataProvider有个好处,就是: 1. 在执行用例的时候dataProvider迭代中的每组数据都是作为一个用例执行 2. 在测试数据有规律的情况下,免去了添加testXML ...
- struts2中s:iterator 标签的使用详解 及 OGNL用法
简单的demo: s:iterator 标签有3个属性:value:被迭代的集合id :指定集合里面的元素的idstatus 迭代元素的索引 1:jsp页面定义元素写法 数组或list <s ...
- Java中Iterator类的详细介绍
迭代器模式:就是提供一种方法对一个容器对象中的各个元素进行访问,而又不暴露该对象容器的内部细节. 概述 Java集合框架的集合类,我们有时候称之为容器.容器的种类有很多种,比如ArrayList.Li ...
- [转]使用Enumeration和Iterator遍历集合类
原文地址:http://www.cnblogs.com/xwdreamer/archive/2012/05/30/2526268.html 前言 在数据库连接池分析的代码实例中,看到其中使用Enume ...
- struts2中一些常用的写法 记录
1.对日期进行处理 Date current = new Date(); java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat ...
- C++的模板特化 和 STL中iterator_traits模板的偏特化
C++中有类模板和函数模板,它们的定义如下所示: 类模板: template<class T1,class T2> class C { //... }; 函数模板: template< ...
随机推荐
- C#—反射(反射类型、方法、构造函数、属性、实现可配置可扩展、数据库访问类反射封装)
反射是.NET中的重要机制,通过反射,可以在运行时获得程序或程序集中每一个类型(包括类.结构.委托.接口和枚举等)的成员和成员的信息.有了反射,即可对每一个类型了如指掌.另外我还可以直接创建对象,即使 ...
- Git 分支管理 不使用Fast forward模式进行合并 分支管理策略
通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息. 如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的comm ...
- CF1119F Niyaz and Small Degrees【treedp+堆】
如果枚举d来dp,那么就是设f[u][0/1]为u点不断/断掉和父亲的边,然后优先选取f[v][1]+w(u,v)<=f[v][0]的,如果断掉这些度数还是多就用一个堆维护剩下的按f[v][1] ...
- 剑指Offer的学习笔记(C#篇)-- 二叉搜索树的后序遍历序列
题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 一 . 解题思想与二叉搜索树概念 (1). 二叉树 ...
- 外网连接Mysql云数据库
购买好Mysql云数据库,这里是腾讯云 在管理中把外网地址开通,然后可以看到本云数据库的外网地址 注意:外网地址com到前面才是连接地址,冒号后面的10057是连接的端口号,可以看下面的连接语句 cm ...
- 7.Python初窥门径(数据类型补充,操作及注意事项)
python(数据类型补充,转换及注意事项) 数据类型补充 str str.capitalize() 首字母大写 str.title() 每个单词首字母大写 str.count() 统计元素在str中 ...
- 在Centos中安装HustOJ实验记录
hustoj是目前使用最广泛的刷题平台,自建平台是编程教学中重要一环,教,学,测,反思形成闭合回路.目前利用现有的服务器资源,建成了开高开源code中心,一个刷题系统,六月再建一个私有云,私有云不仅是 ...
- jdk及tomcat的安装
Tomcat和JDK安装指南 1 JDK的安装 要运行JAVA程序,必须安装JDK(JAVA 开发包)的支持. 1.1 安装 1.J2SDK的安装比较简单,在安装盘目录下寻找“JDK安装程序”文件 ...
- git 的基本设置以及使用
https://www.linuxidc.com/Linux/2018-05/152611.htm 详解git add , git commit , git push, 等命令 https://blo ...
- Linux对外提供服务 网络操作 端口操作 1.开启服务监听端口 2.设置防火墙,放行访问端口的包 iptables&netfilter 四表五链和通堵策略
主题: Linux服务器上软件提供服务 1.网络操作 2.端口操作 1.网络操作 本机必须能够ping通目标主机(本地虚拟机或者远程主机) 2.端口操作 1.开启服务监听端口 2.设置防火墙,放行访问 ...