- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个枚举如下
public enum OrderStatusEnum {
ACTIVE("A","Active Order"),
AWAITING("I","Awaiting Order")
}
我想将 ACTIVE, AWAITING 保存在数据库中。还可以在查询中检索相同的内容
当实体设置为枚举并通过 JdbcTemplate 保存时,我遇到异常。数据截断异常
问题
我们正在使用MapSqlParameterSource
。
谢谢。
最佳答案
1) 您可以存储“ACTIVE/AWAITING”并使用枚举的 valueOf
方法。
优点:
enum
的 valueOf
。缺点:
例如:
将数据插入表中:
jdbcTemplate.update(
"INSERT INTO orders (id, order_status, description) VALUES (?, ?, ?)",
new Object[] {
order.getId(),
order.getStatus().toString(),
order.getDescription()
}
);
加载数据:
public List<Order> findAllOrders()
{
return jdbcTemplate.query(
"SELECT * FROM orders",
new String[]{},
(rs, rowNum) -> new Order(rs.getInt("id"), OrderStatus.valueOf(rs.getString("order_status")), rs.getString("description"))
);
}
这里的巧妙之处在于,您不需要编写 valueOf
方法,它存在于任何枚举中,请参阅 https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html#valueOf-java.lang.Class-java.lang.String-
2) 您可以使用 shortName
(例如“A”),但您需要遍历所有枚举才能找到正确的枚举。
优点:
缺点:
例如:
要保存,请使用order.getStatus().getShortName()
对于加载使用:getStatus(rs.getString("order_status"))
:
private OrderStatus getStatus(String shortName)
{
switch(shortName)
{
case "A":
return OrderStatus.ACTIVE;
case "I":
return OrderStatus.AWAITING;
default:
throw new RuntimeException("Cannot find order status for short name: " + shortName);
}
}
更新:OrderStatus
枚举声明:
public enum OrderStatus
{
ACTIVE("A","Active Order"),
AWAITING("I","Awaiting Order");
private String shortName;
private String description;
private OrderStatus(String shortName, String description)
{
this.shortName = shortName;
this.description = description;
}
public String getShortName()
{
return shortName;
}
public String getDescription()
{
return description;
}
}
更新 2:OrderStatus 与其所需的数据库表示之间的映射应由您明确进行。如果您想使用 shortName
进行映射,您应该以某种方式在代码中表达它,否则它如何知道您想如何映射它?您可以使用另一种映射方式,这意味着存在不同的方法。例如,有一种方法可以保存 OrderStatus.ordinal()
,然后使用 OrderStatus.values()[rs.getInt("order_status")]
对其进行转换。在这种情况下,您可能会使用更少的空间来存储值,具体取决于您的 DBMS,但如果您添加更多枚举常量,现有常量可能会为 OrderStatus.SOME_ENUM_CONSTANT.ordinal()
获得不同的值,这会导致数据损坏或需要更新数据库中的旧记录,然后启动新版本的应用程序,这就是为什么我没有将此选项包含在映射选项列表中。
关于java - 使用描述和键保存枚举 - MySQL 和 Java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48950919/
在一个环境中,我有 pandas 版本 0.17.0 和 numpy 版本 1.10.1。在另一个环境中,我有 pandas 版本 0.18.1 和 numpy 版本 1.10.4。 我运行这段代码
This question already has answers here: Default stringify for objects, equivalent to Java's toString
我一直在尝试为我的profile命令嵌入设置一个人们可以更改的简历。我认为它应该有效,但我的代码似乎有问题。 相关代码如下: const PREFIX = '!'; var bio = {}; cli
我正在尝试获取网站图标、网站标题和外部 URL 列表的描述,最好使用 jquery。我已经成功地为我的网址同步了谷歌的图标服务,任何人都可以阐明如何实现网站标题和描述吗?这是我到目前为止获得图标的内容
我在尝试运行代码时收到错误。找不到问题出在哪里。我可能遗漏了一些小细节,如果您能纠正它那就太好了。 计算Servlet import java.io.IOException; impo
我的数据库中有两个字段,一个是描述(TEXT),另一个是short_desc(VARCHAR-200)。 当我显示搜索结果时,我显然使用了short_desc,当有人点击该项目时,他们会得到完整的描述
当我尝试通过ajax和Jquery调用 Controller 上的save方法时,我正在使用Spring MVC、Jquery、Hibernate和tomcat。单击“保存”按钮时,我在 tomcat
我试图使用describe()来获取一些描述性统计数据,但获取了应该是数字的nan值。 我尝试使用 axis=0 或 axis=1,而 axis=1 产生了正确的数值,但这不是正确的数值我需要; ax
我有超过 1 亿个字符串要存储在文件系统中。与字符串 (~255Chars utf8) 一起,将有两个日期和一些定义其属性的整数值。 我可以将它们放在一个 CSV 文件中,但它会很大。我可以将几个较小
有没有办法将 JavaScript 合并到 Jenkins 顶部的描述字段中? 每当我添加脚本标签时,当您查看源代码时,它都会被 Jenkins 删除。 如果有人有建议或方向指出我,那就太好了。
您如何获得 SEH 的名称和/或描述?异常无需必须将字符串硬编码到您的应用程序中? 我尝试使用 FormatMessage(),但它有时会截断消息,即使您指定忽略插入也是如此: __asm { //
如果我在 MySQL 中使用 CREATE TRIGGER 语法创建一个触发器,我该如何附加注释来描述它?我的意思是在声明中或之后对我来说是一样的。 我想不通。对于表格,您可以在声明末尾添加 COMM
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
当开发多媒体应用或者游戏应用的时候,需要使用音量控制键来设置程序的音量大小。在Android系统中有多中音频流,通过Activity中的函数 setVolumeControlStream(int s
Slick DSL 允许通过两种方式在表中创建可选字段。 对于这个案例类: case class User(id: Option[Long] = None, fname: String, lname:
如果不属于默认命名空间,我如何描述 pod 信息。使用默认命名空间我没有任何问题。 但我想获得与命名空间对齐的特定 pod 的信息。 但是,当我想描述我可以制作的同一个 pod 时,请参阅 我尝试使用
在我使用过的几乎所有 vim 副本中,程序都会在替换文本后给出更改的描述。 (例如,将显示类似“20 行 92 个替换”之类的内容。) 我现在正在使用默认情况下不这样做的 vim 副本。 是否有一个简
我正在编写规范,需要描述一些 JSON 对象。单独的文本和选项卡往往会使大型 JSON 变得过于困惑。是否有任何在线(最好)工具可以创建类似于 http://www.json.org/ 上的图表的工具
我正在尝试通过 DNS 将我的 Kubernetes 部署连接在一起。 我有一个 Java (Spring Boot) 部署和一个 javascript (node.js) 部署,两者都通过默认的 C
我只是在学习 WebGL 图形编程。 我正在检查包含该语句的某人的代码 // multiply the position by the matrix. gl_Position = vec4((u_ma
我是一名优秀的程序员,十分优秀!