5

私は ORmlite を使用して db アプリケーションに取り組んでいます。私のモデルは次のようなものです。

MDL オブジェクト..

DatabaseTable(tableName = "UserCars")
public class CarMDL
{
    @DatabaseField(generatedId = true)
    private int _id;

    @DatabaseField(columnName = "name")
    private String _name;

//................. etc
}

// DB Helper class...

public class DatabaseHelper extends OrmLiteSqliteOpenHelper
{
    private Dao<CarMDL,Integer> _carDao = null;

 @Override
    public void onCreate(SQLiteDatabase database,ConnectionSource connectionSource)
    {
        try 
        {
            TableUtils.createTable(connectionSource, CarMDL.class);

        } catch (SQLException e)
        {
            throw new RuntimeException(e);
        } catch (java.sql.SQLException e)
        {
            e.printStackTrace();
        }

    }

  public Dao<CarMDL, Integer> getCarDao() 
    {
        if (null == _carDao) 
        {
            try 
            {
                _carDao = getDao(CarMDL.class);

            }catch (java.sql.SQLException e) 
            {
                e.printStackTrace();
            }
        }
        return _carDao;
    }

}

// DatabaseManager class...

public class DatabaseManager
{
    static private DatabaseManager  instance;

    private DatabaseHelper  helper;


    static public void init(Context ctx)
    {
        if (null == instance)
        {
            instance = new DatabaseManager(ctx);
        }
    }

    static public DatabaseManager getInstance()
    {
        return instance;
    }

    private DatabaseManager(Context ctx)
    {
        helper = new DatabaseHelper(ctx);
    }

    private DatabaseHelper getHelper()
    {
        return helper;
    }

// All the Dao functions of all MDL objects are in this class, for example:

public List<CarMDL> getAllCars()
    {
        List<CarMDL> carLists = null;
        try
        {
            carLists = getHelper().getCarDao().queryForAll();
        } catch (SQLException e)
        {
            e.printStackTrace();
        }
        return carLists;
    }

// This is another MDL object..

public List<MarkMDL> getAllMarks()
    {
        List<MarkMDL> marks = null;
        try
        {
            marks = getHelper().getMarkDao().queryForAll();
        } catch (SQLException e)
        {
            e.printStackTrace();
        }
        return marks;       
    }

}

だから私の質問は、次のようなすべてのモデルオブジェクトのすべての機能を備えた DatabaseManager があるのは良いことですか?

listCarById(int id)
listPlaneById(int id)
removeCar(int id)
removePlane(int id)

等.....

4

3 に答える 3

3

グレイのコメントごとに更新。

「シングルトン」の実装には注意してください。あなたのinit方法は、並行性の問題のためにクラスsynchronizedの複数のインスタンスにならないようにすることです。メソッドとメソッドを次のようDatabaseManagerに組み合わせるだけです(追加されたsynchronizedキーワードに注意してください)。initgetInstance

public static synchronized DatabaseManager getInstance(Context c)
{
    if(instance == null)
        instance = new DatabaseManager(c);

    return instance;
}

詳細については、Kevin Galligan (ORMlite の寄稿者の 1 人) による単一 SQLite 接続Android Sqlite ロックに関するこれらのブログ投稿を参照してください。

アップデート:

のようなローディング メソッドを整理する方法についての質問に答えるには、getAllCars最初に を作成することをお勧めしstaticます。これらのタイプのメソッドが少数ある場合は、それらをすべて の静的メンバーにすることができます。多数ある場合は、型に対応するすべての静的メソッドのヘルパー クラスを作成できます。DatabaseManagerstaticDatabaseManger

orの特定のインスタンスの内部に依存するメソッドがある場合(関連付けられた参照を取得するメソッドが必要な場合など)、これらのメソッドをorクラスのメンバーにすることを検討してください。CarMDLMarkMDLCarMDLMarkMDL

于 2012-04-09T20:57:32.767 に答える
0

アプリごとに 1 回限りのすべての作業を Application onCreate に配置し、アプリケーション インスタンス自体の参照を保持しているため、同期されたメソッドなどをいじることなく多くのタスクを実行できます。それでは、アプリケーションがあるとしましょう (忘れずにマニフェストに追加してください):

public class App extends Application
{
    private static App gInstance = null;
    // your static globals here

    @Override
    public void onCreate()
    {
        // according to documentation onCreate is called before any other method
        super.onCreate();
        // assign here all your static stuff
        gInstance = this;
    }

    // doesn't need to be synchronized because of the early onCreate
    public static App getInstance()
    {
        return gInstance;
    }
}

次に、データベース ヘルパー クラスの Manifest.class は、すべてのデータ型クラスの配列です。

public class DatabaseHelper extends OrmLiteSqliteOpenHelper
{
    // private constructor, singleton pattern, we use
    // App context so the class is created on static init
    private static DatabaseHelper gHelper = new DatabaseHelper(App.getInstance());

    private DatabaseHelper(Context context)
    {
        super(context, DATABASE_NAME, null, DATABASE_VERSION, R.raw.ormlite_config);

        // cache your dao here
        for (Class<?> cls: Manifest.classes)
        {
            try
            {
                DaoManager.createDao(getConnectionSource(), cls);
            } catch (SQLException e)
            {
                e.printStackTrace();
            }
        }
    }

    // if you need the instance, you don't need synchronized because of static init
    public static DatabaseHelper getHelper()
    {
        return gHelper;
    }

    // lookup from cache
    public static <D extends Dao<T, ?>, T> D getTypeDao(Class<T> cls)
    {
        return DaoManager.lookupDao(gHelper.getConnectionSource(), cls);
    }

    // we leak this class here since android doesn't provide Application onDestroy
    // it's not really a big deal if we need the orm mapping for all application lifetime
    // Q: should I keep the instance closeable? the android finalyzer calls somehow close here? I was unable to reproduce, to be sure you can call the super.close() and print a warning
    @Override
    public void close()
    {
        throw new RuntimeException("DatabaseHelper Singleton is ethernal");
    }
}
于 2013-04-17T01:31:11.040 に答える