例如,用一个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方法,你可以从数据库行中安全地获取列的值,并指定期望的值类型。这种设计提高了类型安全性,确保了在运行时不会出现类型错误。

相关推荐
麦兜*9 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
chat2tomorrow12 分钟前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
a5876912 分钟前
消息队列(MQ)初级入门:详解RabbitMQ与Kafka
java·分布式·microsoft·面试·kafka·rabbitmq
稻草人想看远方14 分钟前
关系型数据库和非关系型数据库
数据库
考虑考虑15 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
千里码aicood24 分钟前
【springboot+vue】党员党建活动管理平台(源码+文档+调试+基础修改+答疑)
java·数据库·spring boot
Chan1628 分钟前
【智能协同云图库】基于统一接口架构构建多维度分析功能、结合 ECharts 可视化与权限校验实现用户 / 管理员图库统计、通过 SQL 优化与流式处理提升数据
java·spring boot·后端·sql·spring·intellij-idea·echarts
先做个垃圾出来………33 分钟前
差分数组(Difference Array)
java·数据结构·算法
对你无可奈何35 分钟前
关于Ubuntu的 update造成的内核升级
运维·服务器·ubuntu
TDengine (老段)1 小时前
TDengine 选择函数 Max() 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据