我想在部署它的设备中查看在我的应用程序中创建的数据库的内容。我可以在 shell 中使用 sqlite 命令并在模拟器中查看,但不能在真实设备中查看。
谁能知道如何在真实设备中做到这一点?
如果应用程序被标记为可调试,则不需要 root。您可以使用run-as
adb 命令。
例如使用 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
实际上你的真实设备没有root,所以你没有访问 /data/data/<Application>/database/
目录的权限。
只有一个解决方案将该文件复制到外部存储.. 并在SQLiteManager或任何其他SQLite工具中查看它。
我认为您需要有根设备才能访问 sqlite。
看看这个讨论。
尝试这个,
您可以将数据库复制到您的 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");
}
}
希望能帮助到你。
试试这个功能
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);
}
}