MySQLiteDemo.java:
import android.app.Activity; import android.database.sqlite.SQLiteOpenHelper; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.ArrayAdapter; import android.widget.Button; import android.widget.LinearLayout; import android.widget.ListView; public class MySQLiteDemo extends Activity { private SQLiteOpenHelper helper = null ; // 数据库操作 private Button findBut = null ; // 定义按钮 private LinearLayout mylayout = null ; // 定义布局管理器 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 父类onCreate() super.setContentView(R.layout.main); // 默认布局管理器 this.findBut = (Button) super.findViewById(R.id.findBut) ; // 取得组件 System.out.println("**" + super.findViewById(R.id.mylayout).getClass()) ; this.mylayout = (LinearLayout) super.findViewById(R.id.mylayout) ; // 取得组件 this.helper = new MyDatabaseHelper(this) ; // 定义数据库辅助类 this.findBut.setOnClickListener(new OnClickListenerImpl()) ; // 设置监听 } private class OnClickListenerImpl implements OnClickListener { @Override public void onClick(View view) { MySQLiteDemo.this.helper = new MyDatabaseHelper(MySQLiteDemo.this) ; ListView listView = new ListView(MySQLiteDemo.this) ; // 定义ListView listView.setAdapter(new ArrayAdapter<String>(MySQLiteDemo.this, // 将数据包装 android.R.layout.simple_list_item_1, // 每行显示一条数据 new MytabCursor(MySQLiteDemo.this.helper .getReadableDatabase()).find())); // 设置显示数据 MySQLiteDemo.this.mylayout.addView(listView) ; // 追加组件 } } }
MytabCursor.java:
import java.util.ArrayList; import java.util.List; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; public class MytabCursor { private static final String TABLENAME = "mytab" ; // 数据表名称 private SQLiteDatabase db = null ; // SQLiteDatabase public MytabCursor(SQLiteDatabase db) { // 构造方法 this.db = db ; // 接收SQLiteDatabase } public List<String> find() { // 查询数据表 List<String> all = new ArrayList<String>() ; // 定义List集合 int currentPage = 1 ; // 当前页 int lineSize = 5 ; // 没页显示5条 String keyWord = "中国" ; // 查询关键字 String sql = "SELECT id,name,birthday FROM " + TABLENAME + " WHERE (name LIKE ? OR birthday LIKE ?)" + " LIMIT ?,? " ; // 查询SQL String selectionArgs[] = new String[] { "%" + keyWord + "%", "%" + keyWord + "%", String.valueOf((currentPage - 1) * lineSize), String.valueOf(lineSize) }; // 查询参数 Cursor result = db.rawQuery(sql, selectionArgs); // 查询 for (result.moveToFirst(); !result.isAfterLast(); result.moveToNext()) { all.add("【" + result.getInt(0) + "】" + " " + result.getString(1) + "," + result.getString(2)); // 设置集合数据 } this.db.close() ; // 关闭数据库连接 return all ; } }
相关推荐
前言:最近做基于openfire聊天(仿QQ、微信)翻页查看聊天记录,为此做了根据时间倒序查看聊天记录,先声明这demo是根据id来倒序(原理和时间倒序一样) 文章地址:...
android的分页加载是非常有用且非常常见的功能,我对分页加载做了一个例子很实用,希望能给你带来帮助。
这是一个android listview分页查询显示的demo,使用sqlite数据库,然后每次显示10条,上拉加载更多数据,studio项目
适合初学者 知识点: 1、listView分页加载 2、利用SparseArray实现ViewHolder的缓存 3、java反射机制读取sqlite查询结果 4、sqlite数据库分页读取 5、文件拷贝操作
android sqlite数据库的分页显示
Android提高第九篇之SQLite分页表格
Android提高第八篇之SQLite分页读取
上次讲的Android上的SQLite分页读取,只用文本框显示数据而已,这次就讲得更加深入些,实现并封装一个SQL分页表格控件,不仅支持分页还是以表格的形式展示数据。
从Sqlite数据库中查询出数据,进行分页显示,计算总页数,可以点击上一页,下一页。也可以自定义,每页要显示的数量,适合初学者学习用,高手指点下需要改进的地方。
android sqlite操作源码,包括增删改查,环境要求4.0以上
主要介绍了Android提高之SQLite分页表格实现方法,在项目开发中有很高的实用价值,需要的朋友可以参考下
21天学习android开发教程之SQLite分页读取,Android包含了常用于嵌入式系统的SQLite,免去了开发者自己移植安装的功夫,感兴趣的朋友可以参考一下
主要介绍了Android的SQLite分页读取实现方法,在Android项目开发中非常实用,需要的朋友可以参考下
Android上的SQLite数据库分页读取数据,实现并封装一个SQL分页表格控件,不仅支持分页还以表格的形式展示数据。主要功能包括: 1、创建数据库 2、插入示例数据 3、关闭数据库 4、分页显示数据 实现的SQL分页表格...
android内部有缓存可关闭也不关闭也行,查询rawQuery是方法 3.在分页有到Cursor(游标)取游标下一个值cursor.moveToNext(),用游标对象接数据 "select * from person limit ?,?" person不能加上where 关键字 4.在...
Android Room是Google发布的一个和SQLite相关的的数据库,它是一个轻量级的ORM(Object Relational Mapping)对象关系映射数据库,其本质上是对Android原生的SQLite的封装,只不过相对比原生操作更简单、高效,目前...
主要介绍了Android实现基于滑动的SQLite数据分页加载技术,涉及Android针对SQLite数据的读取及查询结果的分页显示功能相关实现技巧,末尾还附带demo源码供读者下载参考,需要的朋友可以参考下