gpt4 book ai didi

Java数据库字符串类型和类型安全

转载 作者:行者123 更新时间:2023-12-01 12:08:03 25 4
gpt4 key购买 nike

如何使用从数据库读取的类型以及如何在代码中提供类型安全?

前提条件

给定的是一个包含各种类型列的数据库表。 “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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com