Android操作SQLite數(shù)據(jù)庫(增、刪、改、查、分頁等)及ListView顯示數(shù)據(jù)的方法詳解
本文實(shí)例講述了Android操作SQLite數(shù)據(jù)庫(增、刪、改、查、分頁等)及ListView顯示數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
由于剛接觸android開發(fā),故此想把學(xué)到的基礎(chǔ)知識記錄一下,以備查詢,故此寫的比較啰嗦:
步驟如下:
一、介紹:
此文主要是介紹怎么使用android自帶的數(shù)據(jù)庫SQLite,以及把后臺的數(shù)據(jù)用ListView控件顯示
二、新建一個(gè)android工程——DBSQLiteOperate
工程目錄:
三、清單列表AndroidManifest.xml的配置為:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.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://schemas.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://schemas.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對象 //得到該條目數(shù)據(jù) // Person person = (Person)listView.getItemAtPosition(position); // //廣播出去 // Toast.makeText(getApplicationContext(), person.toString(), Toast.LENGTH_LONG).show(); //2、如果使用showList2()方法中的適配器時(shí),則取得的值是不一樣的,返回的是cursor // Cursor cursor = (Cursor)listView.getItemAtPosition(position); // int personid = cursor.getInt(cursor.getColumnIndex("_id")); // Toast.makeText(getApplicationContext(), personid+"", Toast.LENGTH_LONG).show(); //3、如果使用showList()方法中的適配器時(shí),則取得的值是不一樣的,返回的是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); //該適配器要求返回的結(jié)果集cursor必須包含_id字段,所以需要對取得結(jié)果集進(jìn)行處理 SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,R.layout.item,cursor,new String[]{"name","phone","amount"}, new int[]{R.id.name,R.id.phone,R.id.amount} ); listView.setAdapter(adapter); } /** * 自定義適配器 */ public void showList3(){ List<Person> persons = personService.getScrollData(0, 50); /** * 第一個(gè)參數(shù):上下文context,第二個(gè)參數(shù):要顯示的數(shù)據(jù),第三個(gè)參數(shù):綁定的條目界面 */ PersonAdapter adapter = new PersonAdapter(this, persons, R.layout.item); listView.setAdapter(adapter); } }
八、person.java 實(shí)體類 源碼:
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 業(yè)務(wù)類源碼:
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) {//默認(rèn)創(chuàng)建的數(shù)據(jù)庫文件保存在<包名>/database/ //第一個(gè)參數(shù)是上下文,第二個(gè)參數(shù)是數(shù)據(jù)庫名稱,第三個(gè)是游標(biāo)工廠為null時(shí)使用 數(shù)據(jù)庫默認(rèn)的游標(biāo)工廠,第四個(gè)是數(shù)據(jù)庫版本號但是不能為0,一般大于0 super(context, "smallpig", null, 4); } /** * 數(shù)據(jù)庫每一次被創(chuàng)建時(shí)被調(diào)用 */ @Override public void onCreate(SQLiteDatabase sqldb) { sqldb.execSQL("create table person(personid integer primary key autoincrement,name varchar(20),phone varchar(12) null)"); } /** * 每一次數(shù)據(jù)庫版本號發(fā)生變動時(shí)觸發(fā)此方法 * 比如如果想往數(shù)據(jù)庫中再插入一些表、字段或者其他信息時(shí)通過修改數(shù)據(jù)庫版本號來觸發(fā)此方法 */ @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 業(yè)務(wù)類源碼:
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){ //得到數(shù)據(jù)庫實(shí)例,里面封裝了數(shù)據(jù)庫操作方法 SQLiteDatabase sqldb = dbOperateHelper.getWritableDatabase(); //sqldb.execSQL("insert into person(name,phone) values('"+person.getName()+"','"+person.getPhone()+"')"); //利用占位符可以避免注入,但是注意數(shù)組參與與占位符對應(yīng)的字段要一一對應(yīng) sqldb.execSQL("insert into person(name,phone,amount) values(?,?,?)",new Object[]{person.getName(),person.getPhone(),person.getAmount()}); //關(guān)閉數(shù)據(jù)庫 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=?",new Object[]{person.getName(),person.getPhone(),person.getAmount(),person.getId()}); sqldb.close(); } /** * 通過ID查詢記錄 * @param id * @return */ public Person find(Integer id){ /** * getWritableDatabase 與 getReadableDatabase 的區(qū)別: * getReadableDatabase會先返回getWritableDatabase(可寫),如果調(diào)用getWritableDatabase失敗 * 則才會調(diào)用getReadableDatabase后續(xù)方法,使數(shù)據(jù)庫只讀 * 當(dāng)寫入的數(shù)據(jù)超過數(shù)據(jù)庫大小則調(diào)用getWritableDatabase會失敗 * 所以只讀時(shí)則可以使用此方法,其它情況(只要不是超過數(shù)據(jù)庫大小)也可以使用此方法 */ 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,phone,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,name,phone,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,name,phone,amount from person order by personid asc limit ?,?", new String[]{String.valueOf(offset),String.valueOf(maxResult)}); return cursor; } /** * 返回總記錄數(shù) * @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();//開啟事務(wù) 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();//設(shè)置事務(wù)標(biāo)志位true } finally { //結(jié)束事務(wù):有兩種情況:commit\rollback,事務(wù)提交或者回滾是由事務(wù)的標(biāo)識決定的 //事務(wù)為ture則提交,事務(wù)為flase則回滾,默認(rèn)為false sqldb.endTransaction(); } } }
十一、OtherPersonService.java 業(yè)務(wù)類源碼:
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){ //得到數(shù)據(jù)庫實(shí)例,里面封裝了數(shù)據(jù)庫操作方法 SQLiteDatabase sqldb = dbOperateHelper.getWritableDatabase(); //sqldb.execSQL("insert into person(name,phone) values('"+person.getName()+"','"+person.getPhone()+"')"); //利用占位符可以避免注入,但是注意數(shù)組參與與占位符對應(yīng)的字段要一一對應(yīng) //sqldb.execSQL("insert into person(name,phone) values(?,?)",new Object[]{person.getName(),person.getPhone()}); ContentValues values = new ContentValues(); values.put("name", person.getName()); values.put("phone", person.getPhone()); values.put("amount", person.getAmount()); //第一個(gè)參數(shù)是表名,第三個(gè)為字段值集合,第二個(gè)參數(shù)是空值字段,當(dāng)?shù)谌齻€(gè)字段值集合為空時(shí),系統(tǒng)會自動插入一條第二個(gè)參數(shù)為空的sql語句 //否則當(dāng)?shù)谌齻€(gè)參數(shù)為空時(shí),如果第二個(gè)參數(shù)也為空,那么插入表就會找不到插入的字段信息,會報(bào)錯(cuò) sqldb.insert("person", "name", values ); //關(guān)閉數(shù)據(jù)庫 sqldb.close(); } /** * 刪除記錄 * @param id */ public void delete(Integer id){ SQLiteDatabase sqldb = dbOperateHelper.getWritableDatabase(); //sqldb.execSQL("delete from person where personid=?",new Object[]{id}); //第一個(gè)參數(shù)是表名,第二個(gè)是where后面的條件用占位符表示,第三個(gè)對應(yīng)占位符為參數(shù)值 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=?",new Object[]{person.getName(),person.getPhone(),person.getId()}); //第一個(gè)參數(shù)為表名,第二個(gè)是一個(gè)更新值集合,采用鍵值對的形式,每個(gè)更新的字段對應(yīng)更新值 //第三個(gè)參數(shù)是where后面條件字段用占位符標(biāo)識,第四個(gè)參數(shù)是對應(yīng)where占位符的值 ContentValues values = new ContentValues(); values.put("name", person.getName()); values.put("phone", person.getPhone()); values.put("amount", person.getAmount()); sqldb.update("person", values , "personid=?", new String[]{person.getId().toString()}); sqldb.close(); } /** * 通過ID查詢記錄 * @param id * @return */ public Person find(Integer id){ /** * getWritableDatabase 與 getReadableDatabase 的區(qū)別: * getReadableDatabase會先返回getWritableDatabase(可寫),如果調(diào)用getWritableDatabase失敗 * 則才會調(diào)用getReadableDatabase后續(xù)方法,使數(shù)據(jù)庫只讀 * 當(dāng)寫入的數(shù)據(jù)超過數(shù)據(jù)庫大小則調(diào)用getWritableDatabase會失敗 * 所以只讀時(shí)則可以使用此方法,其它情況(只要不是超過數(shù)據(jù)庫大小)也可以使用此方法 */ SQLiteDatabase sqldb = dbOperateHelper.getReadableDatabase(); //Cursor cursor = sqldb.rawQuery("select * from person where personid=?", new String[]{String.valueOf(id)}); //第一個(gè)參數(shù)是表名;第二個(gè)參數(shù)是查詢顯示的字段,null時(shí)默認(rèn)查詢顯示所有字段; //第三個(gè)參數(shù)是where查詢條件占位符;第四個(gè)是占位符對應(yīng)的值; //第五個(gè)參數(shù)是group by條件;第六個(gè)是having條件;第七個(gè)是order by條件 Cursor cursor = sqldb.query("person", null, "personid=?", new String[]{id.toString()}, null, null, 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,name,phone,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)}); //第一個(gè)參數(shù)是表名;第二個(gè)參數(shù)是查詢顯示的字段,null時(shí)默認(rèn)查詢顯示所有字段; //第三個(gè)參數(shù)是where查詢條件占位符;第四個(gè)是占位符對應(yīng)的值; //第五個(gè)參數(shù)是group by條件;第六個(gè)是having條件;第七個(gè)是order by條件 //第八個(gè)參數(shù)是limit ?,? 條件 Cursor cursor = sqldb.query("person", null, null, null, null, null, "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,name,phone,amount); persons.add(person); } cursor.close(); return persons; } /** * 返回總記錄數(shù) * @return */ public long getCount(){ SQLiteDatabase sqldb = dbOperateHelper.getReadableDatabase(); //Cursor cursor = sqldb.rawQuery("select count(*) from person", null); //第一個(gè)參數(shù)是表名;第二個(gè)參數(shù)是查詢顯示的字段,null時(shí)默認(rèn)查詢顯示所有字段; //第三個(gè)參數(shù)是where查詢條件占位符;第四個(gè)是占位符對應(yīng)的值; //第五個(gè)參數(shù)是group by條件;第六個(gè)是having條件;第七個(gè)是order by條件 Cursor cursor = sqldb.query("person", new String[]{"count(*)"}, null, null, null, null, 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,"xiaopang","18887654321",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, 5); for(Person person:persons){ Log.i("PersonService",person.toString()); } } public void testGetCount() throws Exception{ OtherPersonService ps = new OtherPersonService(getContext()); Long count = ps.getCount(); Log.i("PersonService",count.toString()); } }
十四、注意事項(xiàng)以及相關(guān)知識點(diǎn):
1、掌握SQLite數(shù)據(jù)庫如何創(chuàng)建數(shù)據(jù)庫、建立表、維護(hù)字段等操作
繼承SQLiteOpenHelper類,構(gòu)造函數(shù)調(diào)用父類構(gòu)造函數(shù)創(chuàng)建數(shù)據(jù)庫,利用onCreate創(chuàng)建表,利用onUpgrade更新表字段信息
2、掌握SQLite數(shù)據(jù)庫如何增、刪、改、查以及分頁
取得SQLiteDatabase的實(shí)例,然后調(diào)用該實(shí)例的方法可以完成上述操作
SQLiteDataBase提供兩種操作上述功能的方式:一是直接調(diào)用execSQL書寫sql語句,另一種是通過insert、update、delete、query等方法來傳值來拼接sql,前一種適合熟練掌握sql 語句的
3、對需要數(shù)據(jù)同步的處理請?zhí)砑邮聞?wù)處理,熟悉事務(wù)的處理方式
4、了解各個(gè)方法參數(shù)的意義以及傳值
5、掌握ListView顯示后臺數(shù)據(jù)的使用方法
SimpleAdapter、SimpleCursorAdapter以及自定義適配器的使用,以及OnItemClickListener取值時(shí)各個(gè)適配器返回值的區(qū)別以及取值方法
6、多學(xué)、多記、多練、多思,加油!
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)入門與進(jìn)階教程》、《Android通信方式總結(jié)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計(jì)有所幫助。
- Oracle、MySQL和SqlServe三種數(shù)據(jù)庫分頁查詢語句的區(qū)別介紹
- jQuery+Ajax+PHP+Mysql實(shí)現(xiàn)分頁顯示數(shù)據(jù)實(shí)例講解
- oracle,mysql,SqlServer三種數(shù)據(jù)庫的分頁查詢的實(shí)例
- MSSQL MySQL 數(shù)據(jù)庫分頁(存儲過程)
- MySQL數(shù)據(jù)庫查看數(shù)據(jù)表占用空間大小和記錄數(shù)的方法
- sql 查詢記錄數(shù)結(jié)果集某個(gè)區(qū)間內(nèi)記錄
- MYSQL速度慢的問題 記錄數(shù)據(jù)庫語句
- SQL小技巧 又快又簡單的得到你的數(shù)據(jù)庫每個(gè)表的記錄數(shù)
- SQL Server 在分頁獲取數(shù)據(jù)的同時(shí)獲取到總記錄數(shù)
相關(guān)文章
Flutter實(shí)現(xiàn)牛頓擺動畫效果的示例代碼
牛頓擺大家應(yīng)該都不陌生,也叫碰碰球、永動球(理論情況下),那么今天我們用Flutter實(shí)現(xiàn)這么一個(gè)理論中的永動球,可以作為加載Loading使用,需要的可以參考一下2022-04-04android組件SwipeRefreshLayout下拉小球式刷新效果
這篇文章主要為大家詳細(xì)介紹了android組件SwipeRefreshLayout下拉小球式刷新效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02Android實(shí)現(xiàn)多段顏色進(jìn)度條效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)多段顏色進(jìn)度條效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01關(guān)于Android Studio封裝SDK的那些事兒
這篇文章主要給大家介紹了關(guān)于Android Studio封裝SDK的那些事兒,文中通過圖文以及示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09Android個(gè)人手機(jī)通訊錄開發(fā)詳解
在本篇文章里小編給大家分享了關(guān)于Android個(gè)人手機(jī)通訊錄開發(fā)的步驟和相關(guān)源碼,有需要的朋友們學(xué)習(xí)下。2019-02-02Android自定義view利用PathEffect實(shí)現(xiàn)動態(tài)效果
這篇文章主要為大家詳細(xì)介紹了Android自定義view利用PathEffect實(shí)現(xiàn)動態(tài)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05Android通過ExifInterface判斷Camera圖片方向的方法
今天小編就為大家分享一篇關(guān)于Android通過ExifInterface判斷相機(jī)圖片朝向的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12如何用HMS Nearby Service給自己的App添加近距離數(shù)據(jù)傳輸功能
這篇文章主要介紹了如何用HMS Nearby Service給自己的App添加近距離數(shù)據(jù)傳輸功能,本文通過圖文示例代碼相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07