簡體   English   中英

在本地數據庫上存儲數據

[英]Storing Data on a Local Database

感謝Stackoverflow的貢獻者,我無需使用Java就可以使用Android Studio開發我的第一個Android應用程序。 這是一個具有兩個EditText字段和一個OK按鈕的獨特界面條形碼掃描應用程序(使用ZXing)。 條碼掃描器填充了兩個字段。

我想將數據存儲在本地數據庫的兩個EditText字段中,該字段具有兩列(用於兩個字段)和一個表。

我不是在要求代碼,只是在尋求指導和建議以推動應用程序的開發。

謝謝

這是我的應用的屏幕截圖

為什么選擇一個數據庫來存儲這兩個值? 您是否考慮過偏好設置? 我覺得比較合適。

首先,您應該閱讀此https://developer.android.com/guide/topics/data/data-storage

現在,請牢記所有相關因素,自己決定最適合您的需求。

對我來說,這看起來像是一個寵物項目,您只想存儲兩個值,建議您使用SharedPreferences存儲它們

請參閱https://developer.android.com/training/data-storage/shared-preferences

我認為您應該使用Sqlite數據庫,這就是應該使用它的方式。

DBHelper.java

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Hashtable;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.DatabaseUtils;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase;

public class DBHelper extends SQLiteOpenHelper {

   public static final String DATABASE_NAME = "MyDBName.db";
   public static final String CONTACTS_TABLE_NAME = "barcode";
   public static final String CONTACTS_COLUMN_ID = "id";
   public static final String CONTACTS_COLUMN_TEXT1 = "field1";
   public static final String CONTACTS_COLUMN_TEXT2 = "field2";

   private HashMap hp;

   public DBHelper(Context context) {
      super(context, DATABASE_NAME , null, 1);
   }

   @Override
   public void onCreate(SQLiteDatabase db) {
      // TODO Auto-generated method stub
      db.execSQL(
         "create table barcode" +
         "(id integer primary key, field1 text, field2 text)"
      );
   }

   @Override
   public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
      // TODO Auto-generated method stub
      db.execSQL("DROP TABLE IF EXISTS barcode");
      onCreate(db);
   }

   public boolean insertData (String text1, String text2) {
      SQLiteDatabase db = this.getWritableDatabase();
      ContentValues contentValues = new ContentValues();
      contentValues.put("field1", text1);
      contentValues.put("field2", text2);
      db.insert("barcode", null, contentValues);
      return true;
   }

   public Cursor getData(int id) {
      SQLiteDatabase db = this.getReadableDatabase();
      Cursor res =  db.rawQuery( "select * from barcode where id="+id+"", null );
      return res;
   }



   public boolean updateBarcode (Integer id, String text1, String text2) {
      SQLiteDatabase db = this.getWritableDatabase();
      ContentValues contentValues = new ContentValues();
      contentValues.put("field1", text1);
      contentValues.put("field2", text2);
      db.update("barcode", contentValues, "id = ? ", new String[] { Integer.toString(id) } );
      return true;
   }

您的活動或片段

  private DBHelper mydb ;
  mydb = new DBHelper(this);

   //insert
   if(mydb.insertBarcode(EditText1.getText().toString(), 
                       EditText2.getText().toString())){
              Toast.makeText(getApplicationContext(), "done",
                       Toast.LENGTH_SHORT).show();  
    } else{
           Toast.makeText(getApplicationContext(), "not done", 
                   Toast.LENGTH_SHORT).show();  
    }

   //Read
   Cursor getBarcode= mydb.getData(id_to_search);

您還可以在DBHelper.java添加更多功能,例如從表中DBHelper.java完整數據等。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM