基本 ORMLite DAO クラスを拡張して、いくつかのカスタム メソッドを追加できるようにしようとしています。ここで答えに従ってみましたが、null エラーが発生し、dao オブジェクトを正しくキャストする方法がわかりません ( Ormlite - BaseDaoImpl が拡張されたときにコンストラクター呼び出しが失敗する) 現在、次の表があります。
@DatabaseTable(tableName="beers", daoClass=BeerDao.class)
public class Beer {
public static final String BEER_NAME = "name";
@DatabaseField(generatedId = true)
private UUID id = UUID.randomUUID();
@DatabaseField()
private String name;
@DatabaseField()
private String breweryName;
public Beer() {}
... getters/setters
}
BeerDao クラス:
public class BeerDao<Beer,UUID> extends BaseDaoImpl<Beer,UUID> {
public BeerDao(ConnectionSource connectionSource, Class<Beer> dataClass) throws SQLException {
super(connectionSource, dataClass);
}
}
データベースヘルパー コード:
public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
private static final String TAG = "Database";
private static final String DATABASE_NAME = "brewgenius.db";
private static final int DATABASE_VERSION = 7;
private BeerDao<Beer, UUID> beerDao = null;
private Dao<Checkin, UUID> checkinDao = null;
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION, R.raw.ormlite_config);
}
/* ... onCreate and onUpgrade code ..*/
/**
* Get Beer Model DAO
*
* @return Beer DAO
*/
public BeerDao<Beer, UUID> getBeerDao() {
if (beerDao == null) {
try {
beerDao = getDao(Beer.class);
} catch (SQLException e) {
e.printStackTrace();
}
}
return beerDao;
}
}
私のアクティビティでは、Dao を取得しようとすると、null ポインター例外が発生します。
BeerDao<Beer,UUID> dao = getHelper().getBeerDao();
参考までに、Dao は次のようにキャストされます。
BeerDao<Beer,UUID>
アップデート
私の DatabaseConfigUtil が DaoClass 属性を読み取っていないようです。
public class DatabaseConfigUtil extends OrmLiteConfigUtil {
public static void main(String[] args) throws SQLException, IOException {
writeConfigFile("ormlite_config.txt");
}
}
DatabaseHelper のコンストラクターから ormlite_config.txt を削除すると、DaoClass 属性を正しく読み取るオンザフライ読み取りが発生しました。作家がこれを書かない理由は何ですか?
ここに ormlite_config.txt があります
# --table-start--
dataClass=com.brewgenius.model.Beer
tableName=beers
# --table-fields-start--
# --field-start--
fieldName=id
columnName=_id
generatedId=true
# --field-end--
# --field-start--
fieldName=name
# --field-end--
# --field-start--
fieldName=breweryName
# --field-end--
# --table-fields-end--
# --table-end--
#################################