1、实体

package mydemo.mycom.demo2.entity;

public class UserInfo {
private int id;
private String username;
private String password; public UserInfo()
{ } public UserInfo(int id, String username, String password) {
this.id = id;
this.username = username;
this.password = password;
} public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
}
}

2.UserSQLiteOpenHelper

package mydemo.mycom.demo2.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper; public class UserSQLiteOpenHelper extends SQLiteOpenHelper { /**
* 数据库的构造方法 用来定义数据库的名称 数据库查询的结果集 数据库的版本
* **/ public UserSQLiteOpenHelper(Context context) {
super(context, "user.db", null, 1);
}
/**
* 数据库第一次被创建的时候调用的方法
* db被创建的数据库
* **/
@Override
public void onCreate(SQLiteDatabase db) {
//初始化数据库的表结构 d integer primary key autoincrement,
db.execSQL("create table user (id integer primary key autoincrement,username varchar(20),password varchar(20))");
}
/**
* 当数据库的版本号发生变化的时候(增加的时候) 调用
* */
@Override
public void onUpgrade(SQLiteDatabase db, int i, int i2) { db.execSQL("alter table user add account varchar(20)");
}
}

3.JDBC的UserDAO

package mydemo.mycom.demo2.dao;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase; import java.util.ArrayList;
import java.util.List; import mydemo.mycom.demo2.db.UserSQLiteOpenHelper;
import mydemo.mycom.demo2.entity.UserInfo; public class UserDao { private UserSQLiteOpenHelper helper; public UserDao(Context context)
{
helper = new UserSQLiteOpenHelper(context);
} /**
* 添加一条记录到数据库
* username 用户名
* password 密码
*
* */
public void add(String username,String password)
{
SQLiteDatabase db = helper.getWritableDatabase();
db.execSQL("insert into user(username,password) values(?,?)",new String[]{username,password});
db.close(); } /**
* 判断数据库是否存在username 的数据
*
* username 用户名
* */
public boolean findByUsername(String username)
{
SQLiteDatabase db = helper.getWritableDatabase();
Cursor cursor = db.rawQuery("select * from user where username=?",new String[]{username});
boolean result = cursor.moveToNext();
db.close();
return result;
} /**
* 修改一条记录
* 通过username 修改 password
*
* username 用户名
* password 密码
*
* */
public void update(String username,String password)
{
SQLiteDatabase db = helper.getWritableDatabase();
db.execSQL("update user set password=? where username=?",new String[]{password,username});
db.close(); } /**
* 删除记录
* 通过username修改一条记录
*
* username 用户名
* */
public void delete(String username)
{
SQLiteDatabase db = helper.getWritableDatabase();
db.execSQL("delete from user where username=?",new String[]{username});
db.close();
} /**
* 找出所有用户信息
* */
public List<UserInfo> findAll()
{
SQLiteDatabase db = helper.getWritableDatabase();
List<UserInfo> list = new ArrayList<UserInfo>();
Cursor cursor = db.rawQuery("select * from user",null);
while(cursor.moveToNext())
{
int id = cursor.getInt(cursor.getColumnIndex("id"));
String username = cursor.getString(cursor.getColumnIndex("username"));
String password = cursor.getString(cursor.getColumnIndex("password")); UserInfo userInfo = new UserInfo(id,username,password);
list.add(userInfo);
}
cursor.close();
db.close();
return list;
} /**
* 通过id 用户信息
* id 用户id
* */
public UserInfo findById(int id)
{
SQLiteDatabase db = helper.getWritableDatabase();
Cursor cursor =db.rawQuery("select * from user where id=?",new String[]{id+""}); UserInfo user = new UserInfo(); while(cursor.moveToNext())
{
int uid = cursor.getInt(cursor.getColumnIndex("id"));
String username = cursor.getString(cursor.getColumnIndex("username"));
String password = cursor.getString(cursor.getColumnIndex("password")); user.setId(uid);
user.setPassword(password);
user.setUsername(username); break;
}
cursor.close();
db.close();
return user; } }

4.SQLiteOpenHelper的 UserDAO

package mydemo.mycom.demo2.dao;

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; import mydemo.mycom.demo2.db.UserSQLiteOpenHelper;
import mydemo.mycom.demo2.entity.UserInfo; /**
* Created by Administrator on 2015/5/15.
*/
public class UserDao2 { private UserSQLiteOpenHelper helper; public UserDao2(Context context)
{
helper = new UserSQLiteOpenHelper(context);
} /**
* 添加一条记录到数据库
* username 用户名
* password 密码
*
* */
public long add(String username,String password)
{
SQLiteDatabase db = helper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("username",username);
values.put("password",password); long num = db.insert("user",null,values); db.close(); return num;
} /**
* 判断数据库是否存在username 的数据
*
* username 用户名
* */
public boolean findByUsername(String username)
{
SQLiteDatabase db = helper.getWritableDatabase();
Cursor cursor = db.query("user",null,"username=?",new String[]{username},null,null,null);
boolean result = cursor.moveToNext();
db.close();
return result;
} /**
* 修改一条记录
* 通过username 修改 password
*
* username 用户名
* password 密码
*
* */
public int update(String username,String password)
{
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("password",password);
int num = db.update("user",values,"username=?", new String[]{username});
db.close();
return num;
} /**
* 删除记录
* 通过username修改一条记录
*
* username 用户名
* */
public int delete(String username)
{
SQLiteDatabase db = helper.getWritableDatabase();
int num = db.delete("user","username=?",new String[]{username});
db.close();
return num;
} /**
* 找出所有用户信息
* */
public List<UserInfo> findAll()
{
SQLiteDatabase db = helper.getWritableDatabase();
List<UserInfo> list = new ArrayList<UserInfo>();
Cursor cursor = db.query("user",null,null,null,null,null,null);
while(cursor.moveToNext())
{
int id = cursor.getInt(cursor.getColumnIndex("id"));
String username = cursor.getString(cursor.getColumnIndex("username"));
String password = cursor.getString(cursor.getColumnIndex("password")); UserInfo userInfo = new UserInfo(id,username,password);
list.add(userInfo);
}
cursor.close();
db.close();
return list;
} /**
* 通过id 用户信息
* id 用户id
* */
public UserInfo findById(int id)
{
SQLiteDatabase db = helper.getWritableDatabase();
Cursor cursor = db.query("user",null,"id=?",new String[]{id+""},null,null,null); UserInfo user = new UserInfo(); while(cursor.moveToNext())
{
int uid = cursor.getInt(cursor.getColumnIndex("id"));
String username = cursor.getString(cursor.getColumnIndex("username"));
String password = cursor.getString(cursor.getColumnIndex("password")); user.setId(uid);
user.setPassword(password);
user.setUsername(username); break;
}
cursor.close();
db.close();
return user; }
}

5.SQLiteOpenHelper 简单使用

package mydemo.mycom.demo2;

import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast; import mydemo.mycom.demo2.dao.UserDao;
import mydemo.mycom.demo2.dao.UserDao2; public class Register extends ActionBarActivity implements View.OnClickListener { private EditText et_register_username;
private EditText et_register_password;
private Button btn_register; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register); et_register_username = (EditText)findViewById(R.id.et_register_username);
et_register_password = (EditText)findViewById(R.id.et_register_password);
btn_register = (Button)findViewById(R.id.btn_register);
btn_register.setOnClickListener(this); } @Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_register, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
} @Override
public void onClick(View view) { String username = et_register_username.getText().toString().trim();
String password = et_register_password.getText().toString().trim();
if(TextUtils.isEmpty(username) || TextUtils.isEmpty(password))
{
Toast.makeText(this,"用户名和密码不能为空",Toast.LENGTH_SHORT).show();
return;
}
UserDao2 userDao = new UserDao2(this);
userDao.add(username,password);
Toast.makeText(this,"注册成功",Toast.LENGTH_SHORT).show(); }
}

6.SQLiteOpenHelper事务管理

package mydemo.mycom.demo2.testUserDao;

import android.database.sqlite.SQLiteDatabase;
import android.test.AndroidTestCase; import mydemo.mycom.demo2.db.UserSQLiteOpenHelper; public class TestUserInfo extends AndroidTestCase{
private String s;
public void testTransaction() throws Exception
{
UserSQLiteOpenHelper helper = new UserSQLiteOpenHelper(getContext());
SQLiteDatabase db = helper.getWritableDatabase();
//开始数据库的事务
db.beginTransaction();
try{
db.execSQL("update user set account=account-1000 where id=1");
//空指针异常
s.equals("123");
db.execSQL("update user set account=account+1000 where id=2");
//提交事务
db.setTransactionSuccessful();
}
catch(Exception ex)
{
}
finally
{
//结束事务
db.endTransaction();
db.close();
}
} }

android SQLiteOpenHelper 使用的更多相关文章

  1. Android SQLiteOpenHelper(二)

    上一篇我们已经了解了SQLiteOpenHelper 和 构造函数. 现在我们就来掌握一下:onCreate( )  onUpgrade( )  onDowngrade( ) public void ...

  2. Android SQLiteOpenHelper(一)

    SQLiteOpenHelper api解释: A helper class to manage database creation and version management. You creat ...

  3. Android SQLiteOpenHelper类的使用

    SQLiteOpenHelper类是Android平台提供的用于SQLite数据库的创建.打开以及版本管理的帮助类.一般需要继承并这个类并实现它的onCreate和onUpgrade方法,在构造方法中 ...

  4. android SQLiteOpenHelper使用示例

    我们大家都知道Android平台提供给我们一个数据库辅助类来创建或打开数据库,这个辅助类继承自SQLiteOpenHelper类,在该类的 构造器中,调用Context中的方法创建并打开一个指定名称的 ...

  5. Android SQLiteOpenHelper Sqlite数据库升级onUpgrade

    Android Sqlite数据库升级,在Android APP开发之中,非常常见: 在确定原来的数据库版本号之后,在原来数据库版本号+1,就会执行onUpgrade方法,进行数据库升级操作: 在on ...

  6. Android SQLiteOpenHelper Sqlite数据库的创建与打开

    Android Sqlite数据库是一个怎样的数据库? 答:是一种嵌入式小型设备,移动设备,的数据库,应用在穿戴设备(例如:智能手表,计算手环 等等),移动设备(例如:Android系统类型的手机 等 ...

  7. Android SqliteOpenHelper详解

    一. SQLite介绍 SQLite是android内置的一个很小的关系型数据库. SQLite的官网是http://www.sqlite.org/,可以去下载一些文档或相关信息. 博客中有一篇有稍微 ...

  8. Android · SQLiteOpenHelper实例PrivateContactsDBHelper

    package privatecontact; import android.content.ContentValues; import android.content.Context; import ...

  9. 升级后开机就提示“android.process.acore”停止执行 --分析 解决方式

    OTA升级的,升级引发的全部问题都是能够解释的,有的能解决,有的不能解决. 一个项目报了这个问题. 升级后开机就提示"android.process.acore"停止执行 抓取 a ...

随机推荐

  1. js對象

    js聲明一個數據,即使沒有賦值,也是創建了一個對象: js的所有數據都是對象,對象裡面有屬性也有方法,屬性方法是對象中的成員: 訪問對象的屬性:objectname.屬性名 訪問對象的方法:objec ...

  2. ThinkPHP 框架出现安全隐患 ,导致网站被持续攻击一周

    导读 据 ZDNET 报道,有超过 45000 个中国网站由于使用 ThinkPHP 框架受到了攻击. 这些攻击针对的是使用 ThinkPHP 构建的网站,ThinkPHP 是一个中国的 PHP 框架 ...

  3. GO系列教程

    1.介绍与安装 2.Hello World 3.变量 4. 类型 5.常量 6.函数(Function) 7.包 8.if-else 语句 9.循环 10.switch语句 11.数组和切片 12.可 ...

  4. Redundant Paths POJ - 3177(边—双连通分量)

    题意: 在图中加边 看最少能通过加多少条边把 图变成边—双连通分量 解析: 先做一次dfs,不同的连通分量的low是不同的  注意重边 缩点 统计度为1的点  那么需要加的边为(ret+1)/2 #i ...

  5. 【转】安全加密(三):RFID标签防伪为生活开启安全模式

    本文导读 随着RFID技术的快速发展和RFID电子标签的生产成本不断降低,RFID标签防伪技术的应用也得到了极大的普及,逐步出现在各行各业当中,如交通出行.票务安全.商品防伪等领域. RFID技术简介 ...

  6. 洛谷 P1462 通往奥格瑞玛的道路 解题报告

    P1462 通往奥格瑞玛的道路 题目背景 在艾泽拉斯大陆上有一位名叫歪嘴哦的神奇术士,他是部落的中坚力量 有一天他醒来后发现自己居然到了联盟的主城暴风城 在被众多联盟的士兵攻击后,他决定逃回自己的家乡 ...

  7. SP1805 HISTOGRA (单调栈)

    单调栈维护栈顶为高度最大的 记下来栈中每个元素入栈时顶掉的最靠左的一个位置(如果没顶掉就是它本身),那么在它出栈的时候,它所带来的面积就是(出栈位置-记录位置)*高度 (可能会有加一减一之类的细节) ...

  8. luogu3320 寻宝游戏 (dfs序+倍增lca+set)

    一定是从随便某个点开始,然后按着dfs序的顺序跑一圈是最好的 所以说,新加一个点x,就减少了dis(pre,next),增加了dis(pre,x),dis(x,nxt) 删掉一个点同理 这个可以用se ...

  9. C++ 容器:顺序性容器、关联式容器和容器适配器

    什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...

  10. 拆分string 用空格 逗号

    string that have both comma and space struct tokens: std::ctype<char>{ tokens(): std::ctype< ...