详解Android数据存储—使用SQLite数据库

SQLite是Android自带的关系型数据库,是一个基于文件的轻量级数据库。Android提供了3种操作数据的方式,SharedPreference(共享首选项)、文件存储以及SQLite数据库。

SQLite数据库文件被保存在/data/data/package_name/databases目录下。

一、创建和删除表

1.创建表

创建表的SQL语句为:

CREATE TABLE userInfo_brief (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT,
password TEXT);

对应的Java代码为:

  final static int VERSION=1;
  final static String TABLENAME="userInfo_brief";
  final static String ID="id";
  final static String NAME="name";
  final static String PASSWORD="password";
  String sql="CREATE TABLE "+TABLENAME+"("+"ID"+" INTEGER PRIMARY KEY AUTOINCREMENT,"
    +NAME+" TEXT,"// Attention:注意SQL语法,每个变量后需要有空格,否则不认识。
    +PASSWORD+" TEXT,"
    +AGE+" TEXT);";
    db.execSQL(sql);

2.删除表

SQL语句为:

DROP TABLE userInfo_brief;

对应的java代码为:

String sql="DROP TABLE "+TABLENAME+";";
db.execSQL(sql);

二、操作数据库中的记录

1.插入记录

insert用法:

SQliteDatabase.insert(String table,String nullColumnHack,ContentValues values)
ContentValues values=new ContentValues();//获取ContentValues对象,类似HashMAP
      values.put(DatabaseHelper.NAME, name);//键值对形式保存数据
      values.put(DatabaseHelper.PASSWORD, pass);
      values.put(DatabaseHelper.AGE, age);
      db.insert(DatabaseHelper.TABLENAME, null, values);

2.更新记录

update使用方法:

代码如下:

SQliteDatabase.update(String table,ContentValues values,String where-Clause,String[] WhereArgs)

eg:更新表中name为bob的密码

ContentValues values=new ContentValues();
values.put(PASSWORD,"123456");//要更新的数据
db.update(TABLENAME,values,NAME+"=?",new String[]{"bob"});

3.删除记录

delete使用方法:

SQliteDatabase.delete(String table,String where-Clause,String[] WhereArgs)

eg:删除那么为bob的记录

db.delete(TABLENAME,NAME+"=?",new String[]{"bob"});

4.查询记录

1.单表查询

使用SQLiteDatabase.query(7个参数)。

2.多表查询

如果A表中存了用户名和密码,B表中存了用户名和其他具体信息,使用SQLiteQueryBuilder多表查询。
SQL语句:

代码如下:

SELECT A.name,A.password,B.age,B.sex FROM A,B WHERE A.name=B.name AND A.name=“bob”

多表查询步骤:

SQLiteQueryBuilder builder=new SQLiteQueryBuilder();//获得对象
builder.setTables(TABLENAME_A,TABLENAME_B);//设置需要查询的表,可多个
builder.appendWhere(TABLENAME_A+"."+NAME+"="TABLENAME_B+"."+NAME);//设置关联属性,表与属性间.隔开,属性以=连接
cursor=builder.query(7个属性);//7属性同单表查询

实例—通过数据库验证登录

1.数据库设计

使用了数据库帮助类,从写onCreate方法

public class DatabaseHelper extends SQLiteOpenHelper {
  final static String DATABASENAME="my_database.db";
  final static int VERSION=1;
  final static String TABLENAME="userInfo_detail";
  final static String ID="id";
  final static String NAME="name";
  final static String PASSWORD="password";
  final static String AGE="age";

  public DatabaseHelper(Context context) {
    super(context, DATABASENAME, null, VERSION);
    // TODO 自动生成的构造函数存根
  }

  @Override
  public void onCreate(SQLiteDatabase db) {
    // TODO 自动生成的方法存根
    String sql="CREATE TABLE "+TABLENAME+"("+"ID"+" INTEGER PRIMARY KEY AUTOINCREMENT,"
    +NAME+" TEXT,"
    +PASSWORD+" TEXT,"
    +AGE+" TEXT);";
    db.execSQL(sql);

  }

  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO 自动生成的方法存根

  }

}

2.登录界面

public class LoginActivity extends Activity {

  private EditText username;
  private EditText password;
  private CheckBox autoLogin;
  private SharedPreferences sharedPreferences;
  private String message;
  SQLiteDatabase db;
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
   // MyApplication.getInstance().addActivity(this); 

    sharedPreferences = this.getSharedPreferences("userInfo",Context.MODE_WORLD_READABLE); //sharedPreferences实例化,用于记住登录状态,判断是否需要自动登录

    if (sharedPreferences.getBoolean("AUTO_ISCHECK", false)) { //自动登录

      Intent intent = new Intent();
      intent.setClass(LoginActivity.this, MainActivity.class);
      intent.putExtra("NAME", sharedPreferences.getString("userName", ""));
      startActivity(intent); 

    } else {
      setContentView(R.layout.login_main);
      initView(); 

     username = (EditText) findViewById(R.id.accountEdittext);
     password = (EditText) findViewById(R.id.pwdEdittext);
     Button btn_login=(Button) findViewById(R.id.login_in);
     Button btn_register=(Button)findViewById(R.id.register);
     btn_register.setOnClickListener(new OnClickListener() {//跳转注册界面

      @Override
      public void onClick(View v) {
        // TODO 自动生成的方法存根
        Intent intent=new Intent(LoginActivity.this, RegisterActivity.class);
        startActivity(intent);
      }
    });
     btn_login.setOnClickListener(new OnClickListener() { //判断登录

       @Override
       public void onClick(View v) {
         // TODO Auto-generated method stub
        userLogin();
       }
     });
    }
  } 

  /**
   * 初始化视图控件
   */
  public void initView() {
    Log.i(TAG, "初始化视图控件"); 

    username = (EditText) findViewById(R.id.accountEdittext);
    password = (EditText) findViewById(R.id.pwdEdittext);
    autoLogin = (CheckBox) findViewById(R.id.checkBox1); 

    // 默认记住用户名
    username.setText(sharedPreferences.getString("userName", "")); 

  } 

  /**
   * 点击登录按钮时触发的方法
   */
  public void userLogin() {
    //通过帮助类获得数据库对象
    DatabaseHelper helper=new DatabaseHelper(getBaseContext());
    db=helper.getReadableDatabase();
    //得到用户输入信息
    String usernameString = username.getText().toString();
    String passwordString = password.getText().toString();
    //根据用户名查询数据库信息
    Cursor cursor=db.query(DatabaseHelper.TABLENAME, new String[]{DatabaseHelper.PASSWORD},
        DatabaseHelper.NAME+"=?", new String[]{usernameString}, null, null, null);
    //若没有查询到相关信息,不再继续操作
    if(cursor.getCount()==0)
    {
      Toast.makeText(getBaseContext(), "用户名不存在", Toast.LENGTH_SHORT).show();
      return;
    }
    //若用户名存在,则继续操作
    cursor.moveToFirst(); //指向第一条记录
    String password=cursor.getString(0);//取得密码
    //判断密码,若一样则进行跳转
    if(password.equals(passwordString)){
      if(autoLogin.isChecked()){
        Editor editor=sharedPreferences.edit();
        editor.putString("userNAME", usernameString);
        editor.putBoolean("AUTO_ISCHECK", true);
        editor.commit();
      }
      Intent intent=new Intent(LoginActivity.this, MainActivity.class);
      intent.putExtra("NAME",usernameString);
      startActivity(intent);
    }
    else
    {
//     Editor editor = sharedPreferences.edit();
//      editor.putString("userName", usernameString);
//      editor.commit();
      Toast.makeText(getBaseContext(), "密码错误", Toast.LENGTH_SHORT).show();
    }

  }
 }

3.注册界面

public class RegisterActivity extends Activity {
  String name;
  String pass;
  String age;
  SQLiteDatabase db;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    // TODO 自动生成的方法存根
    super.onCreate(savedInstanceState);
    setContentView(R.layout.register);
    final EditText et_userName=(EditText)findViewById(R.id.editText_1);
    final EditText et_password=(EditText)findViewById(R.id.editText_2);
    final EditText et_age=(EditText)findViewById(R.id.editText_3);
    Button btn_confirm=(Button)findViewById(R.id.register_confirm);
    btn_confirm.setOnClickListener(new OnClickListener() {

      @Override
      public void onClick(View v) {
        // TODO 自动生成的方法存根
        name=et_userName.getText().toString();
        pass=et_password.getText().toString();
        age=et_age.getText().toString();
        //得到数据库对象

        DatabaseHelper helper=new DatabaseHelper(getBaseContext());
        db=helper.getWritableDatabase();
        //判断用户名是否已存在
        Cursor cursor=db.query(DatabaseHelper.TABLENAME, new String[]{DatabaseHelper.NAME},
            DatabaseHelper.NAME+"=?", new String[]{name}, null, null, null);
        //若查询目标已存在
        if(cursor.getCount()>0){
          Toast.makeText(getBaseContext(), "用户名已存在", Toast.LENGTH_SHORT).show();
          return;
        }

      //若不存在,则插入数据

      ContentValues values=new ContentValues();
      values.put(DatabaseHelper.NAME, name);
      values.put(DatabaseHelper.PASSWORD, pass);
      values.put(DatabaseHelper.AGE, age);
      db.insert(DatabaseHelper.TABLENAME, null, values);
      //进行跳转
      Intent intent=new Intent(RegisterActivity.this, MainActivity.class);
      intent.putExtra("NAME", name);
      startActivity(intent);
      }
    });
  }
}

4.登录成功界面

public class MainActivity extends Activity {
  String name;
  String pass;
  String age;

   private Button logout;
   SQLiteDatabase db;
   private SharedPreferences sharedPreferences;
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
  //  MyApplication.getInstance().addActivity(this);
    setContentView(R.layout.main_activity);
    logout=(Button) findViewById(R.id.logout);
    doQuery();//进行查询
    doShow();//进行显示
    logout.setOnClickListener(new OnClickListener() {

      @Override
      public void onClick(View v) {
        // TODO 自动生成的方法存根
        removeSharedPreference();
       Intent intent=new Intent();
       intent.setClass(MainActivity.this, LoginActivity.class);
       startActivity(intent);
      }
    });
  }

  private void doQuery() {
    // TODO 自动生成的方法存根
    name=getIntent().getExtras().getString("NAME");
    DatabaseHelper helper=new DatabaseHelper(getBaseContext());
    db=helper.getReadableDatabase();
    //准备查询de属性
    String[] columns=new String[]{DatabaseHelper.PASSWORD,DatabaseHelper.AGE};
    Cursor cursor=db.query(DatabaseHelper.TABLENAME, columns, DatabaseHelper.NAME+"=?",
        new String[]{name}, null, null, null);
    cursor.moveToFirst();
    while(!cursor.isAfterLast()){//判断是否是最后一条记录
      pass=cursor.getString(0);
       age=cursor.getString(1);
      cursor.moveToNext();
    }
  }
  private void doShow() {
    // TODO 自动生成的方法存根
    TextView tv_show=(TextView)findViewById(R.id.show1);
    tv_show.setText("用户信息如下:\n"+"账户:"+name+"\n密码"+pass+"\n年龄"+age);
  }
  public void removeSharedPreference() {
    sharedPreferences = getSharedPreferences("userInfo", Context.MODE_PRIVATE);
    Editor editor = sharedPreferences.edit();
    //editor.remove("userName");
    editor.remove("AUTO_ISCHECK");
    editor.commit();// 提交修改
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android SQLite数据库彻底掌握数据存储

    SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段声明的数据类型是什么. 例如:可以在Integer类型的字段中存放字符串,或者在布尔型字段中存放浮点数,或者在字符型字段中存放日期型值. 但有一种情况例外:定义为INTEGER PRIMARY KEY的字段只能存储64位整数, 当向这种字段保存除整数以外的数据时,将会产生错误. 另外, SQLite 在解析CREATE TABLE 语句时,会忽略 CREATE TABLE 语句中跟在字段名后面的数据类型信息,如下面语句

  • Android基础教程数据存储之文件存储

    Android基础教程数据存储之文件存储 将数据存储到文件中并读取数据 1.新建FilePersistenceTest项目,并修改activity_main.xml中的代码,如下:(只加入了EditText,用于输入文本内容,不管输入什么按下back键就丢失,我们要做的是数据被回收之前,将它存储在文件中) <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="

  • Android四种数据存储的应用方式

    Android四种数据存储的应用方式 作为一个完整的应用程序,数据存储操作是必不可少的.因此,Android系统一共提供了四种数据存储方式.分别是:SharePreference.文件存储.SQLite. Content Provider.对这几种方式的不同和应用场景整理如下. 第一种: 使用SharedPreferences存储数据 适用范围:保存少量的数据,且这些数据的格式非常简单:字符串型.基本类型的值.比如应用程序的各种配置信息(如是否打开音效.是否使用震动效果.小游戏的玩家积分等),解

  • Android通过"记住密码"功能学习数据存储类SharedPreferences详解及实例

    SharedPreferences是Android中存储简单数据的一个工具类.可以想象它是一个小小的Cookie,它通过用键值对的方式把简单数据类型(boolean.int.float.long和String)存储在应用程序的私有目录下(data/data/包名/shared_prefs/)自己定义的xml文件中. 一.简介 它提供一种轻量级的数据存储方式,通过eidt()方法来修改里面的内容,通过Commit()方法来提交修改后的内容. 二.重要方法 public abstract boole

  • Android平台中实现数据存储的5种方式

    本文介绍Android中的5种数据存储方式,具体内容如下 数据存储在开发中是使用最频繁的,在这里主要介绍Android平台中实现数据存储的5种方式,分别是: 1 使用SharedPreferences存储数据 2 文件存储数据 3 SQLite数据库存储数据 4 使用ContentProvider存储数据 5 网络存储数据 下面将为大家一一详细介绍.  第一种:使用SharedPreferences存储数据 SharedPreferences是Android平台上一个轻量级的存储类,主要是保存一

  • 详解Android数据存储之Android 6.0运行时权限下文件存储的思考

    前言: 在我们做App开发的过程中基本上都会用到文件存储,所以文件存储对于我们来说是相当熟悉了,不过自从Android 6.0发布之后,基于运行时权限机制访问外置sdcard是需要动态申请权限,所以以往直接sdcard根目录上直接新建了一个xxx/cache/目录来做文件存储就会不是那么容易控制了,所以有必要重新认识一下Android文件存储的相关知识了. 背景: 有关外置sdcard的读写权限 <uses-permission android:name="android.permissi

  • 5种Android数据存储方式汇总

    本文介绍Android中的5种数据存储方式. 数据存储在开发中是使用最频繁的,在这里主要介绍Android平台中实现数据存储的5种方式,分别是: 1 使用SharedPreferences存储数据 2 文件存储数据 3 SQLite数据库存储数据 4 使用ContentProvider存储数据 5 网络存储数据 下面将为大家一一详细介绍. 第一种:使用SharedPreferences存储数据 SharedPreferences是Android平台上一个轻量级的存储类,主要是保存一些常用的配置比

  • 详解Android的网络数据存储

    一.网络保存数据介绍 可以使用网络来保存数据,在需要的时候从网络上获取数据,进而显示在App中. 用网络保存数据的方法有很多种,对于不同的网络数据采用不同的上传与获取方法. 本文利用LeanCloud来进行网络数据的存储. LeanCloud是一种简单高效的数据和文件存储服务.感兴趣的可以查看网址:https://leancloud.cn/.关于LeanCloud的数据存储使用方法可以在里面找到,本文不讲述关于LeanCloud的使用,知识借助LeanCloud平台举一个在网络上存储数据的例子.

  • 详解Android数据存储—使用SQLite数据库

    SQLite是Android自带的关系型数据库,是一个基于文件的轻量级数据库.Android提供了3种操作数据的方式,SharedPreference(共享首选项).文件存储以及SQLite数据库. SQLite数据库文件被保存在/data/data/package_name/databases目录下. 一.创建和删除表 1.创建表 创建表的SQL语句为: CREATE TABLE userInfo_brief ( id INTEGER PRIMARY KEY AUTOINCREMENT, na

  • 详解Android数据存储之SQLCipher数据库加密

    前言: 最近研究了Android Sqlite数据库以及ContentProvider程序间数据共享,我们清晰的知道Sqlite数据库默认存放位置data/data/pakage/database目录下,对于已经ROOT的手机来说的没有任何安全性可以,一旦被利用将会导致数据库数据的泄漏,所以我们该如何避免这种事情的发生呢?我们尝试这对数据库进行加密. 选择加密方案: 1.)第一种方案 我们可以对数据的数据库名,表名,列名就行md5,对存储的数据进行加密,例如进行aes加密(Android数据加密

  • 实例详解Android文件存储数据方式

    总体的来讲,数据存储方式有三种:一个是文件,一个是数据库,另一个则是网络.下面通过本文给大家介绍Android文件存储数据方式. 1.文件存储数据使用了Java中的IO操作来进行文件的保存和读取,只不过Android在Context类中封装好了输入流和输出流的获取方法. 创建的存储文件保存在/data/data/<package name>/files文件夹下. 2.操作. 保存文件内容:通过Context.openFileOutput获取输出流,参数分别为文件名和存储模式. 读取文件内容:通

  • android studio数据存储建立SQLite数据库实现增删查改

    实验目的: 分别使用sqlite3工具和Android代码的方式建立SQLite数据库.在完成建立数据库的工作后,编程实现基本的数据库操作功能,包括数据的添加.删除和更新. 实验要求: 1.创建一个学生管理的应用,基本信息包含学生姓名,班级,学号.采用数据库存储这些信息. 2.应用应该至少包含信息录入和删除功能. 3.数据显示考虑采用ListView. 实验效果: 工程结构: 源代码: DBAdapter.java package com.example.shiyan6_sqlite; impo

  • android studio数据存储建立SQLite数据库实现增删查改

    实验目的: 分别使用sqlite3工具和Android代码的方式建立SQLite数据库.在完成建立数据库的工作后,编程实现基本的数据库操作功能,包括数据的添加.删除和更新. 实验要求: 1.创建一个学生管理的应用,基本信息包含学生姓名,班级,学号.采用数据库存储这些信息. 2.应用应该至少包含信息录入和删除功能. 3.数据显示考虑采用ListView. 实验效果: 工程结构: 源代码: DBAdapter.java package com.example.shiyan6_sqlite; impo

  • Android数据持久化之SQLite数据库用法分析

    本文实例讲述了Android数据持久化之SQLite数据库用法.分享给大家供大家参考,具体如下: 这一节我将总结一下android中的另一种数据存储--SQLite 的相关知识点 SQLite数据库是android系统自带的,主要用到的类包括SQLiteOpenHelper和SQLiteDatabase. 1.SQLiteOpenHelper:创建数据库和数据库版本管理的辅助类,该类是一个抽象类,所以我们一般都有一个子类SQLiteOpenHelper,需要继承实现的方法主要有onCreate(

  • Android数据存储之SQLite使用

    SQLite是一款开源的.嵌入式关系型数据库,第一个版本Alpha发布于2000年.SQLite在便携性.易用性.紧凑性.高效性和可靠性方面有着突出的表现. 在Android中创建的SQLite数据库存储在:/data/data/<包名>/databases/目录下. 主要特点: -轻量级 -独立性,没有不依赖,无需安装 -跨平台,支持众多操作系统 -支持高达2TB大小的数据库 -每个数据库以单个文件的形式存在 -以B-Tree的数据结构形式存储在硬盘 SQLite的数据类型: SQLite支

  • 详解Android文件存储

    摘要 其实安卓文件的操作和java在pc环境下的操作并无二致,之所以需要单独讲解是因为安卓系统提供了不同于pc的访问文件系统根路径的api,同时对一个应用的私有文件做了统一的管理.根据我的经验,初学者在这部分感到很容易混淆内部存储和外部存储两个概念. 其实安卓文件的操作和java在pc环境下的操作并无二致,之所以需要单独讲解是因为安卓系统提供了不同于pc的访问文件系统根路径的api,同时对一个应用的私有文件做了统一的管理.根据我的经验,初学者在这部分感到很容易混淆内部存储和外部存储两个概念. 相

  • 详解Android 中的文件存储

    目录 概要 当我们查看手机的文件管理器的时候,会发现里面的文件五花八门,想要找到自己项目所对应的文件非常困难,甚至有可能压根就找不到自己的文件,本文就来介绍一下APP开发过程当中文件存储的注意事项. 通常我们会将存放的文件分为两种:独立文件和专属文件.顾名思义,独立文件就是独立于APP之外的文件,不会随着APP的删除而删除,而专属文件则是专属于某个APP的文件,当APP删除后,会自动清空相对应的专属文件. 独立文件 独立文件指的是存放在shared/external storage direct

随机推荐