Как отобразить базу данных телефонов SQLite через SDK? - PullRequest
1 голос
/ 22 июня 2010

В настоящее время я занимаюсь некоторой отладкой, и мне было интересно, возможно ли отобразить содержимое базы данных SQLite для телефонов через SDK?Я знаю, что это можно сделать с помощью запросов по телефону.Но мне было просто интересно, не могли бы вы сделать это через SDK?

1 Ответ

4 голосов
/ 22 июня 2010
  • Экспортируйте базу данных в файл SDCard, и каждый раз, когда вам нужно скопировать на свой компьютер и открыть каким-либо инструментом SQLite Manager, я использую для этого плагин Firefox.Просто мне не нужно снова и снова открывать базу данных, просто нажмите кнопку обновления, и таблицы обновятся.

Вы можете использовать Диспетчер файлов Eclipse, чтобы получить файл с устройства,с SDCard, пока он находится в режиме USB.У вас есть эта опция только потому, что вы не можете подключить устройство к Eclipse и одновременно монтировать SD-карту.Вы должны использовать Eclipse.

Вот код для экспорта базы данных в SDCard

/*
     * Task to backup the database to the SDCard
     */
    public static class ExportDatabaseFileTask extends AsyncTask<String, Void, Boolean> {
        private Context ctx;

        /**
         *
         */
        public ExportDatabaseFileTask(Context ctx) {
            super();
            this.ctx=ctx;
        }

        // automatically done on worker thread (separate from UI thread)
        protected Boolean doInBackground(final String... args) {

           File dbFile =
                    new File(Environment.getDataDirectory() + "/data/[com.your.pkg]/databases/[pkg]");

           File exportDir = new File(Environment.getExternalStorageDirectory(), "");
           if (!exportDir.exists()) {
              exportDir.mkdirs();
           }
           File file = new File(exportDir, dbFile.getName());

           try {
              file.createNewFile();
              this.copyFile(dbFile, file);
              return true;
           } catch (IOException e) {
              Log.e("birthdroid", e.getMessage(), e);
              return false;
           }
        }

        // can use UI thread here
        protected void onPostExecute(final Boolean success) {
           if (success) {
              Toast.makeText(ctx, "Export successful!", Toast.LENGTH_SHORT).show();
           } else {
              Toast.makeText(ctx, "Export failed", Toast.LENGTH_SHORT).show();
           }
        }

        void copyFile(File src, File dst) throws IOException {
           FileChannel inChannel = new FileInputStream(src).getChannel();
           FileChannel outChannel = new FileOutputStream(dst).getChannel();
           try {
              inChannel.transferTo(0, inChannel.size(), outChannel);
           } finally {
              if (inChannel != null)
                 inChannel.close();
              if (outChannel != null)
                 outChannel.close();
           }
        }

     }
  • На курсоре вы всегда можете позвонить:

    DatabaseUtils.dumpCursorToString (cur);

, чтобы получить необработанное строковое представление курсора

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...