SQLite 存储

SQLite是一种轻量级的,嵌入式的数据库系统,它占用的资源非常低。SQLite通过文件来保存数据库与,一个文件就是一个数据库。


 

Android平台下数据库相关类

◆SQLiteOpenHelper 抽象类:通过从此类继承实现用户类,来提供数据库打开、关闭等操作函数。

◆SQLiteDatabase 数据库访问类:执行对数据库的插入记录、查询记录等操作。

◆SQLiteCursor 查询结构操作类:用来访问查询结果中的记录。

 

  • SQLiteOpenHelper抽象类

 

package com.test.sqlitedemo;

import android.R.integer;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.DropBoxManager;
import android.provider.Contacts.Intents.Insert;
import android.text.style.SuperscriptSpan;
import android.widget.TableLayout;

public class dbHelper extends SQLiteOpenHelper
{	
	private static String dbname = "data.db";  
    private static int version = 1;  
    //构造方法1(一般用方法1比较好,应为数据库名字和版本不会改变)
    public dbHelper(Context context)
	{
    	super(context, dbname, null, version);
		
	}
	//构造方法2
	public dbHelper(Context context,String name,CursorFactory cursorFactory,int version)
	{
		//调用父类的构造方法
		super(context, name, cursorFactory, version);
	}

	@Override
	public void onCreate(SQLiteDatabase db)
	{
		// 创建数据库后,对数据库的操作(比如建表)
		db.execSQL("CREATE TABLE IF NOT EXISTS person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age INTEGER)");
	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
	{
		// 更新数据库版本的操作
		db.execSQL("DROP TABLE IF EXISTS person");  
        onCreate(db); 

	}
}

 SQLiteOpenHelper主要的三个方法是:

①构造方法:

public dbHelper(Context context){}

public dbHelper(Context context,String name,CursorFactory cursorFactory,int version){}

其中,context是上下文环境,一般是Activity;name是数据库名字;cursorFactory是游标工程,一般为null;version是指现在数据库版本,由自己指定。

②onCreate(){}方法

public void onCreate(SQLiteDatabase db){}  

这个方法在数据库第一次创建的时候调用,一般是做一些数据库的初始化工作,比如建表。

这个方法的参数是一个SQLiteDatabase数据库,建表之类的工作,就是通过调用db.execSQL()完成。

③onUpgrade(){}

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){}
 

这个方法在更新数据库的时候调用,进行的是一些更新的操作。

 

 

  • SQLiteDatabase 数据库的使用:

要获取SQLiteDatebase对象,可以使用

SQLiteDatabase db = databaseHelper.getWritableDatabase();

 或者

SQLiteDatabase db = databaseHelper.getReaderableDatabase();

 二者的区别是:在数据库是可读写时,无异;当数据库是只读时,前者会抛出异常。

 

获取了db对象后,利用execSQL()方法,就可以对数据库进行增删改查操作了。

例如:

       db.execSQL("DROP TABLE IF EXISTS person");        
       db.execSQL("CREATE TABLE person(id INTEGER PRIMARY KEY AUTOINCREMENT,name VARCHAR(20), age INTEGER)");

 可以使用DDL语言。

对于不熟悉SQL语言的程序员,也可以使用SQLiteDatebase提供的方法:

db.query(),db.insert(),db.update(),db.delete()

这些方法会和哈希键--值对ContentValues一起用到,例如:

        ContentValues contentValues = new ContentValues();  
        contentValues.put("name", person.getName());  
        contentValues.put("age", person.getAge());  
        database.insert("person", null, contentValues);  
  

  • Cursor的使用:

通过db.rawQuery()返回的查询结果,可以用Cursor来指向他们。

Cursor指向的是返回结果的第1个记录的前面一个节点,所以要获取操作第一个记录,需要     Cursor.moveToNext()。

例如:

        String args[]={et_id.getText().toString()};
	Cursor cursor=db.rawQuery("select name,age from student where id=?",args);
	if(cursor.moveToNext())
		{
			et_name.setText(cursor.getString(cursor.getColumnIndex("name")));
			et_age.setText(cursor.getString(cursor.getColumnIndex("age")));
			Toast.makeText(MainActivity.this, "查詢成功", Toast.LENGTH_LONG).show();
		}
 

下面的代码示出Acitivity里面,如何使用这些SQLite

package com.test.sqlitedemo;

import android.R.integer;
import android.R.string;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.content.DialogInterface.OnClickListener;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import android.support.v4.app.NavUtils;

public class MainActivity extends Activity {
	private Button btn_selcet,btn_insert,btn_update,btn_delete;
	private EditText et_id,et_name,et_age;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);      
        
        
        btn_selcet=(Button)findViewById(R.id.btn_select);
        btn_insert=(Button)findViewById(R.id.btn_insert);
        btn_update=(Button)findViewById(R.id.btn_update);
        btn_delete=(Button)findViewById(R.id.btn_delete);
        et_id=(EditText)findViewById(R.id.et_id);
        et_name=(EditText)findViewById(R.id.et_name);
        et_age=(EditText)findViewById(R.id.et_age);
        
        btn_selcet.setOnClickListener(listener);   
        btn_insert.setOnClickListener(listener);
        btn_update.setOnClickListener(listener);   
        btn_delete.setOnClickListener(listener);   
        
    }
    
    View.OnClickListener listener=new View.OnClickListener()
	{
		
		@Override
		public void onClick(View v)
		{
			// 獲取SQLiteDatabase實例db,然後對各個事件調用db的不同操作
			DBHelper dbHelper=new DBHelper(MainActivity.this);
	        SQLiteDatabase db=dbHelper.getWritableDatabase();
			switch (v.getId())
			{
			case R.id.btn_select://查詢
				if(et_id.getText().toString()!=null)
				{
					String args[]={et_id.getText().toString()};
					Cursor cursor=db.rawQuery("select name,age from student where id=?",args);
					if(cursor.moveToNext())
					{
						et_name.setText(cursor.getString(cursor.getColumnIndex("name")));
						et_age.setText(cursor.getString(cursor.getColumnIndex("age")));
						Toast.makeText(MainActivity.this, "查詢成功", Toast.LENGTH_LONG).show();
					}
				}
				else
				{
					Toast.makeText(MainActivity.this, "查詢ID不能為空", Toast.LENGTH_LONG).show();
				}
				break;
            case R.id.btn_insert://添加
            	if (et_id.getText().toString()!=null)
				{     	
    				  			
    				db.execSQL("insert into student(id,name,age) values(?,?,?)",new String[]{et_id.getText().toString(),et_name.getText().toString(),et_age.getText().toString()});
    				Toast.makeText(MainActivity.this, "添加"+et_id.getText().toString()+"成功", Toast.LENGTH_LONG).show();
				} else
				{
					Toast.makeText(MainActivity.this, "插入ID不能為空", Toast.LENGTH_LONG).show();
				}				
				break;
            case R.id.btn_update://更新
            	db.execSQL("update student set name=?,age=? where id=?",new String[]{et_name.getText().toString(),et_age.getText().toString(),et_id.getText().toString()});
            	Toast.makeText(MainActivity.this, "更新成功", Toast.LENGTH_LONG).show();
            	break;
            case R.id.btn_delete://刪除
            	db.execSQL("delete from student where id=?",new String[]{et_id.getText().toString()});            	
            	et_id.setText("");
            	et_name.setText("");
            	et_age.setText("");
            	Toast.makeText(MainActivity.this, "刪除成功", Toast.LENGTH_LONG).show();
            	break;

			default:
				break;
			}
			
		}
	};

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }

    
}

你可能感兴趣的:(sqlite)