哈嘍大家好!如果你感覺SQLiteOpenHelper不懂的可以看一下。
onCreate(SQLiteDatabase db) : 當數據庫被首次創建時執行該方法,一般將創建表等初始化操作在該方法中執行。
直接上代碼:
新建一個QqlText類
package com.example.sjk; import android.content.Context; import android.database.sqlite.SQLiteCursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.util.Log; public class SqlText extends SQLiteOpenHelper{ private static final String DB_NAME = "mydata.db"; //數據庫名稱 private static final int version =1; // 數據庫版本
//調用父類構造器 public SqlText(Context context) { super(context, DB_NAME, null, version); //context 注意一下 } @Override public void onCreate(SQLiteDatabase db) { //新安裝的軟件從這里開始 String sql_message = "create table t_message (id int primary key,name varchar(50),age varchar(50))"; db.execSQL(sql_message); Log.i("hi", "創建表成功"); String sql_up1 = "insert into t_message values(1,'小白','18')"; db.execSQL(sql_up1); Log.i("hi", "版本1.0插入數據成功了"); } @Override //在原來的軟件上更新會從這里開始,不卸載在線更新 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }
public void onCreate(SQLiteDatabase db) //本人理解為:新安裝的軟件從這里開始 ,其他的都不關事;
這個時候我們的數據庫已經創建好了,並且建立表,插入了數據

選擇導出:

數據庫有數據了,小白亂碼了;但還是插入了數據。
//增加點查詢功能 MainActivity.java
package com.example.sjk;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.widget.TextView;
public class MainActivity extends Activity {
private SqlText st; //得到SqlText這個類的context
private TextView tv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv = (TextView) findViewById(R.id.TextView);//找到這個TextView組件
st = new SqlText(MainActivity.this);
String text = query();//調用查詢這個方法
tv.setText("id \t"+"name\t"+"age\n"+text);//顯示
}
public String query(){//查詢數據庫的數據
String result = "";
//獲取數據庫對象
SQLiteDatabase db = st.getReadableDatabase();//只讀:ReadableDatabase;讀寫:WritableDatabase
//查詢數據庫中的數據
Cursor cursor = db.query("t_message", null, null, null, null, null, null);
//結果集
for(int i=0;i<cursor.getCount();i++) {
cursor.moveToNext();
result += cursor.getInt(cursor.getColumnIndex("id"));
result += cursor.getString(cursor.getColumnIndex("name"));
result += cursor.getString(cursor.getColumnIndex("age"));
}
cursor.close();//關閉結果集
db.close();//關閉數據庫對象
return result;
}
}
結果:

