欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Android輕量型數據庫SQLite

 更新時間:2016年10月17日 17:04:25   作者:Jepson_鵬鵬  
這篇文章主要為大家詳細介紹了Android輕量型數據庫SQLite,具有一定的參考價值,感興趣的小伙伴們可以參考一下

數據庫是Android存儲方案的核心,在Andorid中SQLite非常輕量,而且執(zhí)行sql語句甚至比MySQL還要快。
SQLiteDatabase 是 Android 中操作數據庫的核心類之一,使用SQLiteDatabase可以打開數據庫,也可以對數據庫進行操作,然而,為了數據庫升級以及使用更加方便,我們常用SQLiteOpenHelper的子類來完成創(chuàng)建,打開數據庫的操作。
SQLiteOpenHelper是一個抽象類,在該類中有下面兩個必須實現(xiàn)的方法:

public void onCreate(SQLiteDatabase db);// 該函數在數據庫第一次被建立時調用
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion);// 數據庫更新升級操作

我們新建一個類DBHelper extends SQLiteOpenHelper

import java.util.Random;

import android.R.bool;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DBHelper extends SQLiteOpenHelper {

 // 設置數據庫默認版本
 private static final int VERSON = 1;
 // 自定義數據庫名,可以隨便取名字
 private static final String DBNAME = "mydb";

 // 繼承SQLiteOpenHelper類的類必須有自己的構造函數
 // 該構造函數4個參數,直接調用父類的構造函數。其中第一個參數為該類本身;第二個參數為數據庫的名字;
 public DBHelper(Context context, String name, CursorFactory factory,
   int version) {
  super(context, name, factory, version);
 }

 // 該構造函數有3個參數,因為它把上面函數的第3個參數固定為null了
 public DBHelper(Context context, String name, int verson) {
  this(context, name, null, verson);
 }

 // 該構造函數只有2個參數,在上面函數 的基礎上將版本號固定了
 public DBHelper(Context context, String name) {
  this(context, name, VERSON);
 }

 // 該構造函數只有1個參數,固定默認數據庫,在這里我們實現(xiàn)增刪改查為了方便,就用它了
 public DBHelper(Context context) {
  this(context, DBNAME, null, VERSON);
 }

 // 該函數在數據庫第一次被建立時調用
 public void onCreate(SQLiteDatabase db) {
  System.out.println("create a sqlite database");
  //建表語句(注意:因為在綁定數據時,Cursor對象返回的記錄集中必須包含一個"_id"字段,否則無法完成數據綁定
  String sql = "CREATE TABLE [test]("+
      "[_id] AUTOINC,"+
      "[name] varchar(20),"+
      "[age] varchar(20),"+
      "PRIMARY KEY ([_id]))";
  db.execSQL(sql);

  //向test表中插入10條數據
  for (int i = 1; i <= 10; i++) {
   String name = "Jepson";
   name+=i;
   String age = "age";
   age+=i;
   db.execSQL("insert into test(name,age) values(?,?)",new Object[]{name,age});
  }
 }

 // 數據庫更新操作
 public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
  System.out.println("update a sqlite database");
 }

 //自定義query方法,用以執(zhí)行查詢語句,返回Cursor對象
 public Cursor query(String sql,String[] args){
  //調用 getReadableDatabase方法時,如果數據庫文件不存在,會調用 onCreate方法
  SQLiteDatabase db = this.getReadableDatabase();
  Cursor cursor = db.rawQuery(sql, args);
  return cursor;
 }
}

這樣,我們的DBHelper 類寫好了,我們來實現(xiàn)一個查詢操作。

第一步,activity_main.xml添加 listview 展示控件

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="#FFFFFF"
 android:orientation="vertical"
 tools:context=".MainActivity" >

 <ListView
  android:id="@android:id/list"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:divider="#6b6f74"
  android:dividerHeight="1px" >
 </ListView>

</LinearLayout>

第二步,新建一個xml布局文件,用來作為列表項使用的布局資源

user_list_cell.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical" 
 android:background="#FFFFFF">
 <!-- 大字體TextView,用以展示 name姓名 -->
 <TextView
  android:id="@+id/tvName"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="Large"
  android:textColor="#000000"
  android:textSize="20dp" />

 <!-- 小字體TextView,用以展示 age年齡 -->
 <TextView
  android:id="@+id/tvAge"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="Small"
  android:textColor="#000000"
  android:textSize="14dp" />

</LinearLayout>

第三步,主Activity

import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends ListActivity {

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 public void initView(){
  //調用只有1個參數的構造函數,實例化dbHelper
  DBHelper dbHelper = new DBHelper(this);
  //新建Cursor對象來保存query查詢方法返回的結果,查詢test表中所有記錄
  Cursor cursor = dbHelper.query("select * from test", null);
  //創(chuàng)建SimpleCursorAdapter對象,5個參數,
  //第一個是context,就寫當前this就行
  //第二個是布局文件,我這里是自定義的布局文件user_list_cell.xml
  //第三個就是Cursor對象
  //第四個對應就是,cursor查詢后,需要顯示出來的字段名,比如我要顯示姓名name和年齡age
  //第五個就是對應列表項布局中的控件ID了
  SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
    R.layout.user_list_cell, cursor,
    new String[] { "name", "age" }, new int[] { R.id.tvName,
      R.id.tvAge });
  setListAdapter(simpleCursorAdapter);
  Toast.makeText(this, "查詢成功", Toast.LENGTH_SHORT).show();
 }
}

執(zhí)行一下看看,我們是不是查詢成功了?

操作SQLite數據庫應了解,對數據庫的增刪改查都有兩種方法,一種是前面的使用 rawQuery方法直接執(zhí)行SQL語句,另一種就是使用SQLiteDatabase類的相應方法來操作,下面舉一個第二種的例子,比如我們要插入數據 name=11 age=22

import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends ListActivity {

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 public void initView(){
  //執(zhí)行添加操作
  DBHelper dbHelper = new DBHelper(this);
  //獲得寫入權限getWritableDatabase
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  //新建contentvalues保存insert數據
  ContentValues cv = new ContentValues();
  cv.put("name", "11");
  cv.put("age", "22");
  db.insert("test", null, cv);
  Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();

  ////查詢操作
  ////調用只有1個參數的構造函數,實例化dbHelper
  //DBHelper dbHelper = new DBHelper(this);
  ////新建Cursor對象來保存query查詢方法返回的結果,查詢test表中所有記錄
  //Cursor cursor = dbHelper.query("select * from test", null);
  ////創(chuàng)建SimpleCursorAdapter對象,5個參數,
  ////第一個是context,就寫當前this就行
  ////第二個是布局文件,我這里是自定義的布局文件user_list_cell.xml
  ////第三個就是Cursor對象
  ////第四個對應就是,cursor查詢后,需要顯示出來的字段名,比如我要顯示姓名name和年齡age
  ////第五個就是對應列表項布局中的控件ID了
  //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
  //  R.layout.user_list_cell, cursor,
  //  new String[] { "name", "age" }, new int[] { R.id.tvName,
  //    R.id.tvAge });
  //setListAdapter(simpleCursorAdapter);
  //Toast.makeText(this, "查詢成功", Toast.LENGTH_SHORT).show();
 }
} 

執(zhí)行插入成功以后,再將插入語句注釋,將查詢語句去掉注釋,重新啟動,會發(fā)現(xiàn)最后一多了一個item,添加成功。

另外查詢記錄獲得的Cursor對象,需要使用movetoFirst,moveToNext,movToPosition(position)等方法將指針移動相應的位置,來進行查詢結果的讀取。

import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends ListActivity {

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 public void initView(){
  //解析Cursor對象的查詢操作
  DBHelper dbHelper = new DBHelper(this);
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  Cursor cursor = db.query("test", null, null, null, null, null, null,
    null);
  //定義結果字符串
  String result = "";
  // 判斷cursor不為空 這個很重要
  if (cursor != null) {
   while (cursor.moveToNext()) {
    String name = cursor.getString(cursor.getColumnIndex("name"));// 獲取name列的值
    String age = cursor.getString(cursor.getColumnIndex("age"));// 獲取age列的值
    result += "姓名:" + name + ",年齡:" + age + "\n";
   }
  }
  cursor.close();
  db.close();
  System.out.println(result);
  Toast.makeText(this, result, Toast.LENGTH_SHORT).show();

  // //執(zhí)行添加操作
  // DBHelper dbHelper = new DBHelper(this);
  // //獲得寫入權限getWritableDatabase
  // SQLiteDatabase db = dbHelper.getWritableDatabase();
  // //新建contentvalues保存insert數據
  // ContentValues cv = new ContentValues();
  // cv.put("name", "11");
  // cv.put("age", "22");
  // db.insert("test", null, cv);
  // Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();

  ////查詢操作
  ////調用只有1個參數的構造函數,實例化dbHelper
  //DBHelper dbHelper = new DBHelper(this);
  ////新建Cursor對象來保存query查詢方法返回的結果,查詢test表中所有記錄
  //Cursor cursor = dbHelper.query("select * from test", null);
  ////創(chuàng)建SimpleCursorAdapter對象,5個參數,
  ////第一個是context,就寫當前this就行
  ////第二個是布局文件,我這里是自定義的布局文件user_list_cell.xml
  ////第三個就是Cursor對象
  ////第四個對應就是,cursor查詢后,需要顯示出來的字段名,比如我要顯示姓名name和年齡age
  ////第五個就是對應列表項布局中的控件ID了
  //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
  //  R.layout.user_list_cell, cursor,
  //  new String[] { "name", "age" }, new int[] { R.id.tvName,
  //    R.id.tvAge });
  //setListAdapter(simpleCursorAdapter);
  //Toast.makeText(this, "查詢成功", Toast.LENGTH_SHORT).show();
 }
} 

執(zhí)行以后,可以發(fā)現(xiàn),name和age全都獲取到了,并顯示在了Toast和system.out中。是不是很有意思呢?

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Android使用WebSocket實現(xiàn)多人游戲

    Android使用WebSocket實現(xiàn)多人游戲

    WebSocket 是 HTML5 一種新的協(xié)議。實現(xiàn)了瀏覽器與服務器全雙工通信,下面通過本文給大家分享Android使用WebSocket實現(xiàn)多人游戲,需要的朋友參考下吧
    2017-11-11
  • Android ViewPager源碼詳細分析

    Android ViewPager源碼詳細分析

    這篇文章主要為大家詳細介紹了Android ViewPager源碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • Android忽略文件實例代碼

    Android忽略文件實例代碼

    這篇文章主要介紹了Android忽略文件的實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Android中使用Bitmap類將矩形圖片轉為圓形的方法

    Android中使用Bitmap類將矩形圖片轉為圓形的方法

    這篇文章主要介紹了Android中使用Bitmap類將矩形圖片轉為圓形的方法,同時文中也介紹了如何利用矩形直接來畫圓角,需要的朋友可以參考下
    2016-03-03
  • Android文件選擇器ExFilePicker的使用方法

    Android文件選擇器ExFilePicker的使用方法

    這篇文章主要為大家詳細介紹了Android文件選擇器ExFilePicker的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Android開發(fā)實現(xiàn)撥打電話與發(fā)送信息的方法分析

    Android開發(fā)實現(xiàn)撥打電話與發(fā)送信息的方法分析

    這篇文章主要介紹了Android開發(fā)實現(xiàn)撥打電話與發(fā)送信息的方法,結合實例形式分析了Android撥打電話及發(fā)送信息相關布局、功能實現(xiàn)及權限控制操作技巧,需要的朋友可以參考下
    2017-12-12
  • Android實現(xiàn)類似iOS分欄控制器

    Android實現(xiàn)類似iOS分欄控制器

    這篇文章主要為大家詳細介紹了Android實現(xiàn)類似iOS分欄控制器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Android自定義組件獲取本地圖片和相機拍照圖片

    Android自定義組件獲取本地圖片和相機拍照圖片

    這篇文章主要為大家詳細介紹了Android自定義組件獲取本地圖片和相機拍照圖片的相關資料,非常炫酷的效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Android利用動畫實現(xiàn)背景逐漸變暗

    Android利用動畫實現(xiàn)背景逐漸變暗

    這篇文章主要為大家詳細介紹了Android利用動畫實現(xiàn)背景逐漸變暗的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Android ScrollView取消慣性滾動的方法

    Android ScrollView取消慣性滾動的方法

    下面小編就為大家?guī)硪黄狝ndroid ScrollView取消慣性滾動的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04

最新評論