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

首先是如何建立数据库和表:

建立一个类继承SQLiteOpenHelper,即:

public class ReaderOpenHelper extends SQLiteOpenHelper

然后添加构造方法:

public ReaderOpenHelper(Context context) {

        super(context, "people.db", null, 1);

    }

people.db是数据库名字,1是数据库版本。

然后在该类实现以下两个方法:

@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
db.execSQL("create table readers(renumber integer primary key,rename text,retype text,reage text,rephone text,usename integer,password integer,createtime text)");
db.execSQL("create table books(booknumber integer primary key,bookname text,booktype text,bookeditor text,intime text,incounts integer)");
}

db.execSQL的作用是执行SQL语句,create table readers是创建一个叫readers的表,括号里就是各个字段名和值类型。

这里创建了两张表。另一张叫books

继续实现:

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL("drop if table exists readers");
db.execSQL("drop if table exists books");
onCreate(db);
}

执行Sql语句"drop if table exists 表名"

这样你的sqlite数据库和两张表就创建完成了。

接下来再建一个数据库manager类,如:

public class ReaderManager 

添加一个构造方法

public ReaderManager(Context conetxt) {
this.context = context;
readerOpenHelper = new ReaderOpenHelper(conetxt);
}

然后添加表的操作方法:

package com.zhou.db;

import java.util.ArrayList;
import java.util.List; import com.zhou.utils.Books;
import com.zhou.utils.Reader; import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log; public class ReaderManager {
ReaderOpenHelper readerOpenHelper;
Context context; public ReaderManager(Context conetxt) {
this.context = context;
readerOpenHelper = new ReaderOpenHelper(conetxt);
} // 增加读者
public void addSQL(Reader reader) {
SQLiteDatabase db = null;
try {
db = readerOpenHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("renumber", reader.getReNumber());
values.put("rename", reader.getName());
values.put("retype", reader.getSex());
values.put("reage", reader.getAge());
values.put("rephone", reader.getPhoneNumber());
values.put("createtime", reader.getCreateTime());
values.put("usename", reader.getUseName());
values.put("password", reader.getPassword());
db.insert("readers", null, values);
} catch (Exception e) {
// TODO: handle exception
} finally {
db.close();
}
} // 增加图书
public void bookAddSQL(Books book) {
SQLiteDatabase db = null;
try {
db = readerOpenHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("booknumber", book.getBookNumber());
values.put("bookname", book.getBookName());
values.put("booktype", book.getBookType());
values.put("bookeditor", book.getBookEditer());
values.put("intime", book.getInTime());
values.put("incounts", book.getCount());
db.insert("books", null, values);
} catch (Exception e) {
// TODO: handle exception
} finally {
db.close();
}
} // 读者查询
public List<Reader> selectSQL() {
List<Reader> list = new ArrayList<Reader>();
SQLiteDatabase db = null;
// 获取一个光标对象
Cursor cursor = null;
try {
db = readerOpenHelper.getReadableDatabase();
cursor = db.query("readers", null, null, null, null, null, null);
Reader reader = null;
while (cursor.moveToNext()) {
reader = new Reader();
reader.setReNumber(cursor.getInt(cursor
.getColumnIndex("renumber"))); reader.setName(cursor.getString(cursor.getColumnIndex("rename")));
reader.setSex(cursor.getString(cursor.getColumnIndex("retype")));
reader.setAge(cursor.getString(cursor.getColumnIndex("reage")));
reader.setPhoneNumber(cursor.getString(cursor
.getColumnIndex("rephone")));
reader.setCreateTime(cursor.getString(cursor
.getColumnIndex("createtime")));
reader.setUseName(cursor.getInt(cursor
.getColumnIndex("usename")));
reader.setPassword(cursor.getInt(cursor
.getColumnIndex("password")));
list.add(reader);
}
} catch (Exception e) {
// TODO: handle exception
} finally {
cursor.close();
db.close();
} return list;
} // 图书查询
public List<Books> bookSelectSQL() {
List<Books> list = new ArrayList<Books>();
SQLiteDatabase db = null;
// 获取一个光标对象
Cursor cursor = null;
try {
db = readerOpenHelper.getReadableDatabase();
cursor = db.query("books", null, null, null, null, null, null);
Books book = null;
while (cursor.moveToNext()) {
book = new Books();
book.setBookNumber(cursor.getInt(cursor
.getColumnIndex("booknumber")));
book.setBookName(cursor.getString(cursor
.getColumnIndex("bookname")));
book.setBookType(cursor.getString(cursor
.getColumnIndex("booktype")));
book.setBookEditer(cursor.getString(cursor
.getColumnIndex("bookeditor")));
book.setInTime(cursor.getString(cursor.getColumnIndex("intime")));
book.setCount(cursor.getInt(cursor.getColumnIndex("incounts")));
Log.d("TAGG", cursor.getString(cursor.getColumnIndex("intime")));
list.add(book);
}
} catch (Exception e) {
// TODO: handle exception
} finally {
cursor.close();
db.close();
} return list;
} // 读者删除
public void deleteSQL(final long id) {
SQLiteDatabase db = null;
try {
db = readerOpenHelper.getWritableDatabase();
db.delete("readers", "renumber=" + id, null);
} catch (Exception e) { } finally {
db.close();
}
} // 读者更新 public void updateData(int id, String name, String sex, String age,
String phoneNumber, int password) { SQLiteDatabase db = null;
try {
db = readerOpenHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("rename", name);
values.put("retype", sex);
values.put("reage", age);
values.put("rephone", phoneNumber);
values.put("password", password);
db.update("readers", values, "renumber=" + id, null);
} catch (Exception e) {
// TODO: handle exception
} finally {
db.close();
} } // public long getCount() {
//
// Cursor cursor = null;
// long count = 0;
// SQLiteDatabase db = null;
// try {
// db = readerOpenHelper.getWritableDatabase();
// cursor = db.query("readers", null, null, null, null, null, null);
//
// if (null != cursor) {
// count = cursor.getCount();
// cursor.close();
// }
// } catch (Exception e) {
// } finally {
// db.close();
// }
// return count;
// } }

android中sqlite数据库的基本使用和添加多张表的更多相关文章

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

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

  2. Android中SQLite数据库小计

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

  3. 我的Android六章:Android中SQLite数据库操作

    今天学习的内容是Android中的SQLite数据库操作,在讲解这个内容之前小编在前面有一篇博客也是讲解了SQLite数据库的操作,而那篇博客的讲解是讲述了 如何在Window中通过DOM来操作数据库 ...

  4. Android 中 SQLite 数据库的查看

    当 SQLite 数据库创建完成后,如何查看数据库的内容呢?如果直接使用 File Explorer 查看,最多只能看到 database 目录下出现了一个 BookStore.db 文件,Book ...

  5. Android中Sqlite数据库多线程并发问题

    最近在做一个Android项目, 为了改善用户体验,把原先必须让用户“等待”的过程改成在新线程中异步执行.但是这样做遇到了多个线程同时需要写Sqlite数据库,导致操作数据库失败. 本人对Java并不 ...

  6. Android中SQLite数据库操作(2)——SQLiteOpenHelper类

    如果开发者对SQL语法不熟悉,我要告诉你一个好消息,Android提供了一个SQLiteOpenHelper类. 在实际项目中很少使用SQLiteDatabase的方法(请看:http://blog. ...

  7. Android中Sqlite数据库进行增删改查

    今天这篇文章写Sqlite数据库,通过一个小案例来完整讲一下数据库常见的CRUD操作. 先对知识点总结: SQLite数据库 轻量级关系型数据库 创建数据库需要使用的api:SQLiteOpenHel ...

  8. Android中SQLite数据库操作(2)——使用SQLiteDatabase提供的方法操作数据库

    如果开发者对SQL语法不熟,甚至以前从未使用过任何数据库,Android的SQLiteDatabase提供了insert.update.delete或query语句来操作数据库. 一.insert方法 ...

  9. Android 开发中 SQLite 数据库的使用

    SQLite 介绍 SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能.此外它还是开源的,任何人都可以使用它.许多开源项目((Mozilla, PHP, ...

随机推荐

  1. jenkins之docker安装

    此方法安装还存在两个问题1.构建node程序:2.时区问题(在docker run 设置环境变量是否能解决没有试过) 不建议用此方法安装,查看我的其他安装方式 搬运官网步骤,稍微改动. 1.安装doc ...

  2. iOS开发 Error: CGImageProviderCreate: invalid image provider size

    一般可拉伸的图片(俗称点9图片)会放到images.xcassets目录里,然后对图片进行Slicing,但是当对一张图片进行slicing的left和right都是0的话,在iOS7.0上运行会出现 ...

  3. puppeteer爬虫服务

    爬虫文件 baidu.js const puppeteer = require("puppeteer"); const path = require('path'); const ...

  4. puppeteer学习笔记合集

    官方英文版API入口(如果你英文好的话):https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md. 汉化版API入口(网上有 ...

  5. 修改oracle用户登录密码

    运行sqlplus进入输入密码界面 用户名输入: connect as sysdba 密码:这边乱输就可以了 然后进行输入下面的命令: 修改密码命令 alter user system identif ...

  6. 第11组 Alpha冲刺(4/6)

    第11组 Alpha冲刺(4/6)   队名 不知道叫什么团队 组长博客 https://www.cnblogs.com/xxylac/p/11884529.html 作业博客 https://edu ...

  7. ybatis 逆向工程 自动生成的mapper文件没有 主键方法

    1.数据表没有设置主键 设置个主键就好 2.在mybits配置文档里设置了某些属性值为false 在mybatis配置文档里查看 enableSelectByPrimaryKey="true ...

  8. vue2.0中 怎么引用less?

    vue2.0中  怎么引用less? 第一步: 安装less依赖, npm install less less-loader --save 第二步: 修改webpack.config.js文件,配置l ...

  9. 广告行业——数字广告营销中的DSP、SSP、RTB是个什么概念

    原文链接1 原文链接2 如我是一个创业公司,没啥钱,老板给了1000块钱预算,让我去投互联网广告,对我说: “小卡啊!给你1000块钱,我知道你没见过那么多的巨款吧!不要被吓着,尽情去挥霍吧!哦对了, ...

  10. 浅析 Nodejs 模块化

    本文只讨论 CommonJS 规范,不涉及 ESM 我们知道 JavaScript 这门语言诞生之初主要是为了完成网页上表单的一些规则校验以及动画制作,所以布兰登.艾奇(Brendan Eich)只花 ...