• Android之SQLite分页读取


    Android 包含了常用于嵌入式系统的SQLite,免去了开发者自己移植安装的功夫。SQLite 支持多数 SQL92 标准,很多常用的SQL命令都能在SQLite上面使用,除此之外Android还提供了一系列自定义的方法去简化对SQLite数据库的操作。不过有跨 平台需求的程序就建议使用标准的SQL语句,毕竟这样容易在多个平台之间移植。

    先贴出本文程序运行的结果:

    本文主要讲解了SQLite的基本用法,如:创建数据库,使用SQL命令查询数据表、插入数据,关闭数据库,以及使用GridView实现了一个分页栏(关于GridView的用法),用于把数据分页显示。

    分页栏的pagebuttons.xml的源码如下:

     

    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:layout_height="wrap_content" android:paddingBottom="4dip"  
    4.     android:layout_width="fill_parent">  
    5.     <TextView android:layout_width="wrap_content"  
    6.         android:layout_below="@+id/ItemImage" android:layout_height="wrap_content"  
    7.         android:text="TextView01" android:layout_centerHorizontal="true"  
    8.         android:id="@+id/ItemText">  
    9.     </TextView>  
    10. </RelativeLayout>    

    main.xml的源码如下:

     

     

    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:orientation="vertical" android:layout_width="fill_parent"  
    4.     android:layout_height="fill_parent">  
    5.     <Button android:layout_height="wrap_content"  
    6.         android:layout_width="fill_parent" android:id="@+id/btnCreateDB"  
    7.         android:text="创建数据库"></Button>  
    8.     <Button android:layout_height="wrap_content"  
    9.         android:layout_width="fill_parent" android:text="插入一串实验数据" android:id="@+id/btnInsertRec"></Button>  
    10.     <Button android:layout_height="wrap_content" android:id="@+id/btnClose"  
    11.         android:text="关闭数据库" android:layout_width="fill_parent"></Button>  
    12.     <EditText android:text="@+id/EditText01" android:id="@+id/EditText01"  
    13.         android:layout_width="fill_parent" android:layout_height="256dip"></EditText>  
    14.     <GridView android:id="@+id/gridview" android:layout_width="fill_parent"  
    15.         android:layout_height="32dip" android:numColumns="auto_fit"  
    16.         android:columnWidth="40dip"></GridView>  
    17. </LinearLayout>  

    本文程序源码如下:

     

      1. package com.testSQLite;    
      2.     
      3. import java.util.ArrayList;    
      4. import java.util.HashMap;    
      5. import android.app.Activity;    
      6. import android.database.Cursor;    
      7. import android.database.SQLException;    
      8. import android.database.sqlite.SQLiteDatabase;    
      9. import android.os.Bundle;    
      10. import android.util.Log;    
      11. import android.view.View;    
      12. import android.widget.AdapterView;    
      13. import android.widget.AdapterView.OnItemClickListener;    
      14. import android.widget.Button;    
      15. import android.widget.EditText;    
      16. import android.widget.GridView;    
      17. import android.widget.SimpleAdapter;    
      18.     
      19. public class testSQLite extends Activity {    
      20.     /** Called when the activity is first created. */    
      21.     Button btnCreateDB, btnInsert, btnClose;    
      22.     EditText edtSQL;//显示分页数据    
      23.     SQLiteDatabase db;    
      24.     int id;//添加记录时的id累加标记,必须全局    
      25.     static final int PageSize=10;//分页时,每页的数据总数    
      26.     private static final String TABLE_NAME = "stu";    
      27.     private static final String ID = "id";    
      28.     private static final String NAME = "name";    
      29.         
      30.     SimpleAdapter saPageID;// 分页栏适配器    
      31.     ArrayList<HashMap<String, String>> lstPageID;// 分页栏的数据源,与PageSize和数据总数相关    
      32.     
      33.     @Override    
      34.     public void onCreate(Bundle savedInstanceState) {    
      35.         super.onCreate(savedInstanceState);    
      36.         setContentView(R.layout.main);    
      37.         btnCreateDB = (Button) this.findViewById(R.id.btnCreateDB);    
      38.         btnCreateDB.setOnClickListener(new ClickEvent());    
      39.     
      40.         btnInsert = (Button) this.findViewById(R.id.btnInsertRec);    
      41.         btnInsert.setOnClickListener(new ClickEvent());    
      42.     
      43.         btnClose = (Button) this.findViewById(R.id.btnClose);    
      44.         btnClose.setOnClickListener(new ClickEvent());    
      45.             
      46.         edtSQL=(EditText)this.findViewById(R.id.EditText01);    
      47.             
      48.         GridView gridview = (GridView) findViewById(R.id.gridview);//分页栏控件    
      49.         // 生成动态数组,并且转入数据    
      50.         lstPageID = new ArrayList<HashMap<String, String>>();    
      51.     
      52.         // 生成适配器的ImageItem <====> 动态数组的元素,两者一一对应    
      53.         saPageID = new SimpleAdapter(testSQLite.this// 没什么解释    
      54.                 lstPageID,// 数据来源    
      55.                 R.layout.pagebuttons,//XML实现    
      56.                 new String[] { "ItemText" },    
      57.                 new int[] { R.id.ItemText });    
      58.     
      59.         // 添加并且显示    
      60.         gridview.setAdapter(saPageID);    
      61.         // 添加消息处理    
      62.         gridview.setOnItemClickListener(new OnItemClickListener(){    
      63.     
      64.             @Override    
      65.             public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,    
      66.                     long arg3) {    
      67.                 LoadPage(arg2);//根据所选分页读取对应的数据    
      68.             }    
      69.         });    
      70.     
      71.     }    
      72.     
      73.         
      74.     class ClickEvent implements View.OnClickListener {    
      75.     
      76.         @Override    
      77.         public void onClick(View v) {    
      78.             if (v == btnCreateDB) {    
      79.                 CreateDB();    
      80.             } else if (v == btnInsert) {    
      81.                 InsertRecord(16);//插入16条记录    
      82.                 RefreshPage();    
      83.             }else if (v == btnClose) {    
      84.                 db.close();    
      85.             }    
      86.         }    
      87.     
      88.     }    
      89.         
      90.     
      91.     /*  
      92.      * 读取指定ID的分页数据  
      93.      * SQL:Select * From TABLE_NAME Limit 9 Offset 10;  
      94.      * 表示从TABLE_NAME表获取数据,跳过10行,取9行  
      95.      */    
      96.     void LoadPage(int pageID)    
      97.     {    
      98.         String sql= "select * from " + TABLE_NAME +     
      99.         " Limit "+String.valueOf(PageSize)+ " Offset " +String.valueOf(pageID*PageSize);    
      100.         Cursor rec = db.rawQuery(sql, null);    
      101.     
      102.         setTitle("当前分页的数据总数:"+String.valueOf(rec.getCount()));    
      103.             
      104.         // 取得字段名称    
      105.         String title = "";    
      106.         int colCount = rec.getColumnCount();    
      107.         for (int i = 0; i < colCount; i++)    
      108.             title = title + rec.getColumnName(i) + "     ";    
      109.     
      110.             
      111.         // 列举出所有数据    
      112.         String content="";    
      113.         int recCount=rec.getCount();    
      114.         for (int i = 0; i < recCount; i++) {//定位到一条数据    
      115.             rec.moveToPosition(i);    
      116.             for(int ii=0;ii<colCount;ii++)//定位到一条数据中的每个字段    
      117.             {    
      118.                 content=content+rec.getString(ii)+"     ";    
      119.             }    
      120.             content=content+"/r/n";    
      121.         }    
      122.             
      123.         edtSQL.setText(title+"/r/n"+content);//显示出来    
      124.         rec.close();    
      125.     }    
      126.         
      127.     /*  
      128.      * 在内存创建数据库和数据表  
      129.      */    
      130.     void CreateDB() {    
      131.         // 在内存创建数据库    
      132.         db = SQLiteDatabase.create(null);    
      133.         Log.e("DB Path", db.getPath());    
      134.         String amount = String.valueOf(databaseList().length);    
      135.         Log.e("DB amount", amount);    
      136.         // 创建数据表    
      137.         String sql = "CREATE TABLE " + TABLE_NAME + " (" + ID    
      138.                 + " text not null, " + NAME + " text not null " + ");";    
      139.         try {    
      140.             db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);    
      141.             db.execSQL(sql);    
      142.         } catch (SQLException e) {}    
      143.     }    
      144.     
      145.     /*  
      146.      * 插入N条数据  
      147.      */    
      148.     void InsertRecord(int n) {    
      149.         int total = id + n;    
      150.         for (; id < total; id++) {    
      151.             String sql = "insert into " + TABLE_NAME + " (" + ID + ", " + NAME    
      152.                     + ") values('" + String.valueOf(id) + "', 'test');";    
      153.             try {    
      154.                 db.execSQL(sql);    
      155.             } catch (SQLException e) {    
      156.             }    
      157.         }    
      158.     }    
      159.     
      160.     /*  
      161.      * 插入之后刷新分页  
      162.      */    
      163.     void RefreshPage()    
      164.     {    
      165.         String sql = "select count(*) from " + TABLE_NAME;    
      166.         Cursor rec = db.rawQuery(sql, null);    
      167.         rec.moveToLast();    
      168.         long recSize=rec.getLong(0);//取得总数    
      169.         rec.close();    
      170.         int pageNum=(int)(recSize/PageSize) + 1;//取得分页数    
      171.             
      172.         lstPageID.clear();    
      173.         for (int i = 0; i < pageNum; i++) {    
      174.             HashMap<String, String> map = new HashMap<String, String>();    
      175.             map.put("ItemText""No." + String.valueOf(i));  
      176.     
      177.             lstPageID.add(map);    
      178.         }    
      179.         saPageID.notifyDataSetChanged();    
      180.     }    
      181. }   
  • 相关阅读:
    每日英语:Yahoo's Rally: Made in China
    【Java线程】Callable和Future
    Throwable和Exception的区别
    Java异常分类
    牛客网上的剑指offer题目
    合并两个排序的链表
    反转链表
    链表中倒数第k个结点
    调整数组顺序使奇数位于偶数前面
    数值的整数次方
  • 原文地址:https://www.cnblogs.com/Codenewbie/p/2973242.html
Copyright © 2020-2023  润新知