Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南

马肤

温馨提示:这篇文章已超过435天没有更新,请注意相关的内容是否还可用!

摘要:,,本篇文章详细介绍了Android系统中SQLite数据库的使用。内容涵盖了Android中SQLite数据库的基本概念、创建数据库和表格的方法、数据的增删改查操作、优化数据库性能的技巧以及处理数据库事务的方式等。文章旨在帮助开发者更好地理解和运用SQLite数据库,以实现更高效的数据存储和检索功能,提升Android应用的性能和用户体验。

}

public TUser(Integer id, String username, String password, String name,

String sex) {

super();

this.id = id;

this.username = username;

this.password = password;

this.name = name;

this.sex = sex;

}

public TUser() {

super();

}

}

DbOpenHelper.java链接数据库,创建数据库类

package com.example.androiddemo01.dao;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteDatabase.CursorFactory;

import android.database.sqlite.SQLiteOpenHelper;

public class DbOpenHelper extends SQLiteOpenHelper {

private static final String DBNAME = “data.db”;

private static int version = 1;

//content容器,name链接数据库名字,version版本号,factory游标工厂

public DbOpenHelper(Context context) {

super(context, DBNAME, null, version);

}

//运行DbOpenHelper时执行,建立表和数据库,没有数据库则建立,只有第一次运行执行

@Override

public void onCreate(SQLiteDatabase db) {

String sql = “create table t_user(”+

“id integer primary key autoincrement not null,”+

“username text(10),”+

“password text(10),”+

“name text(10),”+

“sex text(2))”;

//执行SQL语句

db.execSQL(sql);

sql = “insert into t_user (‘username’, ‘password’, ‘name’, ‘sex’) values(‘admin’,‘admin’, ‘张三’, ‘男’)”;

db.execSQL(sql);

}

//更新,版本升级

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}

}

TUserDAO.java数据库操作类,增删改查。

package com.example.androiddemo01.dao;

import java.util.ArrayList;

import java.util.List;

import com.example.androiddemo01.model.TUser;

import android.content.Context;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

//持久层类,对数据库的操作

public class TUserDAO {

private SQLiteDatabase db;

//content容器,上下文

public TUserDAO(Context context){

super();

DbOpenHelper helper = new DbOpenHelper(context);

db = helper.getWritableDatabase();

}

//登录验证

public TUser findUserNameAndPassword(String str, String str1) {

String sql = “select * from t_user where username = ? and password = ?”;

Cursor cursor = db.rawQuery(sql, new String[] {str, str1});

TUser user = null;

//cursor.moveToNext判断下一个是否有值

if(cursor.moveToNext()){

user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));

}

return user;

}

//查找表中所有数据

public List findAll(){

String sql = “select * from t_user”;

Cursor cursor = db.rawQuery(sql, null);

List list = new ArrayList();

if(cursor.moveToNext()){

TUser user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));

list.add(user);

}

return list;

}

//根据姓名模糊查找

public List searchByName(String key){

List list = new ArrayList();

key = “%”+key+“%”;

Cursor cursor = db.rawQuery(“select * from t_user where name like ?”, new String[]{key});

while(cursor.moveToNext()){

TUser user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));

list.add(user);

}

return list;

}

//添加

public void insert(TUser t){

db.execSQL(“insert into t_user(username, password, name, sex) values(?, ?, ?, ?)”, new Object[] {t.getUsername(), t.getPassword(), t.getName(), t.getSex()});

System.out.println(“添加数据成功!”);

}

//修改

public void update (TUser user){

db.execSQL(“update t_user set name=?, sex = ?, password = ?, username = ? where id = ?”,

new Object[] {user.getName(), user.getSex(), user.getPassword(), user.getUsername(), user.getId()});

}

//根据id删除

public void delete(int id){

Integer i = new Integer(id);

db.execSQL(“delete from student where id = ?”, new Object[]{i});

}

}

MainActivity.java登录处理类

package com.example.androiddemo01;

import com.example.androiddemo01.dao.TUserDAO;

import com.example.androiddemo01.model.TUser;

import android.app.Activity;

import android.content.Intent;

import android.os.Bundle;

import android.view.Menu;

import android.view.MenuItem;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.widget.TextView;

import android.widget.Toast;

public class MainActivity extends Activity implements OnClickListener {

private TextView username;

private TextView password;

private Button submit;

private Button register;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

username = (TextView) findViewById(R.id.username);

password = (TextView) findViewById(R.id.password);

submit = (Button) findViewById(R.id.submit);

register = (Button) findViewById(R.id.register);

submit.setOnClickListener(this);

register.setOnClickListener(this);

}

@Override

public void onClick(View v) {

TUserDAO user = new TUserDAO(this);

//创建intent对象

Intent intent = new Intent();

switch (v.getId()) {

case R.id.submit:

String str = username.getText().toString();

String str1 = password.getText().toString();

if(str.equals(“”) || str1.equals(“”)){

//弹框提示

Toast.makeText(MainActivity.this, “账号密码不能为空”, Toast.LENGTH_SHORT).show();

}else{

TUser t_user = user.findUserNameAndPassword(str, str1);

if(t_user == null){

Toast.makeText(MainActivity.this, “账号或密码输入错误”, Toast.LENGTH_SHORT).show();

}else{

//跳转指定的Activity

intent.setClass(MainActivity.this, IndexActivity.class);

//传递参数

intent.putExtra(“name”, t_user.getName());

//执行方法

startActivityForResult(intent, 2);

}

}

break;

default:

break;

}

}

}

IndexActivity.java登录成功显示姓名。最后一个类了_

package com.example.androiddemo01;

import android.app.Activity;

import android.content.Intent;

import android.os.Bundle;

import android.view.Menu;

import android.view.MenuItem;

import android.widget.TextView;

public class IndexActivity extends Activity {

private TextView text;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南 第1张

Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南 第2张

Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南 第3张

Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南 第4张

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)

Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南 第5张

最后

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。

【Android学习PDF+学习视频+面试文档+知识点笔记】

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

Android——SQLite数据库使用详解,Android SQLite数据库使用详解指南 第6张

【Android高级架构视频学习资源】

注Android)**

[外链图片转存中…(img-znb22Two-1710816582504)]

最后

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。

【Android学习PDF+学习视频+面试文档+知识点笔记】

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

[外链图片转存中…(img-zm34SvV2-1710816582504)]

【Android高级架构视频学习资源】

**Android部分精讲视频领取学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!


0
收藏0
文章版权声明:除非注明,否则均为VPS857原创文章,转载或复制请以超链接形式并注明出处。

相关阅读

  • 【研发日记】Matlab/Simulink自动生成代码(二)——五种选择结构实现方法,Matlab/Simulink自动生成代码的五种选择结构实现方法(二),Matlab/Simulink自动生成代码的五种选择结构实现方法详解(二)
  • 超级好用的C++实用库之跨平台实用方法,跨平台实用方法的C++实用库超好用指南,C++跨平台实用库使用指南,超好用实用方法集合,C++跨平台实用库超好用指南,方法与技巧集合
  • 【动态规划】斐波那契数列模型(C++),斐波那契数列模型(C++实现与动态规划解析),斐波那契数列模型解析与C++实现(动态规划)
  • 【C++】,string类底层的模拟实现,C++中string类的模拟底层实现探究
  • uniapp 小程序实现微信授权登录(前端和后端),Uniapp小程序实现微信授权登录全流程(前端后端全攻略),Uniapp小程序微信授权登录全流程攻略,前端后端全指南
  • Vue脚手架的安装(保姆级教程),Vue脚手架保姆级安装教程,Vue脚手架保姆级安装指南,Vue脚手架保姆级安装指南,从零开始教你如何安装Vue脚手架
  • 如何在树莓派 Raspberry Pi中本地部署一个web站点并实现无公网IP远程访问,树莓派上本地部署Web站点及无公网IP远程访问指南,树莓派部署Web站点及无公网IP远程访问指南,本地部署与远程访问实践,树莓派部署Web站点及无公网IP远程访问实践指南,树莓派部署Web站点及无公网IP远程访问实践指南,本地部署与远程访问详解,树莓派部署Web站点及无公网IP远程访问实践详解,本地部署与远程访问指南,树莓派部署Web站点及无公网IP远程访问实践详解,本地部署与远程访问指南。
  • vue2技术栈实现AI问答机器人功能(流式与非流式两种接口方法),Vue2技术栈实现AI问答机器人功能,流式与非流式接口方法探究,Vue2技术栈实现AI问答机器人功能,流式与非流式接口方法详解
  • 发表评论

    快捷回复:表情:
    评论列表 (暂无评论,0人围观)

    还没有评论,来说两句吧...

    目录[+]

    取消
    微信二维码
    微信二维码
    支付宝二维码