Возможно, как вы реализуете свою базу данных SQLite.Попробуйте использовать его следующим образом:
DatabaseHelper.java
package YOUR_PACKAGE_NAME;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.DatabaseUtils;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import java.util.ArrayList;
import java.util.HashMap;
public class DatabaseHelper extends SQLiteOpenHelper {
ArrayList<HashMap<String, String>> YourList = new ArrayList<>();
public static final String DATABASE_NAME = "MyDBName.db";
public static final String CONTACTS_TABLE_NAME = "Your_TableName";
public static final String CONTACTS_COLUMN1 = "column1";
public static final String CONTACTS_COLUMN2 = "column2";
public static final String CONTACTS_COLUMN3 = "column3";
private HashMap hp;
public DatabaseHelper(Context context){
super(context ,DATABASE_NAME,null,1);
}
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
db.execSQL(
"create table Your_TableName(column1 VARCHAR,column2 VARCHAR,column3 VARCHAR)"
);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL("DROP TABLE IF EXISTS Your_TableName");
onCreate(db);
}
//Insert Data to SQLite database
public boolean insertData(String column1, String column2 ,String column3) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put("column1", column1);
contentValues.put("column2", column2);
contentValues.put("column2", column3);
db.insert("Your_TableName", null, contentValues);
return true;
}
//delete all data in SQLite database
public Cursor deleteData() {
SQLiteDatabase db = this.getReadableDatabase();
db.execSQL("delete FROM Your_TableName");
return null;
}
//counting the number of items in your database
public int numberOfRows(){
SQLiteDatabase db = this.getReadableDatabase();
int numRows = (int) DatabaseUtils.queryNumEntries(db, CONTACTS_TABLE_NAME);
return numRows;
}
//Get all item in your database
public ArrayList<HashMap<String, String>> getAllDatabaseData() {
//hp = new HashMap();
SQLiteDatabase db = this.getReadableDatabase();
Cursor res = db.rawQuery( "select * from Your_TableName", null );
res.moveToFirst();
while(res.isAfterLast() == false){
HashMap<String, String> array_list = new HashMap<>();
array_list.put("column1",res.getString(res.getColumnIndex(CONTACTS_COLUMN1)));
array_list.put("column2",res.getString(res.getColumnIndex(CONTACTS_COLUMN2)));
array_list.put("column3",res.getString(res.getColumnIndex(CONTACTS_COLUMN3)));
YourList.add(array_list);
res.moveToNext();
}
return YourList;
}
}
, и в своей деятельности просто реализуйте это.
public class company_profile extends AppCompatActivity {
EditText title, address;
SQLiteDatabase sqlitedb;
Button Add;
String companytitle, companyaddress;
Boolean EditTextEmpty;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_company_profile);
title = (EditText) findViewById(R.id.com_name);
address = (EditText) findViewById(R.id.com_address);
Add = (Button) findViewById(R.id.addComapny);
Add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
column1= title.getText().toString();
column2= address.getText().toString();
new DatabaseHelper(this).insertData(column1, column2, column3); //calling the method [inserData] in DatabaseHelper Class
}
});
}
}