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

相关推荐
Apple_羊先森2 分钟前
ORACLE数据库巡检SQL脚本--19、磁盘读次数最高的前5条SQL语句
数据库·sql·oracle
金牌归来发现妻女流落街头10 分钟前
【从SpringBoot到SpringCloud】
java·spring boot·spring cloud
毅炼10 分钟前
Java 基础常见问题总结(4)
java·后端
GR23423422 分钟前
2025年影视仓TV+手机官方版 内置地址源支持高清直播
java·智能手机·软件
全栈前端老曹38 分钟前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
程序员清风1 小时前
北京回长沙了,简单谈谈感受!
java·后端·面试
神梦流1 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
何中应1 小时前
请求头设置没有生效
java·后端
让学习成为一种生活方式1 小时前
trf v4.09.1 安装与使用--生信工具42-version2
数据库
神梦流1 小时前
GE 引擎的内存优化终局:静态生命周期分析指导下的内存分配与复用策略
linux·运维·服务器