java - 使用 SQLite (android) 存储数据的问题

标签 java android sqlite emulation

一直在网上发疯,寻找答案。

目前,我正在构建一个使用 SQLite 数据库的 android 应用程序。 一切都设置好了,注册工作,登录工作,我连接了相机并可以拍照,照片保存到我的本地画廊。但是,以下内容不起作用:

  • 模拟器不工作。在我的手机上测试。
  • DDMS 没有显示我的数据库。
  • CPU 不支持所需的功能 VT-x 或 SVM。

但是,要点是,我一直在到处寻找 SQLiteDB。 android studio 在哪里存储 SQLiteDB 的数据库?

此外,我尝试将数据写入手机的本地存储,但也没有用:

public class DBUtil {

//Because of the fact that laptop refuses to let me use an emulator, data gets saved to my phone directory, folder DataAndroid
final static String FOLDER_EXTERNAL_DIRECTORY = Environment.getExternalStorageDirectory()+ "/DataAndroid";

//saving the data in my local data folder
public static void  copyDatabaseToExtStg(Context context){

    //external storage file
    File externalDirectory = new File(FOLDER_EXTERNAL_DIRECTORY);

    if(!externalDirectory.exists())
        externalDirectory.mkdirs();
    File toFile = new File(externalDirectory, DBHelper.DATABASE_NAME);
    //internal storage file
    File fromFile = context.getDatabasePath(DBHelper.DATABASE_NAME);
    if (fromFile.exists())
        copy(fromFile, toFile);
}

//copy from making the file to 'writing' the file
static void copy(File fromFile, File toFile) {
    try {
        FileInputStream is = new FileInputStream(fromFile);
        FileChannel src = is.getChannel();
        FileOutputStream os = new FileOutputStream(toFile);
        FileChannel dst = os.getChannel();
        dst.transferFrom(src, 0, src.size());
        src.close();    is.close();
        dst.close();    os.close();
    } catch (Exception e) {
    }

}

我的 DBHelper 类如下所示:

public class DBHelper extends SQLiteOpenHelper {

//db attr.
SQLiteDatabase DataBase;

//confirm password doesn't need to be stored, it is just a small check up
private static final int DATABASE_VERSION = 1;
public static final String DATABASE_NAME = "contacts.db";
private static final String TABLE_NAME = "contacts";
private static final String COLUMN_ID = "id";
private static final String COLUMN_NAME = "name";
private static final String COLUMN_SURNAME = "surname";
private static final String COLUMN_EMAIL = "email";
private static final String COLUMN_USERNAME = "username";
private static final String COLUMN_PASSWORD = "password";
//constructor
public DBHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

//create table +TABLE_NAME
private static final String TABLE_CREATE = "create table contacts(id integer primary key not null , " +
        "name text not null, surname text not null, email text not null, username text not null, password text not null);";

@Override
public void onCreate(SQLiteDatabase DataBase) {
    DataBase.execSQL(TABLE_CREATE);
    this.DataBase = DataBase;
}

public void insertContact(Contact contact){

    //To be able to insert anything in DB, it should be writeable.
    //Because of the fact that password.equals(confirmpassword), COLUMN_CONFPASS. is missing in list below
    DataBase = this.getWritableDatabase();
    ContentValues values = new ContentValues();

    String query = "SELECT * FROM contacts";
    Cursor cursor = DataBase.rawQuery(query, null);
    int count = cursor.getCount();

    //To make sure that the count increments, istead of assigning same number to different numbers.
    values.put(COLUMN_ID, count);
    values.put(COLUMN_NAME, contact.getName());
    values.put(COLUMN_SURNAME, contact.getSurname());
    values.put(COLUMN_EMAIL, contact.getEmail());
    values.put(COLUMN_USERNAME, contact.getUsername());
    values.put(COLUMN_PASSWORD, contact.getPassword());

    //Insert contact object into DB
    DataBase.insert(TABLE_NAME, null, values);
    DataBase.close();
}

//Keeping DB up to date
@Override
public void onUpgrade(SQLiteDatabase DataBase, int CurrentVersionOld, int NewVersion) {
    String query = "DROP TABLE IF EXISTS "+TABLE_NAME;
    DataBase.execSQL(query);
    this.onConfigure(DataBase);

}

//Read the DB
public String searchPassword(String username) {

    DataBase = this.getReadableDatabase();
    String query = "SELECT username, password FROM " + TABLE_NAME;
    Cursor cursor = DataBase.rawQuery(query, null);
    String uname, pw;


    //If the password is not found, then print:
    pw = "not found";

    if (cursor.moveToFirst()) {

        do {
            //assign index to username(0) and password (1)
            uname = cursor.getString(0);
            pw = cursor.getString(1);

            if (uname.equals(username)) {
                pw = cursor.getString(1);
                break;
            }
        } while (cursor.moveToNext());

    } return pw;
}

有人可以帮帮我吗? 我的编码不是很好。请耐心等待 :)(新手)

最佳答案

Where does android studio store the databases for SQLiteDB?

如果您在模拟器中运行,此链接可能对您有帮助

https://stackoverflow.com/a/28339178/5156075

如果您使用的是手机,您可以从 google play 商店下载 SQLite Manager

这里是链接 https://play.google.com/store/apps/details?id=com.xuecs.sqlitemanager&hl=en

关于java - 使用 SQLite (android) 存储数据的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40668083/

相关文章:

android - Ormlite Android 批量插入

java - 在数据表 primefaces 中看不到行

java - ArrayList 到 DavidWebb Android

android - Cordova 安卓 FileReader.readAsDataURL NOT_FOUND_ERR

android - 在 Wifi 到 3G 或 3G 到 Wifi 之间切换后,Web 服务调用不起作用

.net - System.Data.SQLite 如何处理 .NET 数据类型?

java - 多线程与多个应用程序

java - 实现接口(interface)的 Java 类可以自动继承注释吗?

java - 如何使用 Maven 发布插件跳过集成测试

python - 我可以将我的 sqlite 连接和游标放在一个函数中吗?