Android:用 SQLite 实现 用户的登录查询功能(详解+效果图)

您所在的位置:网站首页 如何利用电话号码查微博用户名和密码 Android:用 SQLite 实现 用户的登录查询功能(详解+效果图)

Android:用 SQLite 实现 用户的登录查询功能(详解+效果图)

2024-07-16 07:38| 来源: 网络整理| 查看: 265

文章目录 前言:什么是SQLite?为什么要用 SQLite?常见的应用场景: 实现功能:实现效果:代码部分:总结:

前言:

在侃实现功能之前,先来侃侃什么是SQLite?SQLite的具体应用场合有哪些?(了解的大佬就可以跳过啦,嘻嘻,也可以复习一下哦)。

什么是SQLite?

SQLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库一样,您不需要在系统中配置。

就像其他数据库,SQLite 引擎不是一个独立的进程,可以按应用程序需求进行静态或动态连接。SQLite 直接访问其存储文件。 --------- 菜鸟教程

为什么要用 SQLite?

不需要一个单独的服务器进程或操作的系统(无服务器的)。

SQLite 不需要配置,这意味着不需要安装或管理。

一个完整的 SQLite 数据库是存储在一个单一的跨平台的磁盘文件。

SQLite 是非常小的,是轻量级的,完全配置时小于 400KiB,省略可选功能配置时小于250KiB。

SQLite 是自给自足的,这意味着不需要任何外部的依赖。

SQLite 事务是完全兼容 ACID 的,允许从多个进程或线程安全访问。

SQLite 支持 SQL92(SQL2)标准的大多数查询语言的功能。

SQLite 使用 ANSI-C 编写的,并提供了简单和易于使用的 API。

SQLite 可在 UNIX(Linux, Mac OS-X, Android, iOS)和 Windows(Win32, WinCE, WinRT)中运行。

常见的应用场景:

相信大家都用过像百词斩,有道词典等类似的背单词的软件,没有用过的小伙伴可以下载一下尝试尝试(无偿做广告),在用这些软件的时候那些单词是从哪里来的呢?想一下,如果我们每次打开软件的时候都需要去服务器进行下载相应的单词进行学习,一旦有成千上万的英语学习爱好者,那服务器就需要面临崩溃的危机,可能会有人说,升级服务器不就行了,of course。 但是, 百词斩只是一个内存不到 几百M 的软件,用一个超大的服务器显然不是一个优秀的选择。(以上经过 zyg teacher 讲解后自己的推敲)。 SQLite就可以很好的帮助处理这个问题: 它会将单词书下载到本地,然后我们每次看单词时就从本地进行读取。(而且看看上面SQLite的有点,是不是很适合呢?)

实现功能:

用SQLite制作本地登录功能 1、包含两个Actvity:LoginActivity、ListActivity,LoginActivity为启动Activity 2、启动LoginActivity初始化SQLite数据库 3、在LoginActivity录入用户名和密码时,在SQLite中进行校验,校验成功跳转到ListActivity,否则继续。 4、ListActivity显示登录成功!

实现效果:

首页: 在这里插入图片描述 登录成功: 在这里插入图片描述

登录失败: 在这里插入图片描述

代码部分:

目录结构: 在这里插入图片描述 AndroidManifestxml

MainActivity.java 在本项目中用处不大。

package com.example.newsqlite; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } }

SQLiteDBHelper.java:数据库帮助类:

package com.example.newsqlite; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.util.Log; import androidx.annotation.Nullable; /** * A helper class to manage database creation and version management. * * 既然父类是一个帮助类,子类至少也是一个帮助类,而且更加强大 * * */ public class SQLiteDBHelper extends SQLiteOpenHelper { // 创建数据库 static final String CREATE_SQL[] = { "CREATE TABLE news (" + "_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT," + "title varchar," + "content varchar," + "keyword varchar," + "category varchar," + "author INTEGER," + "publish_time varchar" + ")", "CREATE TABLE user (" + "_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT," + "name varchar," + "password varchar," + "email varchar," + "phone varchar," + "address varcher" + ")", "INSERT INTO user VALUES (1,'admin',123,'[email protected]',123,'洛阳')", "INSERT INTO user VALUES (2,'zhangsan',123,'[email protected]',123,'北京')", "INSERT INTO user VALUES (3,'lisi',123,'[email protected]',123,'上海')", "INSERT INTO user VALUES (4,'wangwu',123,'[email protected]',123,'深圳')" }; // 调用父类的构造方法(便于之后进行初始化赋值) public SQLiteDBHelper(@Nullable Context context, @Nullable String name, int version) { super(context, name, null, version); } /** * Called when the database is created for the first time. This is where the * creation of tables and the initial population of the tables should happen. * * @param db The database. */ @Override public void onCreate(SQLiteDatabase db) { // 创建数据库 Log.i("sqlite_____", "create Database"); // 执行 SQL 语句 for (int i = 0; i

activity_sqlite_login.xml

总结:

嘻嘻,到此一个简单的登录+查询的小功能就是实现了,再也不用担心 Teacher 抽作业啦。 如果你 JavaWeb 学的不错的话,可以类比一下,布局管理器相当于是 html 文件,中间的 Activity 类比成 Servlet 进行跳转,数据库当然就是我们的 Dao 层了。 如果对您有帮助的,别忘了来个三连哦,感激感激。 如果上述的代码不够清晰,可以私聊我。 溜了溜了,交作业咯!



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3