表、java、mybatis的转换

本文介绍了一种Java实用工具类,用于将下划线命名的表名和列名转换为驼峰命名,并提供了MyBatis中参数绑定的解决方案,包括#{deviceId}

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class StringUtils {
	/**
	 * 
	 * @Title: modifyName
	 * @Description: 将表名和列名的命名改为驼峰式
	 * @param name
	 * @param type
	 *            1:表;其他:列
	 * @return
	 * @date 2017年10月20日 下午11:27:30
	 * @author Problem terminator
	 */
	public static String modifyName(String name, int type) {

		String[] arrayOfName = name.split("_");
		String result = null;
		if (arrayOfName.length == 1) {
			result = isFirstToUpperCase(arrayOfName, type);
		} else {
			result = isFirstToUpperCase(arrayOfName, type);
			for (int i = 1; i < arrayOfName.length; i++) {
				result = result + arrayOfName[i].substring(0, 1).toUpperCase() + arrayOfName[i].substring(1);
			}
		}
		return result;
	}

	/**
	 * 
	 * @Title: isFirstToUpperCase
	 * @Description: 判断首字母是否要大写
	 * @param arrayOfName
	 * @param type
	 * @return
	 * @date 2017年10月20日 下午11:28:34
	 * @author Problem terminator
	 */
	public static String isFirstToUpperCase(String[] arrayOfName, int type) {
		String result = null;
		if (1 == type) {
			result = arrayOfName[0].substring(0, 1).toUpperCase() + arrayOfName[0].substring(1);
		} else {
			result = arrayOfName[0];
		}
		return result;
	}

	/**
	 * 列名转换 #{productId} 形式
	 * @Title: joinColumnNameForValuesOfMybatis 
	 * @param columns 列名
	 * @return  #{deviceId},#{mac},#{productId}
	 * @date 2018年11月7日 上午11:07:23
	 * @author yz
	 */
	public static String joinColumnNameForValuesOfMybatis(String prefix,String columns) {
		String[] split = columns.split(",");
		StringBuilder properties = new StringBuilder();
		for (String string : split) {
			properties.append("#").append("{").append((prefix != null ? prefix + "." : "") + StringUtils.modifyName(string, 0)).append("}").append(",");
		}

		return properties.deleteCharAt(properties.length() - 1).toString();
	}

	/**
	 * 列名转换user_id=#{userId}的形式
	 * @Title: joinPropertiesForValuesOfMybatis 
	 * @param columns 列字符串,以逗号隔开:device_id,user_id
	 * @return  device_id=#{deviceId},user_id=#{userId}
	 * @date 2018年11月7日 上午11:08:29
	 * @author yz
	 */
	public static String joinPropertiesForValuesOfMybatis(String columns) {
		String[] split = columns.split(",");
		List<String> list = new ArrayList<String>();
		for (String string : split) {

			String str = "#" + "{" + modifyName(string, 0) + "}";
			list.add(str);
		}

		StringBuilder columnProperties = new StringBuilder();

		for (int i = 0; i < split.length; i++) {
			columnProperties.append(split[i]).append("=").append(list.get(i)).append(",");
		}

		return columnProperties.deleteCharAt(columnProperties.length() - 1).toString();
	}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值