【Android 应用】数据库实例---包含String转时间戳、查询升序

2024-04-28 21:48

本文主要是介绍【Android 应用】数据库实例---包含String转时间戳、查询升序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写一个数据库实例,方便以后参考。

推荐一篇sql文章:https://cloud.tencent.com/developer/article/1394216


1、数据库创建类

AdCacheFileDB .java

package com.seecool.apmservice.ad;import android.content.Context;import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase;public class AdCacheFileDB extends SQLiteOpenHelper {private static final String DBFilename = "AdCacheRecord.db";public static final String CREATE_FILE_PAGE = "create table AdCacheRecord("+ "id integer primary key autoincrement,"+ "endtime integer,"+ "url varchar(64))";public AdCacheFileDB(Context context) {super(context, DBFilename, null, 1);}@Overridepublic void onCreate(SQLiteDatabase db) {//初始化数据库的表结构 d integer primary key autoincrement,db.execSQL(CREATE_FILE_PAGE);}@Overridepublic void onUpgrade(SQLiteDatabase database, int oldVersion, int newVersion) {}
}

2、数据库封装类

AdCacheFileDao.java

package com.seecool.apmservice.ad;import android.util.Log;import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;import java.util.ArrayList;
import java.util.List;public class AdCacheFileDao{private static final String TAG = "AdCacheFileDao";private AdCacheFileDB helper;public AdCacheFileDao(Context context){helper = new AdCacheFileDB(context);}public long add(long endtime,String url){SQLiteDatabase db = helper.getWritableDatabase();ContentValues values = new ContentValues();values.put("endtime",endtime);values.put("url",url);long num = db.insert("AdCacheRecord",null,values);db.close();return num;}public boolean findByUrl(String url){SQLiteDatabase db = helper.getWritableDatabase();Cursor cursor = db.rawQuery("select * from AdCacheRecord where url=?",new String[]{url});boolean result = cursor.moveToNext();cursor.close();db.close();return result;}public int update(String url,long endtime){SQLiteDatabase db = helper.getWritableDatabase();ContentValues values = new ContentValues();values.put("endtime",endtime);int num = db.update("AdCacheRecord",values,"url=?", new String[]{url});db.close();return num;}public int delete(String url){SQLiteDatabase db = helper.getWritableDatabase();int num = db.delete("AdCacheRecord","url=?",new String[]{url});db.close();return num;}/*** 找出所有信息* */public List<CacheFileInfo> findAll(){SQLiteDatabase db = helper.getWritableDatabase();List<CacheFileInfo> list = new ArrayList<CacheFileInfo>();Cursor cursor = db.query("AdCacheRecord",null,null,null,null,null,null);while(cursor.moveToNext()){int id = cursor.getInt(cursor.getColumnIndex("id"));long endtime = cursor.getLong(cursor.getColumnIndex("endtime"));String url = cursor.getString(cursor.getColumnIndex("url"));CacheFileInfo fileInfo = new CacheFileInfo(id,endtime,url);list.add(fileInfo);}cursor.close();db.close();return list;}/*** 按时间的排序找出所有信息* */public List<CacheFileInfo> findAllForEndtimeSort(){SQLiteDatabase db = helper.getWritableDatabase();List<CacheFileInfo> list = new ArrayList<CacheFileInfo>();Cursor cursor = db.query("AdCacheRecord",null,null,null,null,null,"endtime asc");while(cursor.moveToNext()){int id = cursor.getInt(cursor.getColumnIndex("id"));long endtime = cursor.getLong(cursor.getColumnIndex("endtime"));String url = cursor.getString(cursor.getColumnIndex("url"));CacheFileInfo fileInfo = new CacheFileInfo(id,endtime,url);list.add(fileInfo);}cursor.close();db.close();return list;}public CacheFileInfo findById(int id){SQLiteDatabase db = helper.getWritableDatabase();Cursor cursor = db.query("AdCacheRecord",null,"id=?",new String[]{id+""},null,null,null);CacheFileInfo user = new CacheFileInfo();while(cursor.moveToNext()){int uid = cursor.getInt(cursor.getColumnIndex("id"));long endtime = cursor.getInt(cursor.getColumnIndex("endtime"));String url = cursor.getString(cursor.getColumnIndex("url"));user.setId(uid);user.setEndtime(endtime);user.setUrl(url);break;}cursor.close();db.close();return user;}public static class CacheFileInfo {private int id;private long endtime;private String url;public CacheFileInfo(){ }public CacheFileInfo(int id, long endtime, String url) {this.id = id;this.endtime = endtime;this.url = url;}public int getId() {return id;}public void setId(int id) {this.id = id;}public long getEndtime() {return endtime;}public void setEndtime(long endtime) {this.endtime = endtime;}public String getUrl() {return url;}public void setUrl(String url) {this.url = url;}}
}

3、数据库使用类

AdCacheFileManager.java

package com.seecool.apmservice.ad;import android.util.Log;import android.content.Context;
import java.util.List;
import java.util.Date;
import java.text.SimpleDateFormat;import java.io.File;
import android.content.Context;
import com.seecool.apmservice.APMApplication;public class AdCacheFileManager{private static final String TAG = "AdCacheFileManager";private static AdCacheFileManager mAdCacheFileManager = null;private static AdCacheFileDao mAdCacheFileDao = null;private static Context mContext = null;private static final String DISK_CACHE_PATH = "/web_image_cache/";public static synchronized AdCacheFileManager getInstance(){if(mAdCacheFileManager == null){mAdCacheFileManager = new AdCacheFileManager();}return mAdCacheFileManager;}private AdCacheFileManager(){mContext = APMApplication.getAppContext();mAdCacheFileDao = new AdCacheFileDao(mContext);}public long addOrUpdate(String endtime, String url){if(mAdCacheFileDao == null){mAdCacheFileDao = new AdCacheFileDao(mContext);}SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMddHHmmss");Date date = null;try {date = simpleDateFormat.parse(endtime);Log.d(TAG, "Endtime :"+ date.getTime() + " url: " + url);if(mAdCacheFileDao.findByUrl(url)){return mAdCacheFileDao.update(url, date.getTime());}return mAdCacheFileDao.add(date.getTime(), url);} catch (Exception e) {e.printStackTrace();return -1;}}private String getFilePath() {String diskCachePath;Context appContext = APMApplication.getAppContext();diskCachePath = appContext.getCacheDir().getAbsolutePath() + DISK_CACHE_PATH;return diskCachePath;}public void clean(){///:TODO 时间如何保证对了long nowtime = (new Date()).getTime();if(mAdCacheFileDao == null){mAdCacheFileDao = new AdCacheFileDao(mContext);}List<AdCacheFileDao.CacheFileInfo> fileinfo = mAdCacheFileDao.findAll();for(int i = 0;i<= fileinfo.size();i++){AdCacheFileDao.CacheFileInfo info = new AdCacheFileDao.CacheFileInfo();if(info.getEndtime() > nowtime){continue;}mAdCacheFileDao.delete(info.getUrl());//String url = "http://192.168.15.165/rem/material/bg71QRktM9in/2020/07/03/UEsHxIMYsym8.jpg";remove(info.getUrl());//WebImage.removeFromCache(url);}return;}private String getCacheKey(String url) {if(url == null){throw new RuntimeException("Null url passed in");} else {return url.replaceAll("[.:/,%?&=]", "+").replaceAll("[+]+", "+");}}public void remove(String url) {if(url == null){return;}// Remove from file cacheFile f = new File(getFilePath(), getCacheKey(url));if(f.exists() && f.isFile()) {f.delete();}}
}

结果

 

这篇关于【Android 应用】数据库实例---包含String转时间戳、查询升序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/944340

相关文章

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

浅谈mysql的sql_mode可能会限制你的查询

《浅谈mysql的sql_mode可能会限制你的查询》本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数groupby的规则... 目录场景:问题描述原因分析:解决方案:第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;

MySQL多列IN查询的实现

《MySQL多列IN查询的实现》多列IN查询是一种强大的筛选工具,它允许通过多字段组合快速过滤数据,本文主要介绍了MySQL多列IN查询的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析与优化1.