文章目录

  • 一、实验内容
  • 二、实验步骤
    • 1、页面布局
    • 2、数据库
    • 3、登录活动
    • 4、增删改查
  • 三、运行演示
  • 四、实验总结
  • 五、源码下载

一、实验内容

根据Android数据存储的内容,综合应用SharedPreferences和SQLite数据库实现一个用户信息管理系统,强化对SharedPreferences的理解的使用,熟练掌握SQLite的操作。要求:

  1. 巩固Android应用开发工具(Eclipse或者AndroidStudio)的常规用法;
  2. 巩固Activity、UI控件的常规用法;
  3. 掌握SharedPpreferences数据存储的使用;
  4. 掌握SQLite数据库及SQLiteOpenHelper的使用。

二、实验步骤

1、页面布局

本次布局提倡从简原则,按照往常习惯,我肯定是创建多个Activity,然后每个Activity设置下页面,分别从主页面跳转到各个页面。既然是实验,那就从简,实现核心的思想就可以了,底层逻辑实现出来,表面内容那不是花时间设计下就行了。言归正传,主页面布局如下,没有任何亮点可言,比较常规,只给Button和TextView都设置了background。


完整的layout代码如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity"><EditTextandroid:id="@+id/et_id"android:layout_width="match_parent"android:layout_height="wrap_content"android:hint="请输入学号"android:textSize="20sp"android:textColor="@color/black"android:padding="10dp"android:layout_margin="20dp"android:inputType="text"android:background="@drawable/et_selector" /><EditTextandroid:id="@+id/et_name"android:layout_width="match_parent"android:layout_height="wrap_content"android:hint="请输入姓名"android:textSize="20sp"android:textColor="@color/black"android:padding="10dp"android:layout_margin="20dp"android:inputType="text"android:background="@drawable/et_selector" /><EditTextandroid:id="@+id/et_age"android:layout_width="match_parent"android:layout_height="wrap_content"android:hint="请输入年龄"android:textSize="20sp"android:textColor="@color/black"android:padding="10dp"android:layout_margin="20dp"android:inputType="text"android:background="@drawable/et_selector" /><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="horizontal"><Buttonandroid:id="@+id/btn_insert"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:gravity="center"android:text="添加"android:background="@drawable/btn_selector"android:textSize="20sp"android:layout_margin="10dp"android:textColor="@color/black"/><Buttonandroid:id="@+id/btn_delete"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:gravity="center"android:text="删除"android:background="@drawable/btn_selector"android:textSize="20sp"android:layout_margin="10dp"android:textColor="@color/black"/></LinearLayout><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="horizontal"android:layout_marginBottom="20dp"><Buttonandroid:id="@+id/btn_update"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:gravity="center"android:text="修改"android:background="@drawable/btn_selector"android:textSize="20sp"android:layout_margin="10dp"android:textColor="@color/black"/><Buttonandroid:id="@+id/btn_query"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:gravity="center"android:text="查询"android:background="@drawable/btn_selector"android:textSize="20sp"android:layout_margin="10dp"android:textColor="@color/black"/></LinearLayout><Viewandroid:layout_width="match_parent"android:layout_height="2dp"android:background="@color/black"/><LinearLayoutandroid:orientation="horizontal"android:layout_width="match_parent"android:layout_height="wrap_content"><TextViewandroid:layout_width="0dp"android:layout_weight="1"android:text="学号"android:textSize="20sp"android:gravity="center"android:layout_height="wrap_content"/><TextViewandroid:layout_width="0dp"android:layout_weight="1"android:text="姓名"android:textSize="20sp"android:gravity="center"android:layout_height="wrap_content"/><TextViewandroid:layout_width="0dp"android:layout_weight="1"android:text="年龄"android:textSize="20sp"android:gravity="center"android:layout_height="wrap_content"/></LinearLayout><Viewandroid:layout_width="match_parent"android:layout_height="2dp"android:background="@color/black"/><ListViewandroid:id="@+id/lv_stu"android:layout_width="match_parent"android:layout_height="match_parent"/>
</LinearLayout>

2、数据库

考查对SQLite的熟练程度,其实就是Android提供了一个数据库帮助类,帮我们进行数据库的各种操作。我们要做的就是建库建表,写个增删改查的方法,然后剩下的事情交给系统。这里是学生表的建表语句,一切属性都能用text表示。

    private val CREATE_STUDENT = "create table Student (" +"id text primary key," +"name text," +"age text)"

再看学生类,简直封装的太好了,Kotlin的魅力所在,换做Java又是属性、构造函数、get和set方法。

class Student(val id:String, val name:String, val age:String) {}

下面看数据库的增删改查操作,所有的操作都是针对数据库的Student表来的,增加、删除和修改都很简单,使用ContentValues添加键值对。查询是最关键的,使用cursor游标一行行遍历表数据,各种约束条件可以自己加,正常全查就完事了。

 val dbHelper = DBHelper(context, "stu.db", 1)lateinit var db:SQLiteDatabasefun openDB() {db = dbHelper.writableDatabase}fun closeDB() {if (db != null) dbHelper.close()}// 插入学生fun insertStudent(stu: Student) {val values = ContentValues().apply {put("id", stu.id)put("name", stu.name)put("age", stu.age)}db.insert("Student", null, values)}// 删除学生fun deleteStudent(stu: Student) {db.delete("Student", "id = ?", arrayOf(stu.id))}// 更新学生fun updateStudent(stu: Student) {val values = ContentValues()values.put("name", stu.name)values.put("age", stu.age)db.update("Student", values, "id = ?", arrayOf(stu.id))}// 查询所有学生fun queryAllStudent():ArrayList<Student> {val cursor = db.query("Student", null, null, null, null, null, null)val stuList = ArrayList<Student>()if (cursor.moveToFirst()) {do {val id = cursor.getString(cursor.getColumnIndex("id"))val name = cursor.getString(cursor.getColumnIndex("name"))val age = cursor.getString(cursor.getColumnIndex("age"))val stu = Student(id, name, age)stuList.add(stu)} while (cursor.moveToNext())}cursor.close()return stuList}

3、登录活动

登录活动用的是sharedPreferences,它使用方法非常easy,首先初始化一个sharedPreferences对象,文件名和访问类型自定义。读数据就是调用getString获取键值对,设定个默认值。写数据就是调用sharedPreferences.edit()赋值给editor对象,然后putString读取键值对。还记录了下app的使用次数。

 override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)binding = ActivityLoginBinding.inflate(layoutInflater)setContentView(binding.root)sharedPreferences = getSharedPreferences("data", Context.MODE_PRIVATE)var editor = sharedPreferences.edit()// 得到之前的使用次数,然后每次打开app都加1var count = sharedPreferences.getString("count", "0");binding.tvCount.text = (count!!.toInt() + 1).toString()// 保存键值对到sharedpreferences中editor.putString("count", (count!!.toInt() + 1).toString())editor.apply()binding.btnLogin.setOnClickListener{editor.putString("account", binding.etAccount.toString().trim())editor.putString("password", binding.etPassword.toString().trim())editor.apply()Toast.makeText(this, "登录成功!", Toast.LENGTH_SHORT).show()val intent = Intent(this, MainActivity::class.java)startActivity(intent)finish()}}

4、增删改查

其实对数据表的增删改查逻辑在StudentDao中已经封装好了,我们在Activity里面也只是调用方法实现界面和数据库的交互罢了。具体的操作逻辑如下:

输入学号、姓名和年龄后点击添加可以添加学生;输入学号点击查询可以查询学生信息,然后点击删除会删除信息,点击修改会修改输入框中的学生信息,最后如果输入的学号不存在而且你点查询了,会显示所有学生的信息,如果存在只会显示该学生的信息。

    override fun onClick(p0: View?) {var stuId = binding.etId.text.toString()var stuName = binding.etName.text.toString()var stuAge = binding.etAge.text.toString()var stu = Student(stuId, stuName, stuAge)var flag = (studentDao.queryById(stuId) != null)when(p0?.id) {R.id.btn_insert->{if (flag) {Toast.makeText(this, "学生已存在,无法添加", Toast.LENGTH_SHORT).show()} else {studentDao.insertStudent(stu)Toast.makeText(this, "添加成功!", Toast.LENGTH_SHORT).show()}}R.id.btn_delete->{if (flag) {studentDao.deleteStudent(stu)Toast.makeText(this, "删除成功!", Toast.LENGTH_SHORT).show()} else {Toast.makeText(this, "该学生不存在,无法删除", Toast.LENGTH_SHORT).show()}}R.id.btn_update->{if (flag) {studentDao.updateStudent(stu)Toast.makeText(this, "修改成功!", Toast.LENGTH_SHORT).show()} else {Toast.makeText(this, "该学生不存在,无法修改", Toast.LENGTH_SHORT).show()}}R.id.btn_query->{if (flag) {// 如果存在则补全信息binding.etAge.setText(studentDao.queryById(stuId)?.age)binding.etName.setText(studentDao.queryById(stuId)?.name)Toast.makeText(this, "查询到该学生信息", Toast.LENGTH_SHORT).show()} else {// 不存在则显示所有学生信息studentList = studentDao.queryAllStudent()adapter = StudentAdapter(this, R.layout.item_student, studentList)binding.lvStu.adapter = adapterToast.makeText(this, "查询所有学生信息", Toast.LENGTH_SHORT).show()}}}}

三、运行演示

1、首先进入登录界面,输入账号和密码然后点击登录即可,右上角是使用次数。

2、进入主界面,我们输入学号、姓名和年龄进行添加学生。


3、点击添加按钮,添加成功。再依次添加几个学生。

4、点击查询,此时学号是不存在的,所以就查询了所有学生的信息。


5、我们输入学号4,然后点击查询,可以看到查询到信息并自动补全了。


6、修改姓名和年龄,然后再点修改,再点击查询,发现已经修改好了信息。


7、我们再查询小益的信息,然后删除小益的信息。

四、实验总结

其实学生系统涉及到数据库的操作完全和前面的其他系统相似,真正做起来还是比较繁琐的。哪里有什么容易代码,都是在一个个bug解决中完成的。理论引导实战,光理论只会纸上谈兵,光实践缺少方法论,基础打牢了才能进阶,不然上限不会高,基础决定了你的上限。

五、源码下载

关注公众号《 萌新加油站 》,后台回复: Kotlin学生

Kotlin实现简单的学生信息管理系统相关推荐

  1. 用python设计学生管理系统_基于python和tkinter实现的一个简单的学生信息管理系统...

    一个简单的学生信息管理系统基于python和tkinter 1.需求分析1.大学生信息管理系统使用tkinter接口创建一个窗口.使界面更漂亮.2. 实现与数据库的连接,教师和学生的信息可以保存或读取 ...

  2. python成绩管理系统设计 gui csdn_用golang简单编写学生信息管理系统

    用golang简单编写学生信息管理系统 发布时间:2020-09-04 11:45:16编辑:三青(参考七米老师的视频)查看次数:187 student.gopackage main import & ...

  3. c++ stl list实现简单的学生信息管理系统

    c++ stl list实现简单的学生信息管理系统 问题描述: 已知有20个学生记录(包括学号.姓名.成绩)的文件student.dat.要求编程序实现查询.排序.插入.删除诸功能. 系统的基本功能: ...

  4. JavaWeb 入门 最简单的学生信息管理系统

    最近在学习JavaWeb,整理一下.写了个很简单的学生信息管理系统.系统只包括简单的对学生信息进行增删改查.系统采用三层设计模式. 先展示一下系统的业务处理逻辑图: 逻辑如图所示,获取前端用户交互信息 ...

  5. Java语言写一个简单的学生信息管理系统,通过JDBC连接数据库对学生信息进行增删改查,采用三层思想和DBUtils第三方框架。

    我把源代码和sql文件放GitHub上了,你们可以自行下载:https://github.com/fenglily1/student. 有问题可以留言或私信,我看到就会回. 进阶版加上页面的管理系统在 ...

  6. JavaWeb之简单的学生信息管理系统(二)

    JavaWeb之简单的学生信息管理系统(一) JavaWeb之简单的学生信息管理系统(二) JavaWeb之简单的学生信息管理系统(三) 今日任务:实现学生管理系统的查找和添加功能! 一. 查询学生信 ...

  7. java实现简单的学生信息管理系统

    java实现简单的学生信息管理系统(无界面) 学生类实体: package com.edu.imau.wcy;public class Stu {private String stuNum;//学号p ...

  8. php编写一个学生类_PHP实现简单的学生信息管理系统(web版)

    (∩_∩) 1.概述 学了php的一些基础,包括HTML,php,pdo,mysql操作等,一直都没有将它们有机结合.最近写了一个简单的网页版学生信息管理系统,前台用HTML,脚本用到了JavaScr ...

  9. php学籍信息管理系统心得_PHP实现简单的学生信息管理系统(web版)

    (∩_∩) 1.概述 学了php的一些基础,包括HTML,php,pdo,mysql操作等,一直都没有将它们有机结合.最近写了一个简单的网页版学生信息管理系统,前台用HTML,脚本用到了JavaScr ...

最新文章

  1. 基于SSM实现的图书馆管理系统
  2. 【VB6笔记-01】 读取Excel绑定到DataGrid
  3. 成功修改fastreport3.15,使其支持中日韩四(CJK)中编码PDF的导出
  4. 使用连接来代替in和not in(使用外连接技巧)
  5. dynamodb java_使用Java第2部分查询DynamoDB项
  6. 用例设计:思维导图orExcel
  7. android-x86 镜像iso下载_2019年微软MSDN原版镜像系统下载地址 Win10/7原版系统iso镜像文件...
  8. 让SH/BAT脚本定位到运行目录的相对位置,实现其脚本可在任意运行目录下被正确执行...
  9. pandas dataframe随机采样
  10. python为什么难_为什么python这么难
  11. 2个月面了鹅厂的5个部门,心态差点奔溃了......
  12. 计算机毕业设计Java美发门店管理系统(源码+系统+mysql数据库+lW文档)
  13. BibTex中参考文献种类
  14. transforms常用函数简介
  15. pytorch中的膨胀卷积
  16. SQL查询JSON格式的字段值 JSON_UNQUOTE与JSON_EXTRACT 去除SQL中双引号
  17. 技术人员如何做晋升答辩
  18. 事件分发机制怎么回答,不断提升自己创造溢价的能力,附带学习经验
  19. MARC21与CNMARC对应关系
  20. 南方人,在北京,夏秋冬

热门文章

  1. diff.js使用指南
  2. kurento代码分析(二)rtp流的处理
  3. LNK2019 unresolved external symbol symbol referenced in function
  4. 2021模拟高考考试成绩查询,2021年第一次模拟考试成绩查询
  5. 支付宝支付 - 申请APP支付
  6. Jetpack-ViewModel
  7. PHP与HTML交互
  8. [Unity安卓开发]Unity3D Gradle基础
  9. 转载:本地项目上传至git码云步骤(超详细,附图文)
  10. 不同种类的网络的特点