例如,用一个DatabaseRow类型表示一个数据库行(容器),用泛型Column<T>作为它的键

以下是一个简单的示例,演示如何使用泛型的Column<T>作为DatabaseRow的键,表示一个数据库行(容器):

java 复制代码
// 列定义
class Column<T> {
    private String columnName;
    private T value;

    public Column(String columnName, T value) {
        this.columnName = columnName;
        this.value = value;
    }

    public String getColumnName() {
        return columnName;
    }

    public T getValue() {
        return value;
    }
}

// 数据库行
class DatabaseRow {
    private Map<String, Column<?>> columns = new HashMap<>();

    // 添加列到数据库行
    public <T> void addColumn(Column<T> column) {
        columns.put(column.getColumnName(), column);
    }

    // 获取列的值
    public <T> T getColumnValue(String columnName, Class<T> valueType) {
        Column<?> column = columns.get(columnName);
        if (column != null && valueType.isInstance(column.getValue())) {
            return valueType.cast(column.getValue());
        }
        return null;
    }
}

public class DatabaseExample {
    public static void main(String[] args) {
        // 创建数据库行
        DatabaseRow row = new DatabaseRow();

        // 添加不同类型的列
        Column<String> nameColumn = new Column<>("Name", "John Doe");
        Column<Integer> ageColumn = new Column<>("Age", 25);
        Column<Double> salaryColumn = new Column<>("Salary", 50000.0);

        row.addColumn(nameColumn);
        row.addColumn(ageColumn);
        row.addColumn(salaryColumn);

        // 获取列的值
        String name = row.getColumnValue("Name", String.class);
        Integer age = row.getColumnValue("Age", Integer.class);
        Double salary = row.getColumnValue("Salary", Double.class);

        // 输出列的值
        System.out.println("Name: " + name);
        System.out.println("Age: " + age);
        System.out.println("Salary: " + salary);
    }
}

在这个例子中,Column<T>表示数据库行的列,具有列名和对应的值。DatabaseRow表示整个数据库行,包含了多个列。使用泛型的好处在于可以存储不同类型的列,并且在获取列的值时能够进行类型安全的检查。

通过addColumn方法,你可以向数据库行添加不同类型的列。而通过getColumnValue方法,你可以从数据库行中安全地获取列的值,并指定期望的值类型。这种设计提高了类型安全性,确保了在运行时不会出现类型错误。

相关推荐
cui_win2 分钟前
Prometheus实战教程 - Redis 监控
数据库·redis·prometheus
AM越.15 分钟前
Java设计模式详解--装饰器设计模式(含uml图)
java·设计模式·uml
59803541532 分钟前
【java工具类】小数、整数转中文大写
android·java·开发语言
JIngJaneIL40 分钟前
基于java + vue个人博客系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
TG:@yunlaoda360 云老大1 小时前
华为云国际站代理商备份策略设置过程中遇到问题如何解决?
服务器·数据库·华为云
吃喝不愁霸王餐APP开发者1 小时前
Java后端服务在对接全国性霸王餐API时的多数据中心部署与就近调用策略
java·开发语言
从心归零1 小时前
springboot-jpa的批量更新方法
java·spring boot·spring
SelectDB1 小时前
Doris Catalog 已上线!性能提升 200x,全面优于 JDBC Catalog,跨集群查询迈入高性能分析时代
数据库·数据分析·apache
这周也會开心1 小时前
128陷阱,==与equals区别
java·开发语言
TAEHENGV1 小时前
进度跟踪模块 Cordova 与 OpenHarmony 混合开发实战
android·javascript·数据库