0

在我目前的项目中,我需要抽象不同数据库之间的数据类型异质性。

例如,我在 MySQL 数据库中有一个表。表名是FIRSTTABLE(badgeID *Integer* , pref INT)

我在 Apache-Derby 数据库中有一个表。表名是FIRSTTABLE (badgeID *varchar(12)*, pref INT)

现在,查询组件同时查询 MySQL 数据库和 Apache Derby 数据库,badgeID 为“double”。

我的要求是查询组件不应该知道底层数据库(MySQL 或 Apache Derby)。它的查询应该独立于数据库的类型。

我该如何解决这个问题?我的研究问题不仅限于 MySQL 或 Apache-Derby。为清楚起见,我以 Apache-Derby 和 MySQL 为例。

4

1 回答 1

1

你必须写一个适配器。您的适配器可以是一个 Java 类或多个 Java 类。

根据您的示例,它看起来像这样。

public class DatabaseAdapter {

    private DatabaseType type;

    public DatabaseAdapter(DatabaseType type) {
        this.type = type;
    }

    public ResultSet selectFirstTable(double badgeID) {
        if (type == DatabaseType.Derby) {
            String s = Double.toString(badgeID);
            return derbySelectFirstTable(s);
        } else if (type == DatabaseType.MySQL) {
            int i = (int) badgeID;
            return mysqlSelectFirstTable(i);
        } else {
            return null;
        }
    }

}

public enum DatabaseType {
    MySQL, Derby
}

另一种更好的编码方式是使用接口。同样,使用您的示例,代码看起来像这样。

public interface Database {
    public ResultSet selectFirstTable(double badgeID);
}

public class MySQLDatabase implements Database {

    public ResultSet selectFirstTable(double badgeID) {
         int i = (int) badgeID;
         // code to select first table in MySQL
    }

}

public class DerbyDatabase implements Database {

    public ResultSet selectFirstTable(double badgeID) {
        String s = Double.toString(badgeID);
        // code to select first table in Derby
    }

}

在您的代码中的某处,您将使用正确的数据库类型初始化数据库接口。

Database database = null;
if (type == DatabaseType.MySQL) {
    database = new MySQLDatabase();
} else if (type == DatabaseType.Derby) {
    database = new DerbyDatabase();
}
于 2012-10-11T19:35:27.793 回答