设为首页 收藏本站
查看: 1844|回复: 0

[经验分享] sqlite数据库分页

[复制链接]

尚未签到

发表于 2016-11-29 11:37:07 | 显示全部楼层 |阅读模式
Android包含了常用于嵌入式系统的SQLite,免去了开发者自己移植安装的功夫。SQLite 支持多数 SQL92 标准,很多常用的SQL命令都能在SQLite上面使用,除此之外Android还提供了一系列自定义的方法去简化对SQLite数据库的操作。不过有跨平台需求的程序就建议使用标准的SQL语句,毕竟这样容易在多个平台之间移植。
先贴出本文程序运行的结果:
DSC0000.gif
本文主要讲解了SQLite的基本用法,如:创建数据库,使用SQL命令查询数据表、插入数据,关闭数据库,以及使用GridView实现了一个分页栏(关于GridView的用法),用于把数据分页显示。
分页栏的pagebuttons.xml的源码如下:

源码打印?


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

 
main.xml的源码如下:
 

源码打印?


  • <?xml version="1.0" encoding="utf-8"?>  
  • <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  •     android:orientation="vertical" android:layout_width="fill_parent"  
  •     android:layout_height="fill_parent">  
  •     <Button android:layout_height="wrap_content"  
  •         android:layout_width="fill_parent" android:id="@+id/btnCreateDB"  
  •         android:text="创建数据库"></Button>  
  •     <Button android:layout_height="wrap_content"  
  •         android:layout_width="fill_parent" android:text="插入一串实验数据" android:id="@+id/btnInsertRec"></Button>  
  •     <Button android:layout_height="wrap_content" android:id="@+id/btnClose"  
  •         android:text="关闭数据库" android:layout_width="fill_parent"></Button>  
  •     <EditText android:text="@+id/EditText01" android:id="@+id/EditText01"  
  •         android:layout_width="fill_parent" android:layout_height="256dip"></EditText>  
  •     <GridView android:id="@+id/gridview" android:layout_width="fill_parent"  
  •         android:layout_height="32dip" android:numColumns="auto_fit"  
  •         android:columnWidth="40dip"></GridView>  
  • </LinearLayout>  

 
本文程序源码如下:

源码打印?


  • package com.testSQLite;    
  •     
  • import java.util.ArrayList;    
  • import java.util.HashMap;    
  • import android.app.Activity;    
  • import android.database.Cursor;    
  • import android.database.SQLException;    
  • import android.database.sqlite.SQLiteDatabase;    
  • import android.os.Bundle;    
  • import android.util.Log;    
  • import android.view.View;    
  • import android.widget.AdapterView;    
  • import android.widget.AdapterView.OnItemClickListener;    
  • import android.widget.Button;    
  • import android.widget.EditText;    
  • import android.widget.GridView;    
  • import android.widget.SimpleAdapter;    
  •     
  • public class testSQLite extends Activity {    
  •     /** Called when the activity is first created. */    
  •     Button btnCreateDB, btnInsert, btnClose;    
  •     EditText edtSQL;//显示分页数据    
  •     SQLiteDatabase db;    
  •     int id;//添加记录时的id累加标记,必须全局    
  •     static final int PageSize=10;//分页时,每页的数据总数    
  •     private static final String TABLE_NAME = "stu";    
  •     private static final String ID = "id";    
  •     private static final String NAME = "name";    
  •         
  •     SimpleAdapter saPageID;// 分页栏适配器    
  •     ArrayList<HashMap<String, String>> lstPageID;// 分页栏的数据源,与PageSize和数据总数相关    
  •     
  •     @Override    
  •     public void onCreate(Bundle savedInstanceState) {    
  •         super.onCreate(savedInstanceState);    
  •         setContentView(R.layout.main);    
  •         btnCreateDB = (Button) this.findViewById(R.id.btnCreateDB);    
  •         btnCreateDB.setOnClickListener(new ClickEvent());    
  •     
  •         btnInsert = (Button) this.findViewById(R.id.btnInsertRec);    
  •         btnInsert.setOnClickListener(new ClickEvent());    
  •     
  •         btnClose = (Button) this.findViewById(R.id.btnClose);    
  •         btnClose.setOnClickListener(new ClickEvent());    
  •             
  •         edtSQL=(EditText)this.findViewById(R.id.EditText01);    
  •             
  •         GridView gridview = (GridView) findViewById(R.id.gridview);//分页栏控件    
  •         // 生成动态数组,并且转入数据    
  •         lstPageID = new ArrayList<HashMap<String, String>>();    
  •     
  •         // 生成适配器的ImageItem <====> 动态数组的元素,两者一一对应    
  •         saPageID = new SimpleAdapter(testSQLite.this// 没什么解释    
  •                 lstPageID,// 数据来源    
  •                 R.layout.pagebuttons,//XML实现    
  •                 new String[] { "ItemText" },    
  •                 new int[] { R.id.ItemText });    
  •     
  •         // 添加并且显示    
  •         gridview.setAdapter(saPageID);    
  •         // 添加消息处理    
  •         gridview.setOnItemClickListener(new OnItemClickListener(){    
  •     
  •             @Override    
  •             public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,    
  •                     long arg3) {    
  •                 LoadPage(arg2);//根据所选分页读取对应的数据    
  •             }    
  •         });    
  •     
  •     }    
  •     
  •         
  •     class ClickEvent implements View.OnClickListener {    
  •     
  •         @Override    
  •         public void onClick(View v) {    
  •             if (v == btnCreateDB) {    
  •                 CreateDB();    
  •             } else if (v == btnInsert) {    
  •                 InsertRecord(16);//插入16条记录    
  •                 RefreshPage();    
  •             }else if (v == btnClose) {    
  •                 db.close();    
  •             }    
  •         }    
  •     
  •     }    
  •         
  •     
  •     /*  
  •      * 读取指定ID的分页数据  
  •      * SQL:Select * From TABLE_NAME Limit 9 Offset 10;  
  •      * 表示从TABLE_NAME表获取数据,跳过10行,取9行  
  •      */    
  •     void LoadPage(int pageID)    
  •     {    
  •         String sql= "select * from " + TABLE_NAME +     
  •         " Limit "+String.valueOf(PageSize)+ " Offset " +String.valueOf(pageID*PageSize);    
  •         Cursor rec = db.rawQuery(sql, null);    
  •     
  •         setTitle("当前分页的数据总数:"+String.valueOf(rec.getCount()));    
  •             
  •         // 取得字段名称    
  •         String title = "";    
  •         int colCount = rec.getColumnCount();    
  •         for (int i = 0; i < colCount; i++)    
  •             title = title + rec.getColumnName(i) + "     ";    
  •     
  •             
  •         // 列举出所有数据    
  •         String content="";    
  •         int recCount=rec.getCount();    
  •         for (int i = 0; i < recCount; i++) {//定位到一条数据    
  •             rec.moveToPosition(i);    
  •             for(int ii=0;ii<colCount;ii++)//定位到一条数据中的每个字段    
  •             {    
  •                 content=content+rec.getString(ii)+"     ";    
  •             }    
  •             content=content+"/r/n";    
  •         }    
  •             
  •         edtSQL.setText(title+"/r/n"+content);//显示出来    
  •         rec.close();    
  •     }    
  •         
  •     /*  
  •      * 在内存创建数据库和数据表  
  •      */    
  •     void CreateDB() {    
  •         // 在内存创建数据库    
  •         db = SQLiteDatabase.create(null);    
  •         Log.e("DB Path", db.getPath());    
  •         String amount = String.valueOf(databaseList().length);    
  •         Log.e("DB amount", amount);    
  •         // 创建数据表    
  •         String sql = "CREATE TABLE " + TABLE_NAME + " (" + ID    
  •                 + " text not null, " + NAME + " text not null " + ");";    
  •         try {    
  •             db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);    
  •             db.execSQL(sql);    
  •         } catch (SQLException e) {}    
  •     }    
  •     
  •     /*  
  •      * 插入N条数据  
  •      */    
  •     void InsertRecord(int n) {    
  •         int total = id + n;    
  •         for (; id < total; id++) {    
  •             String sql = "insert into " + TABLE_NAME + " (" + ID + ", " + NAME    
  •                     + ") values('" + String.valueOf(id) + "', 'test');";    
  •             try {    
  •                 db.execSQL(sql);    
  •             } catch (SQLException e) {    
  •             }    
  •         }    
  •     }    
  •     
  •     /*  
  •      * 插入之后刷新分页  
  •      */    
  •     void RefreshPage()    
  •     {    
  •         String sql = "select count(*) from " + TABLE_NAME;    
  •         Cursor rec = db.rawQuery(sql, null);    
  •         rec.moveToLast();    
  •         long recSize=rec.getLong(0);//取得总数    
  •         rec.close();    
  •         int pageNum=(int)(recSize/PageSize) + 1;//取得分页数    
  •             
  •         lstPageID.clear();    
  •         for (int i = 0; i < pageNum; i++) {    
  •             HashMap<String, String> map = new HashMap<String, String>();    
  •             map.put("ItemText""No." + String.valueOf(i));  
  •     
  •             lstPageID.add(map);    
  •         }    
  •         saPageID.notifyDataSetChanged();    
  •     }    

  • 原文链接:http://blog.csdn.net/hellogv/article/details/6011934

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307214-1-1.html 上篇帖子: 事务和锁(SQLite) 下篇帖子: 开源点评:SQLite数据库扫盲
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表