Greendao-orm数据库锁定错误

时间:2013-05-21 18:09:06

标签: android greendao

我使用greendao得到了小盒数据库错误。我使用正确的库,一切都工作了一段时间,但突然我收到以下内容: (我有HTC Desire with JB 4.2.2.AOPK) NoClassDefFoundError的

  

05-21 19:45:47.639:E / AndroidRuntime(9715):致命异常:主要   05-21 19:45:47.639:E / AndroidRuntime(9715):   java.lang.NoClassDefFoundError:com.schonherz.dbentities.DaoMaster   05-21 19:45:47.639:E / AndroidRuntime(9715):at   com.schonherz.dbentities.DaoMaster $ OpenHelper.onCreate(DaoMaster.java:69)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:252)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   com.schonherz.flottadroid.LoginActivity.onCreate(LoginActivity.java:95)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.app.Activity.performCreate(Activity.java:5104)05-21   19:45:47.639:E / AndroidRuntime(9715):at   android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2260)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2356)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.app.ActivityThread.access $ 600(ActivityThread.java:150)05-21   19:45:47.639:E / AndroidRuntime(9715):at   android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1244)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   android.os.Handler.dispatchMessage(Handler.java:99)05-21   19:45:47.639:E / AndroidRuntime(9715):at   android.os.Looper.loop(Looper.java:137)05-21 19:45:47.639:   E / AndroidRuntime(9715):at   android.app.ActivityThread.main(ActivityThread.java:5195)05-21   19:45:47.639:E / AndroidRuntime(9715):at   java.lang.reflect.Method.invokeNative(Native Method)05-21   19:45:47.639:E / AndroidRuntime(9715):at   java.lang.reflect.Method.invoke(Method.java:511)05-21 19:45:47.639:   E / AndroidRuntime(9715):at   com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:795)   05-21 19:45:47.639:E / AndroidRuntime(9715):at   com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)05-21   19:45:47.639:E / AndroidRuntime(9715):at   dalvik.system.NativeStart.main(原生方法)

这是我的活动:

package com.schonherz.flottadroid;

import java.util.ArrayList;
import java.util.List;

import org.json.JSONArray;
import org.json.JSONObject;

import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.database.sqlite.SQLiteDatabase;
import android.os.AsyncTask;
import android.os.Bundle;
import android.preference.PreferenceManager;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

import com.schonherz.classes.JsonArrayToArrayList;
import com.schonherz.classes.JsonFromUrl;
import com.schonherz.classes.NetworkUtil;
import com.schonherz.classes.SessionManager;
import com.schonherz.dbentities.AutoDao;
import com.schonherz.dbentities.AutoKepDao;
import com.schonherz.dbentities.DaoMaster;
import com.schonherz.dbentities.DaoMaster.DevOpenHelper;
import com.schonherz.dbentities.DaoSession;
import com.schonherz.dbentities.MunkaDao;
import com.schonherz.dbentities.MunkaEszkozDao;
import com.schonherz.dbentities.MunkaKepDao;
import com.schonherz.dbentities.MunkaTipusDao;
import com.schonherz.dbentities.PartnerDao;
import com.schonherz.dbentities.PartnerKepDao;
import com.schonherz.dbentities.ProfilKepDao;
import com.schonherz.dbentities.Sofor;
import com.schonherz.dbentities.SoforDao;
import com.schonherz.dbentities.SoforDao.Properties;
import com.schonherz.dbentities.TelephelyDao;

public class LoginActivity extends Activity {

// Handle first start from preference
SharedPreferences preferences;
long firstStart;

// Database Handlers
private SQLiteDatabase db;
private DevOpenHelper helper;
private DaoSession daoSession;
private DaoMaster daoMaster;

// Greendao objects
private AutoDao autoDao;
private AutoKepDao autoKepDao;
private MunkaDao munkaDao;
private MunkaEszkozDao munkaEszkozDao;
private MunkaKepDao munkaKepDao;
private MunkaTipusDao munkaTipusDao;
private PartnerDao partnerDao;
private PartnerKepDao partnerKepDao;
private ProfilKepDao profilKepDao;
private SoforDao soforDao;
private TelephelyDao telephelyDao;



private SessionManager sessionManager;
private boolean isRefreshed;


Button loginButton;
ProgressDialog dialog;

EditText userEditText;
EditText passEditText;

Context context;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);

    context=getApplicationContext();
    sessionManager=new SessionManager(context);
    isRefreshed=false;

    helper = new DaoMaster.DevOpenHelper(this, "flotta-db", null);
    db = helper.getWritableDatabase();
    daoMaster = new DaoMaster(db);
    daoSession = daoMaster.newSession();

    preferences = PreferenceManager.getDefaultSharedPreferences(this);
    firstStart = preferences.getLong("firstStart", 0);

    userEditText = (EditText) findViewById(R.id.editTextUser);
    passEditText = (EditText) findViewById(R.id.editTextPass);

    userEditText.setText("sofor1");
    passEditText.setText("sofor1");

    // First start, full DB init, get soforTable
    if (firstStart == 0) {

        createTables();

        SharedPreferences.Editor editor = preferences.edit();
        editor.putLong("firstStart", 1);
        editor.commit();
        editor = null;

        if (NetworkUtil.checkInternetIsActive(context) == false) {

            Toast.makeText(this, R.string.no_internet, Toast.LENGTH_SHORT)
                    .show();
        }

    } else {
        // Get a Session and init sofor Table


        soforDao = daoSession.getSoforDao();
    }

        // If internet connection OK, drop sofor Table and get new table
        if (NetworkUtil.checkInternetIsActive(context) == true) {

            new AsyncTask<Void, Void, Boolean>() {

                @Override
                protected void onPreExecute() {
                    // TODO Auto-generated method stub
                    super.onPreExecute();
                }

                @Override
                protected void onPostExecute(Boolean result) {
                    // TODO Auto-generated method stub
                    super.onPostExecute(result);

                    if (result == true) {
                        isRefreshed=true;
                        loginButton.setEnabled(true);
                        Toast.makeText(LoginActivity.this,
                                R.string.refreshed, Toast.LENGTH_SHORT)
                                .show();                            
                    }
                    else
                    {
                        Toast.makeText(LoginActivity.this, R.string.errorRefresh, Toast.LENGTH_SHORT).show();
                    }
                }

                @Override
                protected Boolean doInBackground(Void... params) {
                    // TODO Auto-generated method stub
                    return saveSoforTable();
                }

            }.execute();
        }


    loginButton = (Button) findViewById(R.id.buttonEntry);
    loginButton.setEnabled(false);
    loginButton.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            // Start main activity
            if (checkLogin() == true) {
                Intent intent = new Intent(LoginActivity.this,
                        MainActivity.class);
                intent.putExtra("isRefreshed", isRefreshed);
                LoginActivity.this.startActivity(intent);
                LoginActivity.this.finish();
            } else {
                Toast.makeText(LoginActivity.this,
                        R.string.wrongCredential, Toast.LENGTH_SHORT)
                        .show();
            }

        }
    });
}

public boolean saveSoforTable() {
    JSONArray jsonArray;
    JSONObject json;

    String serverAddres = "http://www.flotta.host-ed.me/querySoforTable.php";

    json = new JSONObject();

    try {

        jsonArray = (JSONArray) JsonFromUrl.getJsonObjectFromUrl(
                serverAddres, json.toString());

        // Eldobjuk a tablat es ujra letrehozzuk
        soforDao.dropTable(soforDao.getDatabase(), true);
        soforDao.createTable(soforDao.getDatabase(), true);


        ArrayList<Sofor> soforok = JsonArrayToArrayList
                .JsonArrayToSofor(jsonArray);

        for (int i = 0; i < soforok.size(); i++) {
            soforDao.insert(soforok.get(i));                
        }
        return true;
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();

        return false;
    }


}

@Override
public void finish() {
    // TODO Auto-generated method stub
    super.finish();
    overridePendingTransition(R.anim.slide_in_right, R.anim.slide_out_left);
}

// Tabla letrehozo metodus, elso inditaskor mindekepp lefut
private void createTables() {

    autoDao = daoSession.getAutoDao();
    autoKepDao = daoSession.getAutoKepDao();
    munkaDao = daoSession.getMunkaDao();
    munkaEszkozDao = daoSession.getMunkaEszkozDao();
    munkaKepDao = daoSession.getMunkaKepDao();
    munkaTipusDao = daoSession.getMunkaTipusDao();
    partnerDao = daoSession.getPartnerDao();
    partnerKepDao = daoSession.getPartnerKepDao();
    profilKepDao = daoSession.getProfilKepDao();
    soforDao = daoSession.getSoforDao();
    telephelyDao = daoSession.getTelephelyDao();

    autoDao.createTable(db, true);
    autoKepDao.createTable(db, true);
    munkaDao.createTable(db, true);
    munkaEszkozDao.createTable(db, true);
    munkaKepDao.createTable(db, true);
    munkaTipusDao.createTable(db, true);
    partnerDao.createTable(db, true);
    partnerKepDao.createTable(db, true);
    profilKepDao.createTable(db, true);
    soforDao.createTable(db, true);
    telephelyDao.createTable(db, true);

}

public String update() {
    return "";
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.login, menu);
    return true;
}   

public boolean checkLogin() {
    if (!userEditText.getText().toString().equals("")) {
        if (!passEditText.getText().toString().equals("")) {

            // Ez csak bemutatato, a loadAll() az a select * from
            List<Sofor> sofors = soforDao.loadAll();

            // Where-ben 2 feltetellel lekerdezes, a Properties az a
            // SoforDao properties osztalya importalva
            // Minden tablanak van minden rekordjara egy property, amihez
            // lehet hasonlita
            List<Sofor> soforok = soforDao
                    .queryBuilder()
                    .where(Properties.SoforLogin.eq(userEditText.getText()
                            .toString()),
                            Properties.SoforPass.eq(passEditText.getText()
                                    .toString())).list();

            if (soforok.size() > 0) {
                sessionManager.createLoginSession(soforok.get(0).getSoforLogin(), soforok.get(0).getSoforPass(), soforok.get(0).getSoforID());
                return true;
            } else {
                return false;
            }

        } else {
            Toast.makeText(LoginActivity.this, R.string.wrongCredential,
                    Toast.LENGTH_SHORT).show();
        }
    } else {
        Toast.makeText(LoginActivity.this, R.string.wrongCredential,
                Toast.LENGTH_SHORT).show();
    }

    return false;
}

}

提前致谢!

2 个答案:

答案 0 :(得分:0)

NoClassDefFoundError - Eclipse and Android

这个主题帮助了我,在此问题之前我有一个ADT更新。

答案 1 :(得分:0)

当您尝试一次打开与数据库的多个连接时会发生这种情况。确保一次只运行一个连接(我相信你的onCreate函数会被多次调用,因为你可能从app切换到app)。最好将初始化移动到构造函数左右。