Android sqlite本地数据库

做任何开发都会用的 数据库 Android 也一样,Android一般都要用的两个数据库本地数据库和远程数据库,本地数据库就是sqlite,远程数据库的话,我一般用的是 MySQL ,这次先了解下本地数据库sqlite,一般数据库类型为varchar(20) 如果你输入个大于20位的数据时,会报错,不能插入吧,但是sqlite里就不一样了,他就可以,这是sqlite的特色之一吧应该是。下来就看看sqlite的 crud:

MainActivity

[java]  view plain  copy
  1. package com.example.sqlite;  
  2.   
  3. import android.os.Bundle;  
  4. import android.app.Activity;  
  5. import android.view.Menu;  
  6. import android.widget.TextView;  
  7.   
  8. public class MainActivity extends Activity {  
  9.   
  10.     @Override  
  11.     public void onCreate(Bundle savedInstanceState) {  
  12.         super.onCreate(savedInstanceState);  
  13.         setContentView(R.layout.activity_main);  
  14.         TextView t;  
  15.           
  16.         DBOpenHelter dbopenhelper=new DBOpenHelter(this);  
  17.     }  
  18.   
  19.     @Override  
  20.     public boolean onCreateOptionsMenu(Menu menu) {  
  21.         getMenuInflater().inflate(R.menu.activity_main, menu);  
  22.         return true;  
  23.     }  
  24. }  


PersonService

[java]  view plain  copy
  1. package com.example.sqlite;  
  2.   
  3. import com.example.bean.Person;  
  4.   
  5. import android.content.Context;  
  6. import android.database.Cursor;  
  7. import android.database.sqlite.SQLiteDatabase;  
  8.   
  9. public class PersonService {  
  10.     private DBOpenHelter dbOpenHelper;  
  11.       
  12.     public PersonService(Context context){  
  13.           
  14.         this.dbOpenHelper=new DBOpenHelter(context);  
  15.     }  
  16.     public void save(Person person){  
  17.         SQLiteDatabase db=dbOpenHelper.getWritableDatabase();  
  18.         StringBuilder sql=new StringBuilder(128);   //这个没用  
  19.         sql.append("insert ");                      //这个没用  
  20.         db.execSQL("insert into person(name,phone) values(?,?)",new Object[]{person.getName(),person.getPhone()});  
  21.         db.close();  
  22.     }  
  23.     public Person find(Integer id){  
  24.         Person person=new Person();  
  25.         SQLiteDatabase db=dbOpenHelper.getReadableDatabase();  
  26.         Cursor cursor=db.rawQuery("select * from testpersion wehre name=?",new String[]{id.toString()});  
  27.         while(cursor.moveToNext()){  
  28.             int personid=cursor.getInt(cursor.getColumnIndex("id"));  
  29.         }  
  30.         return person;  
  31.     }  
  32. }  

DBOpenHelter

package com.example.sqlite;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DBOpenHelter extends SQLiteOpenHelper{

    public DBOpenHelter(Context context) {
        super(context, "itcast.db", null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE testpersion(persionid integer primary key autoincrement,name varchar(20))");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub
        db.execSQL("ALTER TABLE testpersion ADD phone VARCHAR(12) NULL");
    }

}

你可能感兴趣的:(Android sqlite本地数据库)