数据库访问完毕后,游标必须也记得关闭

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数据库的更多相关文章

  1. Qt for Android 打包 SQLite 数据库

    Qt for Android 调用 SQLite 数据库时, 怎样将已经存在的数据库附加到 APK 中? 直接在你项目里面的Android源码的根目录下新建一个文件夹assets, 数据库就可以放里面 ...

  2. Android实现SQLite数据库联系人列表

    Android实现SQLite数据库联系人列表 开发工具:Andorid Studio 1.3 运行环境:Android 4.4 KitKat 工程内容 实现一个通讯录查看程序: 要求使用SQLite ...

  3. Android中SQLite数据库操作(1)——使用SQL语句操作SQLite数据库

    下面是最原始的方法,用SQL语句操作数据库.后面的"Android中SQLite数据库操作(2)--SQLiteOpenHelper类"将介绍一种常用的android封装操作SQL ...

  4. android中sqlite数据库的基本使用和添加多张表

    看了很多关于android使用sqlite数据库的文章,很多都是介绍了数据库的建立和表的建立,而表通常都是只建立一张,而实际情况我们用到的表可能不止一张,那这种情况下我们又该怎么办呢,好了,下面我教大 ...

  5. android 一个SQLite数据库多个数据表的基本使用框架 (带demo)

    android 一个SQLite数据库多个数据表(带demo) 前言        demo演示        一.搭建        二.建立实体类        三.建立数据库操作类        ...

  6. Android之SQLite数据库篇

    一.SQLite简介 Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大. 二.SQLite的特点 1.轻量级使用 SQLit ...

  7. Android之SQLite数据库使用

    转载整理于:http://my.csdn.net/lmj623565791 我刚开始接触Android的时候甚至都不敢相信,Android系统竟然是内置了数据库的!好吧,是我太孤陋寡闻了.由于我之前是 ...

  8. android安卓Sqlite数据库实现用户登录注册

    看了很多别人写的安卓SQlite数据的操作代码,一点也不通俗易懂,我觉得我写的不错,而且安卓项目也用上了,所以在博客园里保存分享一下!建立一个类 并继承SQLiteOpenHelper public ...

  9. Android中SQLite数据库小计

    2016-03-16 Android数据库支持 本文节选并翻译<Enterprise Android - Programing Android Database Applications for ...

  10. android 对sqlite数据库的增删改查等各种操作

    转载:http://blog.csdn.net/vrix/article/details/6717090 package com.sqlite.main; import java.io.File; i ...

随机推荐

  1. 如何用html把文本框外观格式设为只显示底部的横线

    html把文本框外观格式设为只显示底部的横线 <style> input[type='text']{background:none;border:none;border-bottom:1p ...

  2. MyBatis基础入门《十七》动态SQL

    MyBatis基础入门<十七>动态SQL 描述: >> 完成多条件查询等逻辑实现 >> 用于实现动态SQL的元素主要有: > if > trim > ...

  3. MySQL.Linux.安装

    Linux 7.x.安装 MySQL 环境: linux是安装在虚拟机中的,宿主机是:win10系统.安装MySQL的时候,首先需要网络是通的(宿主机和虚拟机之间通信).相关配置,参见:虚拟机和宿主机 ...

  4. hive中安装hive_utils模块

    1. 因为在linux部署的python 3.6 在安装模块的时候遇到了许多问题,所以使用linux中的python3.6环境 2. 首先使用pip安装 hive_utils 模块sudo pip i ...

  5. linux文本文件编辑命令

    1.cat命令 cat命令用于查看纯文本文件(内容较少的),格式为“cat [选项] [文件]”. Linux系统中有多个用于查看文本内容的命令,每个命令都有自己的特点,比如这个cat命令就是用于查看 ...

  6. linux常用命令:rm 命令

    昨天学习了创建文件和目录的命令mkdir ,今天学习一下linux中删除文件和目录的命令: rm命令.rm是常用的命令,该命令的功能为删除一个目录中的一个或多个文件或目录,它也可以将某个目录及其下的所 ...

  7. AWS免费云服务套餐申请步骤及常见问题

    AWS免费云服务套餐申请步骤及常见问题 AWS免费使用套餐常见问题_AWS免费云服务套餐_-AWS云服务https://amazonaws-china.com/cn/free/faqs/ 什么是 AW ...

  8. PNG文件格式详解

    源文件地址:https://blog.mythsman.com/2015/12/08/1/ 最近在看隐写术的时候经常需要研究图片文件的二进制文档格式,那么这就很有必要了解我们的图片文件究竟是如何保存的 ...

  9. いっしょ / Be Together (暴力枚举)

    题目链接:http://abc043.contest.atcoder.jp/tasks/arc059_a Time limit : 2sec / Memory limit : 256MB Score ...

  10. Django框架---- 自定义分页组件

    分页的实现与使用 class Pagination(object): """ 自定义分页 """ def __init__(self,cur ...