Android   发布时间:2022-04-28  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了Android操作sqlite数据库(增、删、改、查、分页等)及ListView显示数据的方法分享给大家供大家参,具体如下:

由于刚接触android开发,故此想把学到的基础知识记录一下,以备查询,故此写的比较拢

步骤如下:

一、介绍:

此文主要是介绍怎么使用android自带数据库sqlite,以及把后台的数据用ListView控件显示

二、新建一个android工程――DBsqliteOperate

工程目录:

Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解

三、清单列表AndroidManifest.xml的配置为:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://scheR_974_11845@as.android.com/apk/res/android"
  package="com.example.dboperate"
  android:versionCode="1"
  android:versionName="1.0" >
  <uses-sdk android:minSdkVersion="8" />
  <application
    android:icon="@drawable/ic_launcher"
    android:label="@String/app_name" >
    <!--单元测试 加这句-->
    <uses-library android:name="android.test.runner" />
    <activity
      android:name=".DBsqliteOperateActivity"
      android:label="@String/app_name" >
      <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category android:name="android.intent.category.LAUNCHER" />
      </intent-filter>
    </activity>
  </application>
 <instrumentation android:name="android.test.instrumentationTestRunner"
 android:targetPackage="com.example.dboperate"
 android:label="Test for my app"/>
</manifest>

四、main.xml配置清单:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://scheR_974_11845@as.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:orientation="vertical" >
  <LinearLayout android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:orientation="horizontal" >
  <TextView
    android:id="@+id/name"
    android:layout_width="100dip"
    android:layout_height="wrap_content"
    android:text="@String/name"
    android:gravity="center"/>
  <TextView
    android:id="@+id/phone"
    android:layout_width="100dip"
    android:layout_height="wrap_content"
    android:text="@String/phone"
    android:gravity="center"/>
  <TextView
    android:id="@+id/amount"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@String/amount"
    android:gravity="center"/>
</LinearLayout>
  <ListView
    android:id="@+id/listView"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >
  </ListView>
</LinearLayout>

五、item.xml配置清单:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://scheR_974_11845@as.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:orientation="horizontal" >
  <TextView
    android:id="@+id/name"
    android:layout_width="100dip"
    android:layout_height="wrap_content"
    android:text="@String/name"
    android:gravity="center"/>
  <TextView
    android:id="@+id/phone"
    android:layout_width="100dip"
    android:layout_height="wrap_content"
    android:text="@String/phone"
    android:gravity="center"/>
  <TextView
    android:id="@+id/amount"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@String/amount"
    android:gravity="center"/>
</LinearLayout>

六、String.xml配置清单:

<?xml version="1.0" encoding="utf-8"?>
<resources>
  <String name="Hello">Hello World,DBsqliteOperateActivity!</String>
  <String name="app_name">ExampleDBsqliteOperate8</String>
  <String name="name">姓名</String>
  <String name="phone">电话</String>
  <String name="amount">存款</String>
</resources>

七、DBsqliteOperateActivity.java Activity类的源码:

package com.example.dboperate;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.example.adapter.PersonAdapter;
import com.example.domain.Person;
import com.example.service.Personservice;
import android.app.Activity;
import android.database.cursor;
import android.os.bundle;
import android.view.View;
import android.view.View.onClickListener;
import android.widget.AdapterView;
import android.widget.AdapterView.onItemClickListener;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.SimplecursorAdapter;
import android.widget.Toast;
public class DBsqliteOperateActivity extends Activity {
 ListView listView;
 Personservice personservice;
 OnItemClickListener listViewListener;
  /** Called when the activity is first created. */
  @Override
  public void onCreate(Bundle savedInstanceStatE) {
    super.onCreate(savedInstanceStatE);
    setContentView(R.layout.main);
    listViewListener = new OnItemClickListener(){
  @Override
  public void onItemClick(AdapterView<?> parent,View view,int position,long id) {
  //得到listView控件
  ListView listView = (ListView)parent;
  //1、如果使用自定义适配器,返回的是Person对象
  //得到该条目数据
//  Person person = (Person)listView.getItemAtPosition(position);
//  //广播出去
//  Toast.makeText(getApplicationContext(),person.toString(),Toast.LENGTH_LONG).show();
  //2、如果使用showList2()方法中的适配器时,则取得的值是不一样的,返回的是cursor
//  cursor cursor = (cursor)listView.getItemAtPosition(position);
//  int personid = cursor.geTint(cursor.getcolumnIndex("_id"));
//  Toast.makeText(getApplicationContext(),personid+"",Toast.LENGTH_LONG).show();
  //3、如果使用showList()方法中的适配器时,则取得的值是不一样的,返回的是map
  @SuppressWarnings("unchecked")
  Map<String,Object> map = (Map)listView.getItemAtPosition(position);
  String name = map.get("name").toString();
  String personid = map.get("personid").toString();
  Toast.makeText(getApplicationContext(),personid +"-"+ name,Toast.LENGTH_LONG).show();
  }
    };
    listView = (ListView) this.findViewById(R.id.listView);
    listView.setOnItemClickListener(listViewListener);
    personservice = new Personservice(this);
    showList();
  }
 private void showList() {
 List<Person> persons = personservice.getScrollData(0,50);
 List<HashMap<String,Object>> data = new ArrayList<HashMap<String,Object>>();
 for(Person person : persons){
  HashMap<String,Object> item = new HashMap<String,Object>();
  item.put("name",person.getName());
  item.put("phone",person.getPhone());
  item.put("amount",person.getamount());
  item.put("personid",person.getId());
  data.add(item);
 }
 SimpleAdapter adapter = new SimpleAdapter(this,data,R.layout.item,new String[]{"name","phone","amount"},new int[]{R.id.name,R.id.phone,R.id.amount});
   listView.setAdapter(adapter);
 }
 public void showList2(){
 cursor cursor = personservice.getcursorScrollData(0,50);
 //该适配器要求返回的结果集cursor必须包含_id字段,所以需要对取得结果集进行处理
 SimplecursorAdapter adapter = new SimplecursorAdapter(this,cursor,R.id.amount} );
 listView.setAdapter(adapter);
 }
 /**
 * 自定义适配器
 */
 public void showList3(){
 List<Person> persons = personservice.getScrollData(0,50);
 /**
  * 第一个参数:上下文context,第二个参数:要显示的数据,第三个参数:绑定的条目界面
  */
 PersonAdapter adapter = new PersonAdapter(this,persons,R.layout.item);
 listView.setAdapter(adapter);
 }
}

八、person.java 实体类 源码:

package com.example.domain;
public class Person {
 private Integer id;
 private String name;
 private String phone;
 private Integer amount;
 public Integer getId() {
 return id;
 }
 public void setId(Integer id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String Name) {
 this.name = name;
 }
 public String getPhone() {
 return phone;
 }
 public void setPhone(String phonE) {
 this.phone = phone;
 }
 public Person(String name,String phonE) {
 this.name = name;
 this.phone = phone;
 }
 public Person(Integer id,String name,String phone,Integer amount) {
 super();
 this.id = id;
 this.name = name;
 this.phone = phone;
 this.amount = amount;
 }
 public Person() {
 super();
 }
 public Integer getamount() {
 return amount;
 }
 public void setamount(Integer amount) {
 this.amount = amount;
 }
 @Override
 public String toString() {
 return "Person [id=" + id + ",name=" + name + ",phone=" + phone
  + ",amount=" + amount + "]";
 }
}

九、DBOperateHelper.java 业务类源码:

package com.example.service;
import android.content.Context;
import android.database.sqlite.sqliteDatabase;
import android.database.sqlite.sqliteDatabase.cursorFactory;
import android.database.sqlite.sqliteOpenHelper;
public class DBOperateHelper extends sqliteOpenHelper {
 public DBOperateHelper(Context context) {//认创建的数据库文件保存在<包名>/database/
 //第一个参数是上下文,第二个参数是数据库名称,第三个是游标工厂为null时使用 数据库认的游标工厂,第四个是数据库版本号但是不能为0,一般大于0
 super(context,"smallpig",null,4);
 }
 /**
 * 数据库每一次被创建时被调用
 */
 @Override
 public void onCreate(sqliteDatabase sqldb) {
 sqldb.execsql("create table person(personid INTEGER PRIMary key autoincrement,name varchar(20),phone varchar(12) null)");
 }
  /**
   * 每一次数据库版本号发生变动时触发此方法
   * 比如如果想往数据库中再插入一些表、字段或者其他信息时通过修改数据库版本号来触发此方法
   */
 @Override
 public void onUpgrade(sqliteDatabase db,int oldVersion,int newVersion) {
 //db.execsql("alter table person add phone varchar(12) null");\
 db.execsql("alter table person add amount Integer null");
 }
}

十、Personservice.java 业务类源码:

package com.example.service;
import java.util.ArrayList;
import java.util.List;
import android.content.Context;
import android.database.cursor;
import android.database.sqlite.sqliteDatabase;
import com.example.domain.Person;
public class Personservice {
 private DBOperateHelper dbOperateHelper;
 public Personservice(Context context) {
 this.dbOperateHelper = new DBOperateHelper(context);
 }
  /**
   * 保存记录
   * @param person
   */
 public void save(Person person){
 //得到数据库实例,里面封装了数据库操作方法
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
   //sqldb.execsql("insert into person(name,phonE) values('"+person.getName()+"','"+person.getPhone()+"')");
 //利用占位符可以避免注入,但是注意数组参与与占位符对应的字段要一一对应
 sqldb.execsql("insert into person(name,phone,amount) values(?,?,?)",new Object[]{person.getName(),person.getPhone(),person.getamount()});
   //关闭数据库
 sqldb.close();
 }
 /**
 * 删除记录
 * @param id
 */
 public void delete(Integer id){
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
 sqldb.execsql("delete from person where personid=?",new Object[]{iD});
 sqldb.close();
 }
 /**
 * 更新记录
 * @param person
 */
 public void update(Person person){
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
 sqldb.execsql("update person set name=?,phone=?,amount=? where personid=?",person.getamount(),person.getId()});
 sqldb.close();
 }
 /**
 * 通过ID查询记录
 * @param id
 * @return
 */
 public Person find(Integer id){
 /**
  * getWritableDatabase 与 getReadableDatabase 的区别:
  * getReadableDatabase会先返回getWritableDatabase(可写),如果调用getWritableDatabase失败
  * 则才会调用getReadableDatabase后续方法,使数据库只读
  * 当写入的数据超过数据库大小则调用getWritableDatabase会失败
  * 所以只读时则可以使用此方法,其它情况(只要不是超过数据库大小)也可以使用此方法
  */
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 cursor cursor = sqldb.rawQuery("SELEct * from person where personid=?",new String[]{String.valueOf(id)});
 int personid;
 String name;
 String phone;
 int amount;
 Person person = null;
 if(cursor.moveToFirst()){
  personid = cursor.geTint(cursor.getcolumnIndex("personid"));
  name = cursor.getString(cursor.getcolumnIndex("name"));
  phone = cursor.getString(cursor.getcolumnIndex("phone"));
  amount = cursor.geTint(cursor.getcolumnIndex("amount"));
  person = new Person(personid,name,amount);
 }
 cursor.close();
 return person;
 }
 /**
 * 返回指定长度记录,limit 3,5,适用于分页
 * @param offset 起始
 * @param maxResult 长度
 * @return
 */
 public List<Person> getScrollData(int offset,int maxResult){
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 cursor cursor = sqldb.rawQuery("SELEct * from person order by personid asc limit ?,?",new String[]{String.valueOf(offset),String.valueOf(maxResult)});
 int personid;
 String name;
 String phone;
 int amount;
 Person person = null;
 List<Person> persons = new ArrayList<Person>();
 while(cursor.moveToNext()){
  personid = cursor.geTint(cursor.getcolumnIndex("personid"));
  name = cursor.getString(cursor.getcolumnIndex("name"));
  phone = cursor.getString(cursor.getcolumnIndex("phone"));
  amount = cursor.geTint(cursor.getcolumnIndex("amount"));
  person = new Person(personid,amount);
  persons.add(person);
 }
 cursor.close();
 return persons;
 }
 /**
 * 返回cursor
 * @param offset 起始
 * @param maxResult 长度
 * @return
 */
 public cursor getcursorScrollData(int offset,int maxResult){
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 cursor cursor = sqldb.rawQuery("SELEct personid as _id,amount from person order by personid asc limit ?,String.valueOf(maxResult)});
 return cursor;
 }
 /**
 * 返回总记录数
 * @return
 */
 public long getCount(){
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 cursor cursor = sqldb.rawQuery("SELEct count(*) from person",null);
 //该查询语句值返回一条语句
 cursor.moveToFirst();
 long result = cursor.getLong(0);
 cursor.close();
 return result;
 }
 public void payment(){
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
 sqldb.begintransaction();//开启事务
 try{
  sqldb.execsql("update person set amount = amount -10 where personid=1");
  sqldb.execsql("update person set amount = amount + 10 where personid=2");
  sqldb.settransactionsuccessful();//设置事务标志位true
 } finally {
  //结束事务:有两种情况:commit\rollBACk,事务提交或者回滚是由事务的标识决定的
  //事务为ture则提交,事务为flase则回滚,认为false
  sqldb.endtransaction();
 }
 }
}

十一、OtherPersonservice.java 业务类源码:

package com.example.service;
import java.util.ArrayList;
import java.util.List;
import com.example.domain.Person;
import android.content.ContentValues;
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 OtherPersonservice {
 private DBOperateHelper dbOperateHelper;
 public OtherPersonservice(Context context) {
 this.dbOperateHelper = new DBOperateHelper(context);
 }
  /**
   * 保存记录
   * @param person
   */
 public void save(Person person){
 //得到数据库实例,里面封装了数据库操作方法
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
   //sqldb.execsql("insert into person(name,'"+person.getPhone()+"')");
 //利用占位符可以避免注入,但是注意数组参与与占位符对应的字段要一一对应
 //sqldb.execsql("insert into person(name,phonE) values(?,person.getPhone()});
 ContentValues values = new ContentValues();
 values.put("name",person.getName());
 values.put("phone",person.getPhone());
 values.put("amount",person.getamount());
 //第一个参数是表名,第三个为字段值集合,第二个参数是空值字段,当第三个字段值集合为空时,系统会自动插入一条第二个参数为空的sql语句
 //否则当第三个参数为空时,如果第二个参数也为空,那么插入表就会找不到插入的字段信息,会报错
 sqldb.insert("person","name",values );
 //关闭数据库
 sqldb.close();
 }
 /**
 * 删除记录
 * @param id
 */
 public void delete(Integer id){
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
 //sqldb.execsql("delete from person where personid=?",new Object[]{iD});
 //第一个参数是表名,第二个是where后面的条件用占位符表示,第三个对应占位符为参数值
 sqldb.delete("person","personid=?",new String[]{Integer.toString(id)});
 sqldb.close();
 }
 /**
 * 更新记录
 * @param person
 */
 public void update(Person person){
 sqliteDatabase sqldb = dbOperateHelper.getWritableDatabase();
 //sqldb.execsql("update person set name=?,phone=? where personid=?",person.getId()});
 //第一个参数为表名,第二个是一个更新值集合,采用键值对的形式,每个更新的字段对应更新值
 //第三个参数是where后面条件字段用占位符标识,第四个参数是对应where占位符的值
 ContentValues values = new ContentValues();
 values.put("name",person.getamount());
 sqldb.update("person",values,new String[]{person.getId().toString()});
 sqldb.close();
 }
 /**
 * 通过ID查询记录
 * @param id
 * @return
 */
 public Person find(Integer id){
 /**
  * getWritableDatabase 与 getReadableDatabase 的区别:
  * getReadableDatabase会先返回getWritableDatabase(可写),如果调用getWritableDatabase失败
  * 则才会调用getReadableDatabase后续方法,使数据库只读
  * 当写入的数据超过数据库大小则调用getWritableDatabase会失败
  * 所以只读时则可以使用此方法,其它情况(只要不是超过数据库大小)也可以使用此方法
  */
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 //cursor cursor = sqldb.rawQuery("SELEct * from person where personid=?",new String[]{String.valueOf(id)});
 //第一个参数是表名;第二个参数是查询显示的字段,null时查询显示所有字段;
 //第三个参数是where查询条件占位符;第四个是占位符对应的值;
 //第五个参数是group by条件;第六个是having条件;第七个是order by条件
 cursor cursor = sqldb.query("person",new String[]{id.toString()},null);
 int personid;
 String name;
 String phone;
 int amount;
 Person person = null;
 if(cursor.moveToFirst()){
  personid = cursor.geTint(cursor.getcolumnIndex("personid"));
  name = cursor.getString(cursor.getcolumnIndex("name"));
  phone = cursor.getString(cursor.getcolumnIndex("phone"));
  amount = cursor.geTint(cursor.getcolumnIndex("amount"));
  person = new Person(personid,int maxResult){
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 //cursor cursor = sqldb.rawQuery("SELEct * from person order by personid asc limit ?,String.valueOf(maxResult)});
 //第一个参数是表名;第二个参数是查询显示的字段,null时查询显示所有字段;
 //第三个参数是where查询条件占位符;第四个是占位符对应的值;
 //第五个参数是group by条件;第六个是having条件;第七个是order by条件
 //第八个参数是limit ?,? 条件
 cursor cursor = sqldb.query("person","personid",offset+","+maxResult);
 int personid;
 String name;
 String phone;
 int amount;
 Person person = null;
 List<Person> persons = new ArrayList<Person>();
 while(cursor.moveToNext()){
  personid = cursor.geTint(cursor.getcolumnIndex("personid"));
  name = cursor.getString(cursor.getcolumnIndex("name"));
  phone = cursor.getString(cursor.getcolumnIndex("phone"));
  amount = cursor.geTint(cursor.getcolumnIndex("amount"));
  person = new Person(personid,amount);
  persons.add(person);
 }
 cursor.close();
 return persons;
 }
 /**
 * 返回总记录数
 * @return
 */
 public long getCount(){
 sqliteDatabase sqldb = dbOperateHelper.getReadableDatabase();
 //cursor cursor = sqldb.rawQuery("SELEct count(*) from person",null);
 //第一个参数是表名;第二个参数是查询显示的字段,null时查询显示所有字段;
 //第三个参数是where查询条件占位符;第四个是占位符对应的值;
 //第五个参数是group by条件;第六个是having条件;第七个是order by条件
 cursor cursor = sqldb.query("person",new String[]{"count(*)"},null);
 //该查询语句值返回一条语句
 cursor.moveToFirst();
 long result = cursor.getLong(0);
 cursor.close();
 return result;
 }
}

十二、PersonserviCETest.java 单元测试类源码:

package com.example.test;
import java.util.List;
import com.example.domain.Person;
import com.example.service.DBOperateHelper;
import com.example.service.Personservice;import android.test.AndroidTESTCase;
import android.util.Log;
public class PersonserviCETest extends AndroidTESTCase {
 public void testcreatedb() throws Exception{
 DBOperateHelper dbHelper = new DBOperateHelper(getContext());
 dbHelper.getWritableDatabase();
 }
 public void testSave() throws Exception{
 Personservice ps = new Personservice(getContext());
 for(int i=1;i<=100;i++){
  Person person = new Person();
  person.setName("我是"+i);
  person.setPhone(String.valueOf(Long.parseLong("18888888800")+i));
  ps.save(person);
  Log.i("Personservice",person.toString());
 }
 }
 public void testdelete() throws Exception{
 Personservice ps = new Personservice(getContext());
 ps.delete(10);
 }
 public void testupdate() throws Exception{
 Personservice ps = new Personservice(getContext());
 ps.update(new Person(1,"xiaopang","18887654321",0));
 }
 public void testFind() throws Exception{
 Personservice ps = new Personservice(getContext());
 Person person = ps.find(1);
 Log.i("Personservice",person.toString());
 }
 public void testGetScrollData() throws Exception{
 Personservice ps = new Personservice(getContext());
 List<Person> persons = ps.getScrollData(3,5);
 for(Person person:persons){
  Log.i("Personservice",person.toString());
 }
 }
 public void testGetCount() throws Exception{
 Personservice ps = new Personservice(getContext());
 Long count = ps.getCount();
 Log.i("Personservice",count.toString());
 }
 public void testupdateamount() throws Exception{
 Personservice ps = new Personservice(getContext());
 Person person1 = ps.find(1);
 Person person2 = ps.find(2);
 person1.setamount(100);
 person2.setamount(100);
 ps.update(person1);
 ps.update(person2);
 }
 public void testPayment() throws Exception{
 Personservice ps = new Personservice(getContext());
 ps.payment();
 }
}

十三、OtherPersonserviCETest 单元测试类源码:

package com.example.test;
import java.util.List;
import com.example.domain.Person;
import com.example.service.DBOperateHelper;
import com.example.service.otherPersonservice;
import android.test.AndroidTESTCase;
import android.util.Log;
public class OtherPersonserviCETest extends AndroidTESTCase {
 public void testcreatedb() throws Exception{
 DBOperateHelper dbHelper = new DBOperateHelper(getContext());
 dbHelper.getWritableDatabase();
 }
 public void testSave() throws Exception{
 OtherPersonservice ps = new OtherPersonservice(getContext());
 for(int i=1;i<=100;i++){
  Person person = new Person();
  person.setName("我是"+i);
  person.setPhone(String.valueOf(Long.parseLong("18888888800")+i));
  ps.save(person);
  Log.i("Personservice",person.toString());
 }
 }
 public void testdelete() throws Exception{
 OtherPersonservice ps = new OtherPersonservice(getContext());
 ps.delete(10);
 }
 public void testupdate() throws Exception{
 OtherPersonservice ps = new OtherPersonservice(getContext());
 ps.update(new Person(1,0));
 }
 public void testFind() throws Exception{
 OtherPersonservice ps = new OtherPersonservice(getContext());
 Person person = ps.find(1);
 Log.i("Personservice",person.toString());
 }
 public void testGetScrollData() throws Exception{
 OtherPersonservice ps = new OtherPersonservice(getContext());
 List<Person> persons = ps.getScrollData(3,person.toString());
 }
 }
 public void testGetCount() throws Exception{
 OtherPersonservice ps = new OtherPersonservice(getContext());
 Long count = ps.getCount();
 Log.i("Personservice",count.toString());
 }
}

十四、注意事项以及相关知识点:

1、掌握sqlite数据库如何创建数据库、建立表、维护字段等操作
继承sqliteOpenHelper类,构造函数调用父类构造函数创建数据库,利用onCreate创建表,利用onUpgrade更新表字段信息

2、掌握sqlite数据库如何增、删、改、查以及分页
取得sqliteDatabase的实例,然后调用该实例的方法可以完成上述操作
sqliteDataBase提供两种操作上述功能的方式:一是直接调用execsql书写sql语句,另一种是通过insert、update、delete、query等方法来传值来拼接sql,前一种适合熟练掌握sql 语句的

3、对需要数据同步的处理请添加事务处理,熟悉事务的处理方式

4、了解各个方法参数的意义以及传值

5、掌握ListView显示后台数据的使用方法
SimpleAdapter、SimplecursorAdapter以及自定义适配器的使用,以及OnItemClickListener取值时各个适配器返回值的区别以及取值方法

6、多学、多记、多练、多思,加油!

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android通信方式总结》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结

希望本文所述对大家Android程序设计有所帮助。

大佬总结

以上是大佬教程为你收集整理的Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解全部内容,希望文章能够帮你解决Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: