[英]How do i insert data to SQLite database at the biggening of the Table?
我是SQLite android开发中的新手。 我想使用SQLite保存数据。 我还轻松地扩展了SQLiteOpenHelper类。 我在表上使用了自动增量键ID。 当我使用Cursor.moveToFirst()到Cursor.moveToLast()打印所有数据(不使用命令的任何命令)将数据插入到表中之后,我发现数据按插入顺序打印(或者,基于键ID升序订购)。
好吧,那很好! 但是问题是我还需要在同一张表的开头附加数据(或在旧数据之前先打印新插入的数据)。
我搜索了互联网,但没有找到任何解决方案。 我怎样才能做到这一点?
帮我描述一下功能:
insertDataToTheBiggening(字符串数据)
insertDataToTheEnd(字符串数据)
我的代码是:
public class StoreData extends SQLiteOpenHelper {
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_NAME = "AllData";
private static final String TABLE = "Data";
private static final String KEY_ID = "id";
private static final String KEY_NAME = "versity_name";
private static final String KEY_TITLE = "title";
private static final String KEY_INFO = "info";
private static final String KEY_DATE = "date";
private static final String KEY_LINK = "link";
public StoreData(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
public StoreData(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
public StoreData(Context context, String name, SQLiteDatabase.CursorFactory factory, int version, DatabaseErrorHandler errorHandler) {
super(context, name, factory, version, errorHandler);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
String CREATE_TABLE = "CREATE TABLE " + TABLE + "("
+ KEY_ID + " integer primary key autoincrement, "
+ KEY_NAME + " text not null, "
+ KEY_TITLE + " text not null, "
+ KEY_INFO + " text not null, "
+ KEY_DATE + " text not null, "
+ KEY_LINK + " text not null"
+ ")";
sqLiteDatabase.execSQL(CREATE_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
sqLiteDatabase.execSQL("DROP TABLE IF EXISTS " + TABLE);
onCreate(sqLiteDatabase);
}
public void addNewData(String VersityName, String Title, String Info, String Time, String Link)
{
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(KEY_NAME, VersityName);
values.put(KEY_TITLE, Title);
values.put(KEY_INFO, Info);
values.put(KEY_DATE, Time);
values.put(KEY_LINK, Link);
db.insert(TABLE, null, values);
db.close();
}
}
public void PrintAllData()
{
new AsyncTask<String, String, String>() {
@Override
protected String doInBackground(String... strings) {
SQLiteDatabase db = getWritableDatabase();
String selectQuery = "SELECT * FROM " + TABLE ;
Cursor cursor = db.rawQuery(selectQuery, null);
try{
if (cursor.moveToFirst()) {
do{
publishProgress(cursor.getString(0)+" "+cursor.getString(1),cursor.getString(2),cursor.getString(3),cursor.getString(4),cursor.getString(5));
Thread.sleep(100);
}while (cursor.moveToNext());
}
} catch (InterruptedException e) {
e.printStackTrace();
} finally{
db.close();
cursor.close();
}
return null;
}
@Override
protected void onProgressUpdate(String... strings)
{
ManagePanes.addPane(strings[0],strings[1],strings[2],strings[3],strings[4]);
}
}.execute("");
}
我发现数据按插入顺序打印
您可能已经观察到了这种情况,但是不能保证总是如此。 通常,SQL表是按无序记录集建模的,也就是说,任何表的记录都没有内部顺序。 因此,解决问题的方法是只在表中进行普通的SQLite插入,如果需要订购,则可以使用一个或多个列通过ORDER BY
子句强加该订购。 例如,您可能有一个timestamp列,该列可以表示一个较早或较晚的记录,并按所需顺序查询记录。
在开始处给出负 ID以增加插入值,在结束处增加正 ID并在结尾增加插入值
在描述表时使用id最小-最大-正
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.