Java中更换Map中的主键key的名称

1、引言

在程序的执行流程中,经常会遇到获取的数据中某一主键需要更改,用以保证后面的程序可以直接进行解析。

以下案例是模拟创建map类并赋值后,修改其中的key并保证value不变。

package action;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class TestMap {
	
	public static void main(String[] args) {
		List<HashMap<String, String>> mapList = new ArrayList<HashMap<String, String>>();
		HashMap<String, String> map = new HashMap<String, String>();
		map.put("extdate", "6");
		map.put("extdate1", "2");
		map.put("extdate2", "3");
		for(Object obj : map.keySet()){
			Object value = map.get(obj);
			System.out.println(obj+":"+value);
			}
		mapList.add(map);
		
		for(HashMap<String, String> maps:mapList) {
			maps.put("B", maps.remove("extdate"));
		}
				
		System.out.println("=======================");
		for(HashMap<String, String> mapa:mapList) {
			for(Object obj : mapa.keySet()){
				Object value = mapa.get(obj);
				System.out.println(obj+":"+value);
				}
		}

	}

}

运行结果:

extdate2:3
extdate1:2
extdate:6
=======================
extdate2:3
extdate1:2
B:6

3、结论

从运行结果可以看出,主键:extdate已经更换为B 。 如果在list中有多个map集合,可以通过循环的形式修改。

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 的 MyBatis ,`ON DUPLICATE KEY UPDATE` 是一种在数据库插入操作处理重复键冲突的机制。它通常用于 MySQL 数据库的插入语句。 当你想要向数据库表插入一行数据,但是该行数据的主键或唯一索引与已存在的数据冲突时,`ON DUPLICATE KEY UPDATE` 语句提供了一种解决方案。它允许你在冲突发生时执行更新操作,而不是简单地抛出错误。 在 MyBatis 的 XML 映射文件,你可以使用 `ON DUPLICATE KEY UPDATE` 语句来处理重复键冲突。以下是一个示例代码: ```xml <!-- your-mapper.xml --> <insert id="insertOrUpdate" parameterType="YourObject"> INSERT INTO your_table (column1, column2, ...) VALUES (#{property1}, #{property2}, ...) ON DUPLICATE KEY UPDATE column1 = #{property1}, column2 = #{property2}, ... </insert> ``` 在上述代码,`INSERT INTO` 子句用于插入数据,`VALUES` 子句用于指定要插入的值。接下来的 `ON DUPLICATE KEY UPDATE` 子句用于指定在出现重复键冲突时执行的更新操作。你可以通过列名和属性名的对应关系来更新相应的列。 需要注意的是,`ON DUPLICATE KEY UPDATE` 仅适用于具有唯一索引或主键约束的列。如果在插入时没有重复键冲突,将会执行插入操作;如果有冲突,将会执行更新操作。 此外,`ON DUPLICATE KEY UPDATE` 语句在不同的数据库可能有所不同,具体的语法和支持程度可能会有差异。请根据你所使用的数据库类型和版本进行相应的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值