`
ivoter
  • 浏览: 91420 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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. 原文链接:http://blog.csdn.net/hellogv/article/details/6011934
分享到:
评论
1 楼 mh_920930 2013-09-24  
[u][/u][/b][b][/b][b]
引用
[img][/img][url][/url][   flash=200,200][/flash]
[align=left][/align][/size][size=xx-large][color=brown][/color]

相关推荐

    Qt数据库分页显示

    本教程将深入探讨如何在Qt应用中实现SQLite数据库的数据分页显示。 首先,我们需要在Qt项目中集成SQLite数据库支持。在Qt Creator中,新建一个Qt Widgets Application项目,然后在.pro文件中添加`QT += sql`来启用...

    使用C#开发的Sqlite数据库创建、操作的源码项目工程

    这是一个使用C#开发的Sqlite数据库创建、操作的源码工程,关于Sqlite的所有操作已经单独创建了专门的跨平台【.NETCore3.1】类库包含相应的帮助类,可以直接生成后拿到任何项目中直接使用,高效简单,省去了从头开发...

    SQLite数据库分页

    公式select * from person limit ?,?; (第一个? 当前页码第一条数据的下标,第二个? 每页显示的数据) 1.页码为1时在ListView中展示对应的数据 2.当ListView加载完本页数据分页加载下一页数据

    c#连接sqlite分页显示实用教程资料.docx

    C#连接SQLite数据库并实现分页显示的教程 在C#开发Windows应用程序时,有时我们需要连接SQLite数据库并显示数据,特别是在处理大量数据时,分页显示尤为重要,这能提高用户体验并减少内存消耗。本教程将指导你如何...

    winform使用sqlite数据库自定义用户控件分页源码

    本项目“winform使用sqlite数据库自定义用户控件分页源码”结合了这两者,通过C#语言实现了一个自定义的分页用户控件,方便在WinForm应用中对SQLite数据库的数据进行分页显示。下面将详细解释这个项目中的关键知识点...

    SQLite 查询所有 分页查询 查询个数

    SQLite 是一个轻量级的、开源的嵌入式关系型数据库,它被广泛应用于移动设备、桌面应用甚至服务器端的数据存储。在处理大量数据时,为了提高效率并避免一次性加载所有数据导致性能下降,通常会采用分页查询的方式来...

    C#分享辅助类:SQLite数据库操作(SQLiteDao)

    本篇文章将深入探讨如何利用C#创建一个名为`SQLiteDao`的辅助类来实现对SQLite数据库的操作。我们将讨论相关的类、方法以及如何使用它们来执行常见的数据库操作。 首先,`SQLiteDao`类是数据库操作的核心,通常包含...

    Qt编写的数据库分页demo

    **Qt编写的数据库分页demo**是一个用于展示如何在Qt应用程序中实现高效、用户友好的数据库数据分页功能的示例项目。这个demo的核心在于它能够处理大量的数据,如千万级记录,同时提供流畅的用户体验,包括上一页、...

    Android 数据库开发(SQLite)

    Android上的SQLite数据库分页读取数据,实现并封装一个SQL分页表格控件,不仅支持分页还以表格的形式展示数据。主要功能包括: 1、创建数据库 2、插入示例数据 3、关闭数据库 4、分页显示数据 实现的SQL分页表格...

    AndroidSqlite数据库操作封装SQLiteUtils.zip

    一个简单的基于Android的Sqlite数据库的操作封装,它有如下的好处:便捷地创建表和增添表字段灵活的数据类型处理通过操作对象来insert或者update表记录支持多种查询方式,支持多表自定义的复杂查询,支持分页查询支持...

    易语言Sqlite数据库填充超级列表框

    SQLite数据库填充超级列表框是易语言编程中常见的数据可视化操作,它允许用户在界面上以列表形式查看数据库中的信息。 首先,我们要了解SQLite数据库。SQLite是一个嵌入式的、零配置的、支持事务的SQL数据库引擎。...

    C#操作SQLite数据库帮助类详解

    本文档介绍了C#操作SQLite数据库帮助类的实现和封装技巧,主要涉及到C#针对sqlite数据库的连接、查询、分页等各种常见操作。通过本文,读者可以了解如何使用C#语言来操作SQLite数据库,从而实现离线存储数据和查询...

    Android分页获取sqlite数据

    适合初学者 知识点: 1、listView分页加载 2、利用SparseArray实现ViewHolder的缓存 3、java反射机制读取sqlite查询结果 4、sqlite数据库分页读取 5、文件拷贝操作

    易语言Sqlite数据库类模块

    易语言Sqlite数据库类模块源码,Sqlite数据库类模块,初始化_SQLITE,销毁_SQLITE,添加纪录_批量,添加纪录,读取记录_单个字段_文本值,读取记录_多个字段,修改记录,删除记录,取记录集,填充记录们to超级列表框,分页_初始...

    Sqlite数据库的封装

    本知识点将详细探讨如何使用Java反射技术来封装Sqlite数据库,实现批量插入和分页查询,并且引入事务处理。 首先,我们需要创建一个Sqlite数据库的基类,这个类将包含与数据库交互的基本方法,如打开、关闭、创建表...

    SQLite数据库图形化管理工具

    SQLite数据库是一种轻量级、无服务器、自包含的SQL数据库引擎,广泛应用于移动应用、嵌入式系统以及作为测试和开发环境中的数据存储解决方案。它无需独立的数据库服务器进程,可以直接在应用程序中进行操作,降低了...

    查询Sqlite分页显示在ListView里

    首先,我们需要创建一个SQLite数据库。在Android中,这通常通过实现`SQLiteOpenHelper`类来完成。这个类允许我们创建和升级数据库,并提供了`onCreate()`和`onUpgrade()`两个关键方法。在`onCreate()`中,我们会定义...

    SQLite数据库封装

    本项目“SQLite数据库封装”专注于简化SQLite数据库在Android开发中的操作,通过Kotlin语言实现了高效、简洁的数据库访问接口。 首先,SQLite数据库在Android中的使用通常涉及以下步骤: 1. 创建数据库:通过继承`...

    Nodejs操作Sqlite3数据库封装

    在Node.js环境中,SQLite3是一个常用的轻量级数据库,它不需要单独的服务进程,可以直接在内存中或磁盘上创建数据库文件。本篇文章将深入探讨如何使用`node-sqlite3`库来操作SQLite3数据库,并对其进行封装,以便于...

    SQLite 数据库拷贝 联想输入 滚动翻页实例

    在移动应用开发中,SQLite数据库通常用于存储应用程序的数据,因为它轻量级、高效且本地化。本实例聚焦于SQLite数据库的拷贝、使用以及在应用中的实现,特别关注联想输入和滚动翻页功能。以下是对这些关键知识点的...

Global site tag (gtag.js) - Google Analytics