Android之Sqlite数据库
数据库访问完毕后,游标必须也记得关闭
import com.huangzhong.love_power_model.UserInfoDto;
import java.util.ArrayList;
import java.util.List;
import android.app.AlertDialog;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log; public class UserInfoDao{ private static final int MODE_PRIVATE = 0x0;
private static final String DATABASE = "lovepower";
private static SQLiteDatabase db; public static void insert(Context context,UserInfoDto model) {
//Id,UserName,Birthday,PhoneNumber,QQ,Address,CreateDate
Cursor cursor;
int count = ;
try {
db = context.openOrCreateDatabase(DATABASE, MODE_PRIVATE, null);
//db.execSQL("drop table UserInfo ;");
String sqlCheckExsit = "select count(*) as c from Sqlite_master where type ='table' and name ='UserInfo' ";
cursor = db.rawQuery(sqlCheckExsit, null); if(cursor.moveToNext()){
count = cursor.getInt();
if(count <= ){
db.execSQL("Create table UserInfo (Id text not null,UserName text,Birthday text,PhoneNumber text,QQ text,Address text,CreateDate text);");
Log.e("insertSql", "");
}
}
String insertSql = "insert into UserInfo (Id,UserName,Birthday,PhoneNumber,QQ,Address,CreateDate) " +
"values('" + model.getId() + "', '"
+ model.getUserName()+"','"
+ model.getBirthday()+"','"
+ model.getPhoneNumber()+"','"
+ model.getQQ()+"','"
+ model.getAddress()+"','"
+ model.getCreateDate() + "');";
db.execSQL(insertSql);
cursor.close();
Log.e("insertSql", "ok");
}
finally { db.close();
}
} /**
* 查询
* @param context 上下文
* @param sql SQl查询语句
* @param fields 字段名集合
* @return 查询结果集 List<String>类型
*/
public static List<UserInfoDto> query(Context context, String sql) {
Log.e("UserInfoDto", "取数据");
List<UserInfoDto> dataList = new ArrayList<UserInfoDto>();
Cursor cursor;//Id,UserName,Birthday,PhoneNumber,QQ,Address,CreateDate
try {
db = context.openOrCreateDatabase(DATABASE, MODE_PRIVATE, null);
cursor = db.rawQuery(sql, null);
if (cursor != null) {
while (cursor.moveToNext()) {
UserInfoDto model =new UserInfoDto();
model.setId(cursor.getString(cursor.getColumnIndex("Id")));
model.setUserName(cursor.getString(cursor.getColumnIndex("UserName")));
model.setBirthday(cursor.getString(cursor.getColumnIndex("Birthday")));
model.setPhoneNumber(cursor.getString(cursor.getColumnIndex("PhoneNumber")));
model.setQQ(cursor.getString(cursor.getColumnIndex("QQ")));
model.setAddress(cursor.getString(cursor.getColumnIndex("Address")));
model.setCreateDate(cursor.getString(cursor.getColumnIndex("CreateDate")));
dataList.add(model);
}
cursor.close();//游标必须关闭
}
}catch(Exception e) {
new AlertDialog.Builder(context).setIcon(android.R.drawable.ic_dialog_alert).setTitle("数据库连接错误:")
.setMessage("数据访问异常。").show();
} finally {
db.close();
}
return dataList;
} /**
* 数据记录总条数
* @param context 上下文
* @param sql SQL查询语句
* @return 记录条数
*/
public static int getCount(Context context, String sql) { int totalCounty = ;
try {
db = context.openOrCreateDatabase(DATABASE, MODE_PRIVATE, null);
Cursor cursor = db.rawQuery(sql, null);
cursor.moveToFirst();
totalCounty = cursor.getInt();
cursor.close();//游标必须关闭
} catch (Exception e) {
new AlertDialog.Builder(context)
.setIcon(android.R.drawable.ic_dialog_alert)
.setTitle("数据库连接错误:").setMessage("数据访问异常。").show();
} finally {
db.close();
}
return totalCounty;
}
}
数据访问层
public class UserInfoDto {
//Id,UserName,Birthday,PhoneNumber,QQ,Address,CreateDate
private String Id;
private String UserName;
private String Birthday;
private String PhoneNumber;
private String QQ;
private String Address;
private String CreateDate;
public String getId() {
return Id;
}
public void setId(String id) {
Id = id;
}
public String getUserName() {
return UserName;
}
public void setUserName(String userName) {
UserName = userName;
}
public String getBirthday() {
return Birthday;
}
public void setBirthday(String birthday) {
Birthday = birthday;
}
public String getPhoneNumber() {
return PhoneNumber;
}
public void setPhoneNumber(String phoneNumber) {
PhoneNumber = phoneNumber;
}
public String getQQ() {
return QQ;
}
public void setQQ(String qQ) {
QQ = qQ;
}
public String getAddress() {
return Address;
}
public void setAddress(String address) {
Address = address;
}
public String getCreateDate() {
return CreateDate;
}
public void setCreateDate(String createDate) {
CreateDate = createDate;
}
}
实体层
Android之Sqlite数据库的更多相关文章
- Qt for Android 打包 SQLite 数据库
Qt for Android 调用 SQLite 数据库时, 怎样将已经存在的数据库附加到 APK 中? 直接在你项目里面的Android源码的根目录下新建一个文件夹assets, 数据库就可以放里面 ...
- Android实现SQLite数据库联系人列表
Android实现SQLite数据库联系人列表 开发工具:Andorid Studio 1.3 运行环境:Android 4.4 KitKat 工程内容 实现一个通讯录查看程序: 要求使用SQLite ...
- Android中SQLite数据库操作(1)——使用SQL语句操作SQLite数据库
下面是最原始的方法,用SQL语句操作数据库.后面的"Android中SQLite数据库操作(2)--SQLiteOpenHelper类"将介绍一种常用的android封装操作SQL ...
- android中sqlite数据库的基本使用和添加多张表
看了很多关于android使用sqlite数据库的文章,很多都是介绍了数据库的建立和表的建立,而表通常都是只建立一张,而实际情况我们用到的表可能不止一张,那这种情况下我们又该怎么办呢,好了,下面我教大 ...
- android 一个SQLite数据库多个数据表的基本使用框架 (带demo)
android 一个SQLite数据库多个数据表(带demo) 前言 demo演示 一.搭建 二.建立实体类 三.建立数据库操作类 ...
- Android之SQLite数据库篇
一.SQLite简介 Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大. 二.SQLite的特点 1.轻量级使用 SQLit ...
- Android之SQLite数据库使用
转载整理于:http://my.csdn.net/lmj623565791 我刚开始接触Android的时候甚至都不敢相信,Android系统竟然是内置了数据库的!好吧,是我太孤陋寡闻了.由于我之前是 ...
- android安卓Sqlite数据库实现用户登录注册
看了很多别人写的安卓SQlite数据的操作代码,一点也不通俗易懂,我觉得我写的不错,而且安卓项目也用上了,所以在博客园里保存分享一下!建立一个类 并继承SQLiteOpenHelper public ...
- Android中SQLite数据库小计
2016-03-16 Android数据库支持 本文节选并翻译<Enterprise Android - Programing Android Database Applications for ...
- android 对sqlite数据库的增删改查等各种操作
转载:http://blog.csdn.net/vrix/article/details/6717090 package com.sqlite.main; import java.io.File; i ...
随机推荐
- vue2.0--请求数据
vue中用vue-reouse请求来的数据,会被封装一层,如下图res:
- DES加解密 cbc模式 的简单讲解 && C++用openssl库来实现的注意事项
DES cbc是基于数据块加密的.数据块的长度为8字节64bit.以数据块为单位循环加密,再拼接.每个数据块加密的秘钥一样,IV向量不同.第一个数据快所需的IV向量,需要我们提供,从第二个数据块开始, ...
- C#学习入门第一篇
1. using System; using System.Collections.Generic; using System.Ling; using System.Text; using Syste ...
- LeetCode155.最小栈
设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈. push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. top() -- 获取栈顶元素. ...
- java outterLoop跳出多重循环用法以及详解
List<CommResultMsg> listresult=new ArrayList<CommResultMsg>(); outterLoop :for (int i = ...
- Unity shader学习之屏幕后期处理效果之运动模糊
运动模糊,代码如下: using UnityEngine; public class MotionBlurRenderer : PostEffectRenderer { [Range(0.1f, 0. ...
- mvc未登录跳转到登录界面
编写一个mvc控制器基类BaseController , 其继承自controller 重写其OnActionExecuting方法, 在其中检测session值,如果没有,则跳转至登录页面. 如下
- 人工智能深度学习框架MXNet实战:深度神经网络的交通标志识别训练
人工智能深度学习框架MXNet实战:深度神经网络的交通标志识别训练 MXNet 是一个轻量级.可移植.灵活的分布式深度学习框架,2017 年 1 月 23 日,该项目进入 Apache 基金会,成为 ...
- AtCoder Beginner Contest 044 C - 高橋君とカード / Tak and Cards
题目链接:http://abc044.contest.atcoder.jp/tasks/arc060_a Time limit : 2sec / Memory limit : 256MB Score ...
- python requests库的简单使用
requests是python的一个HTTP客户端库,跟urllib,urllib2类似,但比urllib,urllib2更加使用简单. 1. requests库的安装在你的终端中运行pip安装命令即 ...