Android_SQLite之创建数据库
今天我们主要学习了SQLite.主要是其中的创建数据库,连接这块。
现在我们先简单讲解下什么是SQLite
一、SQLite 简介
Google为Andriod的较大的数据处理提供了SQLite, 他在数据存储、管理、维护等各方面都相当出色, 功能也非常的强大.
二、SQLite 特点
1.轻量级 使用 SQLite 只需要带一个动态库,就可以享受它的全部功能, 而且那个动态库的尺寸想当小。
2.独立性 SQLite 数据库的核心引擎不需要依赖第三方软件,也不需要所谓的“安装”。
3.隔离性 SQLite 数据库中所有的信息(比如表、视图、触发器等) 都包含在一个文件夹内,方便管理和维护。
4.跨平台 SQLite 目前支持大部分操作系统,不至电脑操作系统更在众多的手机系统 也是能够运行,比如:Android。
5.多语言接口 SQLite 数据库支持多语言编程接口。
6.安全性 SQLite 数据库通过数据库级上的独占性和共享锁来实现独立事务处理。 这意味着多个进程可以在同一时间从同一数据库读取数据, 但只能有一个可以写入数据。
三、创建数据库类
先新建一个 MyDatabaseOpenHelper.class 文件 继承自 SQLiteOpenHelper 类。
注意 :SQLiteOpenHelper 是 SQLiteDatebase 的一个帮助类 用来管理数据库的创建和版本的更新 ,并实现它的OnCreate 和 OnUpdate方法。
package com.example.winxin2; import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log; public class MyDatabaseOpenHelper extends SQLiteOpenHelper{ private static final String DB_NAME = "mydata.db";//数据库名
private static final int version = 1;//数据库版本 public MyDatabaseOpenHelper(Context context) {
super(context, DB_NAME, null, version); } //问题:什么时候执行? 当没有前生的时候执行
//onCrate 是一个回调函数
@Override
public void onCreate(SQLiteDatabase db) {
//编写
//建表语句
Log.i("hey", "没有数据库,创建数据库。");
//创建表 t_message
//autoincrement 自动生成序列。
String sql_message = "create table t_message (uid integer primary key autoincrement,toul varchar(50),userName varchar(50),lastMessage varchar(50),datetime varchar(50))";
db.execSQL(sql_message);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }
四、连接数据库 插入数据
我们在 MaiinActivity.class 中对我们数据库进行连接,并插入数据。
在这里我们得明确两个概念:
1. getReadableDatebase() 创建或打开一个只读数据库
2.getWritableDatebase() 创建或打开一个读写数据库
下面是两种插入数据的方法。
//创建数据库
MyDatabaseOpenHelper helper = new MyDatabaseOpenHelper(this);
SQLiteDatabase db = helper.getWritableDatabase(); //ContentValues 其实是一个map 对象 google 工程师封装的方法
ContentValues values = new ContentValues(); //一一对应填充数据
values.put("userName", "android");
values.put("toul", "xxx");
values.put("lastMessage", "今天学习了SQLite");
values.put("datetime", "11月29号"); db.insert("t_Message", null, values);
//方法二:使用sql 语句
String sql = "insert into t_Message(toul,userName,lastMessage,datetime) values(?,?,?,?)";
//
String[] sqlVales = {
"aaa","oracle","oracle快忘记了","11月20日"
};
db.execSQL(sql,sqlVales);
//关闭数据库连接
db.close();
五、运行结果
今天的内容就是简单的创建sqlite,连接数据库,创建表和插入数据。
下面讲解一些类的方法,希望大家自己去尝试使用。
1.SQLiteDatabase类
常用方法:
(int) delete(String table,String whereClause,String[] whereArgs) | 删除数据行的便捷方法 |
(long) insert(String table,String nullColumnHack,ContentValues values) |
添加数据行的便捷方法 |
(int) update(String table, ContentValues values, String whereClause, String[] whereArgs) |
更新数据行的便捷方法 |
(void) execSQL(String sql) |
执行一个SQL语句,可以是一个select或其他的sql语句 |
(void) close() | 关闭数据库 |
(Cursor) query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit) |
查询指定的数据表返回一个带游标的数据集 |
(Cursor) rawQuery(String sql, String[] selectionArgs) |
运行一个预置的SQL语句,返回带游标的数据集(与上面的语句最大的区别就是防止SQL注入) |
2.SQLiteDatabase类
使用insert方法
ContentValues cv = new ContentValues();
//实例化一个ContentValues用来装载待插入的数据
cv.put("username","Jack Johnson");
//添加用户名 cv.put("password","iLovePopMusic");
//添加密码 db.insert("user",null,cv);//执行插入操作
使用execSQL方式来实现
String sql = "insert into user(username,password) values ('Jack Johnson','iLovePopMuisc');//插入操作的SQL语句
db.execSQL(sql);//执行SQL语句
数据的删除
String whereClause = "username=?";//删除的条件
String[] whereArgs = {"Jack Johnson"};//删除的条件参数
db.delete("user",whereClause,whereArgs);//执行删除
String sql = "delete from user where username='Jack Johnson'";//删除操作的SQL语句
db.execSQL(sql);//执行删除操作
数据修改
ContentValues cv = new ContentValues();//实例化
ContentValues cv.put("password","iHatePopMusic");//添加要更改的字段及内容
String whereClause = "username=?";//修改条件
String[] whereArgs = {"Jack Johnson"};//修改条件的参数
db.update("user",cv,whereClause,whereArgs);//执行修改
String sql = "update [user] set password = 'iHatePopMusic' where username='Jack Johnson'";//修改的SQL语句
db.execSQL(sql);//执行修改
数据查询
通过query实现查询的 public Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)
table | 表名称 |
column | 列名称数组 |
selection | 条件子句,,相当于where |
selectionArgs | 条件语句的参数数组 |
groupBy | 分组 |
having | 分组条件 |
orderBy | 排序类 |
limit | 分页查询的限制 |
Cursor | 返回值,相当于结果集resultSet |
游标(Cursor)
getCount() | 总记录条数 |
isFirst() | 判断是否第一条记录 |
isLast() | 判断是否最后一条记录 |
moveToFirst() | 移动到第一条记录 |
moveToLast() | 移动到最后一条记录 |
move(int offset) | 移动[是指偏移量而不是指移到指定位置] |
moveToNext() | 移动到吓一条记录 |
moveToPrevious() | 移动到上一条记录 |
getColumnIndex(String columnName) | 获得指定列索引的int类型值 |
游标(Cursor)
Cursor c = db.query("user",null,null,null,null,null,null);//查询并获得游标
if(c.moveToFirst()){//判断游标是否为空
for(int i=0;i<c.getCount();i++){
c.moveToNext();
String username = c.getString(c.getColumnIndex("username");
String password = c.getString(c.getColumnIndex("password"));
}
rawQuery实现的带参数查询
Cursor c = db.rawQuery("select * from user where username=?",new Stirng[]{"Jack Johnson"});
if(cursor.moveToFirst()) {
String password = c.getString(c.getColumnIndex("password"));
}
Android_SQLite之创建数据库的更多相关文章
- MVC CodeFirst简单的创建数据库(非常详细的步骤)
最近在学习MVC的开发,相信有过开发经验的人初学一个新的框架时候的想法跟我一样最关心的就是这个框架如何架构,每个架构如何分工,以及最最关键的就是如何与数据库通信,再下来才是学习基础的页面设计啊等 ...
- 使用EF CodeFirst 创建数据库
EntityFramework 在VS2015添加新建项时,选择数据->ADO.NET 实体数据模型,有一下选项 来自数据库的EF设计器,这个就是我们最常用的EntityFramework设计模 ...
- ABP创建数据库操作步骤
1 ABP创建数据库操作步骤 1.1 SimpleTaskSystem.Web项目中的Web.config文件修改数据库配置. <add name="Default" pro ...
- Oracle 11g静默安装软件+手工创建数据库
由于是二次跳转+远程操作,无法使用图形界面,不能直接图形界面安装.采用静默安装软件+手工创建数据库的方式完成需求. 静默模式安装Oracle软件,配置监听程序 手工建库 检查各组件是否符合要求 1. ...
- 使用PD(PowerDesigner)图如何快速生成创建数据库表的SQL脚本
打开PD软件: 1.新建概念模型(conceptual Data Model) File-->New Model-->Conceptual Data Mode 或者点击工作区,右键--&g ...
- 【无私分享:ASP.NET CORE 项目实战(第四章)】Code First 创建数据库和数据表
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 本章我们来介绍下Asp.net Core 使用 CodeFirst 创建数据库和表,通过 控制台 和 dotnet ef 两种 ...
- 利用Oracle创建数据库
本文仅用于学习交流,商业用途请支持正版!转载请注明:http://www.cnblogs.com/mxbs/p/6217151.html 数据库的创建 打开"所有程序"-" ...
- [LINQ TO SQL]使用LINQ TO SQL创建数据库
这篇博客将介绍如何使用LINQ TO SQL来创建数据库,以及如何映射Table之间的主外键关系. 我们的数据库表关系如下: Province与City之间1:M,City与Area之间1:M的关系. ...
- SQL Server 创建数据库邮件
一. 背景 数据库发邮件通知数据库的运行状态(状态可以通过JOB形式获取)和信息,达到预警的效果. 二. 基础知识 msdb系统数据库保存有关Job,Database Mail,Nodifyicati ...
随机推荐
- vue.js 2.0开发(4)
使用vue-cli,首先安装: npm install -g vue-cli 安装完了执行vue命令,会出现 vue init <template-name> <project-na ...
- url-pattern
一,servlet容器对url的匹配过程: 当 一个请求发送到servlet容器的时候,容器先会将请求的url减去当前应用上下文的路径作为servlet的映射url,比如我访问的是 http://lo ...
- Android 通过广播获取网络状态
Android系统网络连接状态的改变会发一个广播,注册一个广播接收者,实时动态的检测网络状态,及时提醒用户,优化用户体验. 本文仅提供WIFI 状态的检测作为参考,其他网络连接方式请 ...
- 【解决】SQL Server作业中Excel Application不能访问文件
在通过SQL Server作业来实现定时任务时,出现如下错误: FullyQualifiedErrorId : ComMethodTargetInvocation使用“1”个参数调用“Add”时发生异 ...
- Linux常用命令集合
常用的Linux命令,备忘 1 pwd 显示当前目录 命令格式: pwd [选项] 2 cd 更换目录 命令格式: cd [目录名] 例: 3 ls 显示当前目录内容 命令格式: ls [选项] [目 ...
- nodejs express环境配置
下载安装最新版nodejs,安装完毕运行命令 node -v 查看版本以及是否安装成功. 然后安装express插件,命令 npm install -g express (全局) , express ...
- 用javascript比较快速排序和合并排序的优劣
<script> //用来调用排列方法的类 function arr_sort(arr){ var startTime,endTime; var priv_arr = new Array; ...
- springmvc图片文件上传接口
springmvc图片文件上传 用MultipartFile文件方式传输 Controller package com.controller; import java.awt.image.Buffer ...
- opencv基于混合高斯模型的图像分割
#include "stdafx.h" #include <opencv\cv.h> #include <opencv\highgui.h> #includ ...
- Chrome Dev Tools :成为更高效的开发人员
原文出处 http://blog.jobbole.com/22065/ 实时CSS Style编辑 选择一个Dom,可以对Dom进行编辑和操作,实时修改Css Style, 同时CssStyle可以保 ...