4

我想在部署它的设备中查看在我的应用程序中创建的数据库的内容。我可以在 shell 中使用 sqlite 命令并在模拟器中查看,但不能在真实设备中查看。

谁能知道如何在真实设备中做到这一点?

4

5 回答 5

7

如果应用程序被标记为可调试,则不需要 root。您可以使用run-asadb 命令。

例如使用 sqlite :

adb shell "run-as com.your.package sqlite3 databases/database_name"

或复制并拉取数据库:

adb shell "run-as com.your.package cat databases/database_name > /sdcard/some_name"
adb pull /sdcard/some_name

不幸的是,似乎 pre-ICSrun-as有很多错误,例如问题2079213965

于 2013-01-04T13:01:29.643 回答
2

实际上你的真实设备没有root,所以你没有访问 /data/data/<Application>/database/目录的权限。

只有一个解决方案将该文件复制到外部存储.. 并在SQLiteManager或任何其他SQLite工具中查看它。

于 2013-01-04T10:40:08.403 回答
1

我认为您需要有根设备才能访问 sqlite。

看看这个讨论

于 2013-01-04T10:41:34.167 回答
0

尝试这个,

您可以将数据库复制到您的 sdcard 中,您可以在其中看到您的数据库

   public void backup() {
        try {
            File sdcard = Environment.getExternalStorageDirectory();
            File outputFile = new File(sdcard,
                    "YourDatabase.db");

            if (!outputFile.exists()) 
                 outputFile.createNewFile(); 

            File data = Environment.getDataDirectory();
            File inputFile = new File(data,
                    "data/"+getPackageName()+"/databases/"+"YourDatabase.db");
            InputStream input = new FileInputStream(inputFile);
            OutputStream output = new FileOutputStream(outputFile);
            byte[] buffer = new byte[1024];
            int length;
            while ((length = input.read(buffer)) > 0) {
                output.write(buffer, 0, length);
            }
            output.flush();
            output.close();
            input.close();
        } catch (IOException e) {
            e.printStackTrace();
            throw new Error("Copying Failed");
        }
    }

希望能帮助到你。

于 2013-01-04T10:45:55.547 回答
0

试试这个功能

copyFile(new File("data/data/<app>/database"),new File("mnt/sdcard/....")).

public void copyFile(File filesrc, File filedst)
 {
  try
 {
  FileInputStream localFileInputStream = new FileInputStream(filesrc);
  FileOutputStream localFileOutputStream = new FileOutputStream(filedst);
  byte[] arrayOfByte = new byte[1024];
  while (true)
  {
    int i = localFileInputStream.read(arrayOfByte);
    if (i == -1)
    {
      localFileOutputStream.close();
      localFileInputStream.close();
      break;
    }
    localFileOutputStream.write(arrayOfByte, 0, i);
  }
}
catch (Exception localException)
{
  Log.d("XXX", "ExceptioncopyFile:" + localException.getMessage(), localException);
}

}

于 2013-01-04T10:46:44.187 回答