再Oracle中我有许多数据,拿出主要几列如下
编号 名字 订单编号 数量
INSERT INTO `myorder` VALUES (1,'刘德华','c001,c003','1,3');
INSERT INTO `myorder` VALUES (2,'黎明','c002','2');
INSERT INTO `myorder` VALUES (3,'郭富城','c004,c001','2,4');
INSERT INTO `myorder` VALUES (4,'张学友','c003','5');
//=================
1 刘德华 c001,c003 1,3
2 黎明 c002 2
3 郭富城 c004,c001 2,4
4 张学友 c003 5
//==========================
现在我要在Java中得到的效果是:把想相同产品的数量统计出来如:c001为5,c002为2,c003为3,c004为2;订单编号和数量为varchar2数据类型。
关键是怎么合并同类产品并在得到合并后的数量,我用split截取但难以统计。大家快抢分啊,在明早前此贴有效
编号 名字 订单编号 数量
INSERT INTO `myorder` VALUES (1,'刘德华','c001,c003','1,3');
INSERT INTO `myorder` VALUES (2,'黎明','c002','2');
INSERT INTO `myorder` VALUES (3,'郭富城','c004,c001','2,4');
INSERT INTO `myorder` VALUES (4,'张学友','c003','5');
//=================
1 刘德华 c001,c003 1,3
2 黎明 c002 2
3 郭富城 c004,c001 2,4
4 张学友 c003 5
//==========================
现在我要在Java中得到的效果是:把想相同产品的数量统计出来如:c001为5,c002为2,c003为3,c004为2;订单编号和数量为varchar2数据类型。
关键是怎么合并同类产品并在得到合并后的数量,我用split截取但难以统计。大家快抢分啊,在明早前此贴有效
解决方案 »
- 刚学习JAVA的String遇到一点小问题。求解释
- 关于使用MyEclipse的注意事项请教
- 【推荐】一款实用的Javadoc查阅工具GroovyHelp3.0 GA
- 初学JAVA遇到的一个问题!谢谢!
- 关于java -Xms -Xmx的问题
- 怎样区分MP3文件中存储的内容?例如,区分歌曲和一般录音。
- 新手求助:如何编译多个.java文件?
- VisualAge中!求救!
- 打开一个新窗口的函数是什么?
- javamail如何删除服务器上的邮件?
- DataSource dataSource = (DataSource) context.lookup(WAPSecurityJNDI)
- 如何直接对硬件编写自己的jar包?
2.遍历arr中的每一个元素,将每个元素都存入HashMap中,有则加1,无则计1
3.将所有的记录都按第一步和第二步的方式进行计数.PS:注意HashMap的作用域!
订单为 order,前提,你已经把 order 全部放到了 list中order中一个方法String[] getProductsName() 返回一组产品名
int[] getProductsCount 返回一组产品数量后面的你用 map吧,不写代码
public static void main(String[] args) throws Exception {
String sql = "select * from myorder";
try {
conn = Order.getConn();
pstmt = conn.prepareStatement(sql);
rs = pstmt.executeQuery();
String[] ss = null;
String[] count = null;
String username = null;
String presentID = null;
String presentCount = null;
Map map = new HashMap();
ArrayList<String> array = new ArrayList<String>();
ArrayList<String> arrayNumber = new ArrayList<String>();
HashSet<String> set = new HashSet<String>();
while (rs.next()) {
int orderid = rs.getInt("orderid");
username = rs.getString("username");
presentID = rs.getString("presentID");
presentCount = rs.getString("presentNumber");
ss = presentID.split(",");
count = presentCount.split(",");
int n = 0;
for (int k = 0; k < ss.length; k++) {
array.add(ss[k]);
if (!array.contains(ss[k])) {
n++;
} else {
n=1;
}
}
}
} catch (SQLException e) {
e.printStackTrace();
}
}
这是我的测试代码,下步如何