Android快速入门-----数据存储(三)Sqlite应用练习:增删查改案例练习,应用的优化(背景显示)
2) 布局文件当中的
3)如果想在没有数据的时候,显示一个提示文本,可以在布局当中定义一个
发布日期:2021-06-29 15:03:36
浏览次数:3
分类:技术文章
本文共 10134 字,大约阅读时间需要 33 分钟。
一、黑名单的管理
二、功能实现
1、创建项目
2、布局功能实现
(1)界面ListView
1)完善activity_main.xml
2)完善MainActivity
package com.itzheng.app04_sqlite;import android.app.Activity;import android.os.Bundle;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.widget.ListView;public class MainActivity extends Activity { //初始化ListView private ListView lv_main; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); lv_main = (ListView) findViewById(R.id.lv_main); } public void add(View v){ }}
3)测试
(2)DBHelper:数据库–表:定义DAO,
创建DBHelper类
package com.itzheng.app04_sqlite;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import android.util.Log;/* * 数据库操作的帮助类 */public class DBHelper extends SQLiteOpenHelper { public DBHelper(Context context ) { super(context, "itzheng.db", null, 1); } @Override public void onCreate(SQLiteDatabase db) { Log.i("TAG", "DBHelper onCreate()"); //创建表 db.execSQL("create table black_number(_id integer primary key autoincrement,number varchar )"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub }}
(3)实体类
创建BlackNumber
package com.itzheng.app04_sqlite;/* * 某一个表black_number表对应的实现类 */public class BlackNumber { private int id; private String number; public BlackNumber() { super(); // TODO Auto-generated constructor stub } public BlackNumber(int id, String number) { super(); this.id = id; this.number = number; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number; } @Override public String toString() { return "BlackNumber [id=" + id + ", number=" + number + "]"; }}
(4)DAO
创建BlackNumberDao,实现增删改查
package com.itzheng.app04_sqlite;import java.util.ArrayList;import java.util.List;import android.content.ContentValues;import android.content.Context;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.util.Log;import android.widget.ArrayAdapter;/* * 操作black_number表的DAO类 */public class BlackNumberDao { private DBHelper dbHelper; public BlackNumberDao(Context context) { dbHelper = new DBHelper(context); } /* * 添加一条记录 */ public void add(BlackNumber blackNumber) { // 1、得到连接 SQLiteDatabase database = dbHelper.getReadableDatabase(); // 2、执行insert insert into balck_number ( number ) values(xxx) ContentValues values = new ContentValues(); values.put("number", blackNumber.getNumber()); long id = database.insert("balck_number", null, values); Log.i("TAG", "id=" + id); // 3、关闭 database.close(); } /* * 根据ID删除一条记录 */ public void deleteById(int id) { // 1、得到连接 SQLiteDatabase database = dbHelper.getReadableDatabase(); // 2、执行delete delete from black_number where _id = id int deleteCount = database.delete("black_number", "_id=?", new String[] { id + "" }); Log.i("TAG", "deleteCount" + deleteCount); // 3、关闭 database.close(); } /* * 更新记录 */ public void update(BlackNumber blackNumber) { // 1、得到连接 SQLiteDatabase database = dbHelper.getReadableDatabase(); // 2、执行update update balck_number set number = xxx where _id = id ContentValues values = new ContentValues(); values.put("number", blackNumber.getNumber()); int updateCount = database.update("black_number", values, "_id=" + blackNumber.getId(), null); Log.i("TAG", "updateCount" + updateCount); // 3、关闭 database.close(); } /* * 查询所有记录,分装为List*/ public List getAll() { List list = new ArrayList (); // 1、得到连接 SQLiteDatabase database = dbHelper.getReadableDatabase(); // 2、执行query select * from black_number Cursor cursor = database.query("black_number", null, null, null, null, null, null); while (cursor.moveToNext()) { // id int id = cursor.getInt(0); // number String number = cursor.getString(1); list.add(new BlackNumber(id, number)); } // 从cursor当中取出所有数据,并封装到List当中 cursor.close(); // 3、关闭 database.close(); return list; }}
(5)显示列表
完善MainActivity
package com.itzheng.app04_sqlite;import java.util.List;import android.app.Activity;import android.os.Bundle;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.view.ViewGroup;import android.widget.BaseAdapter;import android.widget.ListView;import android.widget.TextView;public class MainActivity extends Activity { //初始化ListView private ListView lv_main; private BlackNumberAdapter adapter; private BlackNumberDao dao; private Listdata; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); lv_main = (ListView) findViewById(R.id.lv_main); adapter = new BlackNumberAdapter(); dao = new BlackNumberDao(this); data = dao.getAll(); lv_main.setAdapter(adapter); } public void add(View v){ } class BlackNumberAdapter extends BaseAdapter { @Override public int getCount() { return data.size(); } @Override public Object getItem(int position) { return data.get(position); } @Override public long getItemId(int position) { return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { if(convertView == null){ convertView = View.inflate(MainActivity.this, android.R.layout.simple_list_item_1, null); } BlackNumber blackNumber = data.get(position); TextView textView = (TextView) convertView.findViewById(android.R.id.text1); textView.setText(blackNumber.getNumber()); return convertView; } }}
(6)添加黑名单
完善MainActivity当中的add方法
1、显示添加的dialog(带输入框)
2、在确定的回调方法当中实现: 保存数据到数据库当中 保存数据到内存集合当中 通知更新列表public void add(View v){ final EditText editText = new EditText(this); editText.setHint("输入黑名单号"); new AlertDialog.Builder(this)//在当前页面建立AlertDialog(弹出框) .setTitle("添加黑名单") .setView(editText) .setPositiveButton("添加", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //保存数据到数据库当中 String number = editText.getText().toString();//获取页面上的数据 BlackNumber blackNumber = new BlackNumber(-1,number); dao.add(blackNumber);//将数据保存到数据库当中 //保存数据到内存集合当中 data.add(0,blackNumber);//在以有的数据当中添加数据(页面上已有的数据)已经有ID //通知更新列表 adapter.notifyDataSetChanged(); } } ) .setNegativeButton("取消", null) .show(); }
新添加的需要显示在第一行,后并显示在第一行
修改BlackNumberDao当中getAll方法
/* * 查询所有记录,分装为List*/ public List getAll() { List list = new ArrayList (); // 1、得到连接 SQLiteDatabase database = dbHelper.getReadableDatabase(); // 2、执行query select * from black_number Cursor cursor = database.query("black_number", null, null, null, null, null, "_id desc"); while (cursor.moveToNext()) { // id int id = cursor.getInt(0); // number String number = cursor.getString(1); list.add(new BlackNumber(id, number)); } // 从cursor当中取出所有数据,并封装到List当中 cursor.close(); // 3、关闭 database.close(); return list; }
(7)删除
1、显示ContextMenu
2、响应item的选择 1)删除数据表当中对应的数据 2)删除List当中的对应的数据 3)通知更新列表 给listView设置创建contextMenu的监听lv_main.setOnCreateContextMenuListener(this);
完善MainActivity当中的onCreateContextMenu方法和onContextItemSelected
//触发长按按钮 @Override public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { super.onCreateContextMenu(menu, v, menuInfo); //在长按弹出的菜单当中添加2个item menu.add(0,1,0,"更新"); menu.add(0,2,0,"删除"); //得到长按的position AdapterContextMenuInfo info = (AdapterContextMenuInfo) menuInfo;//得到所有的列表 position = info.position;//得到当前点击的列表下标 } @Override public boolean onContextItemSelected(MenuItem item) { //得到对应的BlackNumber对象 final BlackNumber blackNumber = data.get(position);//通过下标得到对应的BlackNumber对象 switch (item.getItemId()) { case 1://更新 break; case 2://删除 //1)删除数据表当中对应的数据 AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle("警告"); builder.setMessage("是否确认删除:"+blackNumber.getNumber()); builder.setPositiveButton("确定", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { dao.deleteById(blackNumber.getId());//删除数据库当中的数据 //2)删除List当中的对应的数据 data.remove(position);//删除列表当中对应的数据,需要得到长按的position? //3)通知更新列表 adapter.notifyDataSetChanged(); } }); builder.setNegativeButton("取消", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { } }); //一样要show builder.show(); break; default: break; } return super.onContextItemSelected(item); }
测试
(8)更新
1、显示更新的Dialog
2、点击确定的响应 1)更新数据表对应的数据 2)更新List表当中的数据 3)通知更新列表/* * 1、显示更新的Dialog */ private void showUpdateDialog(final BlackNumber blackNumber) { final EditText editText = new EditText(this); editText.setHint(blackNumber.getNumber()); new AlertDialog.Builder(this)//在当前页面建立AlertDialog(弹出框) .setTitle("更新黑名单") .setView(editText) .setPositiveButton("更新", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //1)更新List表当中的数据 String newNumber = editText.getText().toString(); blackNumber.setNumber(newNumber); //2)更新数据表对应的数据 dao.update(blackNumber); //3)通知更新列表 adapter.notifyDataSetChanged(); } } ) .setNegativeButton("取消", null) .show(); }
测试
3、功能实现的主要工作
1、内存的操作(集合)
2、存储的操作(sp/数据库/文件) 3、界面的操作(列表)三、使用ListActivity的优化功能
拆卸重新安装对应的应用后,其中的表对应订单数据都消失了
启动应用后显示空白 需要在屏幕中间设置对应的提示文字使用ListActivity优化功能
1)extends ListActivity
并修改获取ListView的方式
lv_main = (ListView)getListView();
2) 布局文件当中的<ListView>
的id必须是系统定义的id:list
3)如果想在没有数据的时候,显示一个提示文本,可以在布局当中定义一个<TextView>
(id必须为empty)
测试
转载地址:https://code100.blog.csdn.net/article/details/113775387 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2024年04月05日 12时59分37秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
常规邮件基础
2019-04-29
邮件基础之 -- SMTP协议
2019-04-29
Java设计模式--责任链模式
2019-04-29
OpenCV的cvLoadImage函数
2019-04-29
OpenCV中与matlab中相对应的函数
2019-04-29
C/C++中二维数组作函数形参时,调用函数时,可传递的实参类型的小结
2019-04-29
cvGetSubRect与cvMul用法
2019-04-29
opencv图像处理梯度边缘和角点
2019-04-29
Caffe源码中blob文件分析
2019-04-29
OpenCV 图像采样 插值 几何变换
2019-04-29
图像处理-仿射变换 AffineTransform
2019-04-29
图像二值化----otsu(最大类间方差法、大津算法)
2019-04-29
图像二值化----otsu(最大类间方差法、大津算法)(二)
2019-04-29
OpenCV编程案例:使用轮廓函数检测连通区域
2019-04-29
opencv使用cvFindContours提取联通域
2019-04-29
C++中MessageBox的常见用法
2019-04-29
ordfilt2函数功能说明
2019-04-29
在图像变换中用最小二乘法求解仿射变换参数
2019-04-29
软件包应用分享|基于RT-Thread的百度语音识别(一)
2019-04-29
12月8日 RCEA - RT-Thread能力认证考试考前通知
2019-04-29