- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何使用从数据库读取的类型以及如何在代码中提供类型安全?
前提条件
给定的是一个包含各种类型列的数据库表。 “A”列包含字符串值“A”、“B”、“C”。“B”列包含字符串值“X”、“Y”、“Z”。
用法示例
为了保证类型安全,我宁愿将这些值包装在枚举周围并使用类型,而不是将这些值直接用作字符串。
类似这样的事情:
public class TypeSafetyExample {
/**
* TypeA: map string type to enum type.
*/
public enum TypeA {
A("A"),
B("B"),
C("C");
String id;
TypeA( String id) {
this.id = id;
}
public static TypeA get( String id) {
for( TypeA item: EnumSet.allOf(TypeA.class)) {
if( item.id.equals(id)) {
return item;
}
}
throw new IllegalArgumentException("Unsupported enum id: " + id);
}
}
/**
* TypeB: map string type to enum type and give it some other attribute.
*/
public enum TypeB {
X("X", true),
Y("Y", true),
Z("Z", false);
String id;
boolean someAttribute;
TypeB( String id, boolean someAttribute) {
this.id = id;
this.someAttribute = someAttribute;
}
public boolean isSomeAttribute() {
return this.someAttribute;
}
public static TypeB get( String id) {
for( TypeB item: EnumSet.allOf(TypeB.class)) {
if( item.id.equals(id)) {
return item;
}
}
throw new IllegalArgumentException("Unsupported enum id: " + id);
}
}
/**
* Object using enums as types.
*/
public static class MyObjectTyped {
TypeA typeA;
TypeB typeB;
public String toString() {
return "Type A: " + typeA + ", Type B: " + typeB;
}
}
/**
* Object using strings as types.
*/
public static class MyObjectUntyped {
String typeA;
String typeB;
public String toString() {
return "Type A: " + typeA + ", Type B: " + typeB;
}
}
/**
* Example usage.
* @param args
*/
public static void main(String[] args) {
MyObjectTyped objTyped;
MyObjectUntyped objUntyped;
// ... here we would read data from the database and create our typed objects ...
objTyped = new MyObjectTyped();
objTyped.typeA = TypeA.get( "A");
objTyped.typeB = TypeB.get( "X");
System.out.println( objTyped); // Type A: A, Type B: X
objTyped = new MyObjectTyped();
objTyped.typeA = TypeA.get( "A");
objTyped.typeB = TypeB.get( "?"); // Runtime Error during database read: java.lang.IllegalArgumentException: Unsupported enum id: ?
objUntyped = new MyObjectUntyped();
objUntyped.typeA = "???"; // no error at all, probably we'll get a runtime error or some inconsistency later, but never during database loading
objUntyped.typeB = "???"; // no error at all, probably we'll get a runtime error or some inconsistency later, but never during database loading
System.exit(0);
}
}
基本上,对于每种类型都会创建一个枚举,并将数据库字符串类型映射到该枚举。在java代码中只使用枚举,而不使用字符串。
枚举的优点:
枚举的缺点:
字符串的优点:
字符串的缺点:
您对这些概念有何看法?你更倾向哪个?或者还有更好的方法吗?我宁愿坚持类型安全,因为代码的稳定性是值得的。另一方面,每当添加新类型时就进行代码更改也不是一个好的做法。
感谢您的意见!
最佳答案
这完全取决于您如何使用这些字符串。您的代码的逻辑是否取决于实际值,或者只是您从数据库中读取的内容,也许以某种方式进行转换并呈现给用户或发送给其他消费者?
如果是前者,则可能需要枚举。
另请注意,如果您想确保字符串属于已知的有效集,则可以在数据库级别强制实现约束。因此,“数据库可以包含任何内容”并不是真的。
一般来说,如果您确实使用数据库,那么它应该是您放置在那里的数据的一致性和有效性的“事实来源”。这就是数据库的用途,也是它们所擅长的。将垃圾扔到数据存储中,然后依靠应用程序代码对其进行清理根本不是一个好主意。
关于Java数据库字符串类型和类型安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27454103/
如何使用 SPListCollection.Add(String, String, String, String, Int32, String, SPListTemplate.QuickLaunchO
我刚刚开始使用 C++ 并且对 C# 有一些经验,所以我有一些一般的编程经验。然而,似乎我马上就被击落了。我试过在谷歌上寻找,以免浪费任何人的时间,但没有结果。 int main(int argc,
这个问题已经有答案了: In Java 8 how do I transform a Map to another Map using a lambda? (8 个回答) Convert a Map>
我正在使用 node + typescript 和集成的 swagger 进行 API 调用。我 Swagger 提出以下要求 http://localhost:3033/employees/sear
我是 C++ 容器模板的新手。我收集了一些记录。每条记录都有一个唯一的名称,以及一个字段/值对列表。将按名称访问记录。字段/值对的顺序很重要。因此我设计如下: typedef string
我需要这两种方法,但j2me没有,我找到了一个replaceall();但这是 replaceall(string,string,string); 第二个方法是SringBuffer但在j2me中它没
If string is an alias of String in the .net framework为什么会发生这种情况,我应该如何解释它: type JustAString = string
我有两个列表(或字符串):一个大,另一个小。 我想检查较大的(A)是否包含小的(B)。 我的期望如下: 案例 1. B 是 A 的子集 A = [1,2,3] B = [1,2] contains(A
我有一个似乎无法解决的小问题。 这里...我有一个像这样创建的输入... var input = $(''); 如果我这样做......一切都很好 $(this).append(input); 如果我
我有以下代码片段 string[] lines = objects.Split(new string[] { "\r\n", "\n" }, StringSplitOptions.No
这可能真的很简单,但我已经坚持了一段时间了。 我正在尝试输出一个字符串,然后输出一个带有两位小数的 double ,后跟另一个字符串,这是我的代码。 System.out.printf("成本:%.2
以下是 Cloud Firestore 列表查询中的示例之一 citiesRef.where("state", ">=", "CA").where("state", "= 字符串,我们在Stack O
我正在尝试检查一个字符串是否包含在另一个字符串中。后面的代码非常简单。我怎样才能在 jquery 中做到这一点? function deleteRow(locName, locID) { if
这个问题在这里已经有了答案: How to implement big int in C++ (14 个答案) 关闭 9 年前。 我有 2 个字符串,都只包含数字。这些数字大于 uint64_t 的
我有一个带有自定义转换器的 Dozer 映射: com.xyz.Customer com.xyz.CustomerDAO customerName
这个问题在这里已经有了答案: How do I compare strings in Java? (23 个回答) 关闭 6 年前。 我想了解字符串池的工作原理以及一个字符串等于另一个字符串的规则是
我已阅读 this问题和其他一些问题。但它们与我的问题有些无关 对于 UILabel 如果你不指定 ? 或 ! 你会得到这样的错误: @IBOutlet property has non-option
这两种方法中哪一种在理论上更快,为什么? (指向字符串的指针必须是常量。) destination[count] 和 *destination++ 之间的确切区别是什么? destination[co
This question already has answers here: Closed 11 years ago. Possible Duplicates: Is String.Format a
我有一个Stream一个文件的,现在我想将相同的单词组合成 Map这很重要,这个词在 Stream 中出现的频率. 我知道我必须使用 collect(Collectors.groupingBy(..)
我是一名优秀的程序员,十分优秀!