这段代码摘自我的blog:http://loin.iteye.com/admin/blogs/745323
感觉这种多if else的代码太丑了,请问如何重构
/**
* 返回参数的sql类型,这段代码很丑,如何改
*
* @param prepareParam
* @return
*/
private static int getType(Object prepareParam) {
// TODO Auto-generated method stub
if (prepareParam == null)
return Types.NULL;
if (prepareParam instanceof String) {
return Types.VARCHAR;
} else if (prepareParam instanceof Boolean) {
return Types.BOOLEAN;
} else if (prepareParam instanceof Integer) {
return Types.INTEGER;
} else if (prepareParam instanceof Long) {
return Types.BIGINT;
} else if (prepareParam instanceof Float) {
return Types.FLOAT;
} else if (prepareParam instanceof Double) {
return Types.DOUBLE;
} else if (prepareParam instanceof BigDecimal) {
return Types.NUMERIC;
} else if (prepareParam instanceof Date) {
return Types.TIMESTAMP;
} else if (prepareParam instanceof Short) {
return Types.SMALLINT;
} else if (prepareParam instanceof InputStream) {
return Types.BINARY;
} else {
throw new RuntimeException("没有此类型");
}
}
谢谢
求对多if else的重构方法
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
7条回答 默认 最新
- badonly 2010-08-27 12:49关注
[code="java"]
static enum FieldType {
NULL, VARCHAR, BOOLEAN, INTEGER, BIGINT, FLOAT, DOUBLE, NUMERIC, TIMESTAMP, SMALLINT, BINARY
}private static FieldType getType(Object prepareParam) {
if (prepareParam == null)
return FieldType.NULL;
return FieldType.valueOf(prepareParam.getClass().getSimpleName().toUpperCase());//找不到对应的类型,valueOf会参数异常错误:IllegalArgumentException
}
[/code]枚举是最好的方式
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 程序不包含适用于入口点的静态Main方法
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记