Android 开发(13)数据存储技术

2024-01-31 20:48

本文主要是介绍Android 开发(13)数据存储技术,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、shared preferences存储

1、SP存取数据

写数据

在这里插入图片描述

读数据

在这里插入图片描述

2、QQ自动登录实现

public class MainActivity extends AppCompatActivity {private EditText editText1, editText2;private Button button;private String username = "stan", password = "stan123";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);editText1 = (EditText) findViewById(R.id.et1);editText2 = (EditText) findViewById(R.id.et2);button = (Button) findViewById(R.id.btn);final SharedPreferences sp = getSharedPreferences("stan", MODE_PRIVATE);String user = sp.getString("user", null);String pass = sp.getString("pass", null);if (user != null && pass != null) {if (user.equals(username) && pass.equals(password)) {Intent intent = new Intent(MainActivity.this, DetailActivity.class);startActivity(intent);}} else {button.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String username_in = editText1.getText().toString();String password_in = editText2.getText().toString();if (!(username_in == null) && !(password_in == null)) {if (username_in.equals(username) && password_in.equals(password)) {SharedPreferences.Editor editor = sp.edit();editor.putString("user", username_in);editor.putString("pass", password_in);editor.commit();Intent intent = new Intent(MainActivity.this, DetailActivity.class);startActivity(intent);} else {Toast.makeText(MainActivity.this, "用户名或者密码错误", Toast.LENGTH_SHORT).show();}} else {Toast.makeText(MainActivity.this, "用户名或者密码为空", Toast.LENGTH_SHORT).show();}}});}}
}

sharedPreferences 最终将数据保存在一个 xml 文件中,这个文件所在的位置是 data>data>包名>shared_prefs


二、文件存储

  • 这里的外部存储和内部存储不是指内置存储和SD的卡的差异

1、内部存储

在这里插入图片描述

简易备忘录的实现
public class MainActivity extends AppCompatActivity {private ImageButton btn_cancel, btn_save;private EditText editText;private FileInputStream fis;private FileOutputStream fos;private byte[] buffer;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);btn_cancel = (ImageButton) findViewById(R.id.cancel);btn_save = (ImageButton) findViewById(R.id.save);editText = (EditText) findViewById(R.id.et);btn_save.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {try {fos = openFileOutput("inner", MODE_PRIVATE);String text = editText.getText().toString();fos.write(text.getBytes());fos.flush();Toast.makeText(MainActivity.this, "文件已经保存", Toast.LENGTH_SHORT).show();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();} finally {if (fos != null) {try {fos.close();} catch (IOException e) {e.printStackTrace();}}}}});//open app to open filetry {fis = openFileInput("inner");buffer = new byte[fis.available()];fis.read(buffer);editText.setText(new String(buffer));} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();} finally {if (fis != null) {try {fis.close();} catch (IOException e) {e.printStackTrace();}}}btn_cancel.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {finish();}});}
}

2、外部存储

  • 简单来说我们的手机连接电脑,在电脑上能够查看的部分就是外部存储
  • 上面的备忘录实例将获取输入和输出流的部分改为直接新建一个相应的FOS或者FIS对象并指定相应的File文件就可以了
关键代码
  • 记得要在 manifest 里面开启权限
final File file = new File(Environment.getExternalStorageDirectory(),"stan.txt");
fos = new FileOutputStream(file);
fis = new FileInputStream(file);

三、数据库存储

1、关于SQLite数据库

基本特点

在这里插入图片描述

使用
  • 总的来说和其他的数据库的使用基本上是大同小异
  • 使用前需要在 adb shell 的命令行创建数据库的目录和文件,使用SDK中提供的adb工具
  • 创建好目录和文件之后可以使用 sqlite3 databasename进入sqlite 数据库进行操作
  • 利用SDK提供的sqlite3.exe 工具也可以直接连接数据库操作
  • 关于命令:.exit退出数据库.tables查看当前数据库的数据表
  • 数据表的创建和查询基本就是sql了,没啥可说
  • 注意:创建数据库文件的时候先要进入数据库的目录

2、使用代码操作SQLite数据库

简易的字典的实现
  • Mainactivity代码
public class MainActivity extends AppCompatActivity {private ImageButton btn_search, btn_add;private EditText text_search;private ListView word_list;private DBhelper dBhelper;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);btn_add = (ImageButton) findViewById(R.id.btn_add);btn_search = (ImageButton) findViewById(R.id.btn_search);text_search = (EditText) findViewById(R.id.word_search);word_list = (ListView) findViewById(R.id.display_word);dBhelper = new DBhelper(this, "dict.db", null, 1);btn_search.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String searchWord = text_search.getText().toString().trim();Cursor cursor = dBhelper.getReadableDatabase().query("word_dict", null, "word=?", new String[]{searchWord}, null, null, null);ArrayList<HashMap<String, String>> resList = new ArrayList<>();while (cursor.moveToNext()) {String word = cursor.getString(1);String detail = cursor.getString(2);HashMap<String, String> map = new HashMap<>();map.put("word", word);map.put("detail", detail);resList.add(map);}if (resList != null && resList.size() != 0) {SimpleAdapter adapter = new SimpleAdapter(MainActivity.this, resList, R.layout.result_main,new String[]{"word", "detail"}, new int[]{R.id.list_word, R.id.list_detail});word_list.setAdapter(adapter);} else {Toast.makeText(MainActivity.this, "查询的单词不存在", Toast.LENGTH_SHORT).show();}}});btn_add.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this, AddActivity.class);startActivity(intent);}});}}
  • 添加单词activity
public class AddActivity extends AppCompatActivity {private ImageButton btn_save, btn_cancel;private EditText word, detail;private DBhelper dBhelper;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_add);btn_cancel = (ImageButton) findViewById(R.id.add_cancel);btn_save = (ImageButton) findViewById(R.id.add_save);word = (EditText) findViewById(R.id.add_word);detail = (EditText) findViewById(R.id.add_detail);dBhelper = new DBhelper(this, "dict.db", null, 1);btn_cancel.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {finish();}});btn_save.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String word_text = word.getText().toString();String detail_text = detail.getText().toString();if (!word_text.equals("") && !detail_text.equals("")) {ContentValues values = new ContentValues();values.put("word", word_text);values.put("detail", detail_text);dBhelper.getReadableDatabase().insert("word_dict", null, values);Toast.makeText(AddActivity.this, "单词添加成功", Toast.LENGTH_SHORT).show();} else {Toast.makeText(AddActivity.this, "输入的单词或释义为空", Toast.LENGTH_SHORT).show();}}});}
}
  • 帮助类
public class DBhelper extends SQLiteOpenHelper {private final static String CREATE = "create table word_dict(_id integer primary key autoincrement,word text,detail text)";public DBhelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {super(context, name, factory, version);}@Overridepublic void onCreate(SQLiteDatabase db) {db.execSQL(CREATE);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {Log.i("upgrade", "版本升级" + oldVersion + "--->" + newVersion);}
}

四、数据共享

1、基本原理

  • 本质就是 ContentResolver 来作为应用之间媒介,进行数据信息的分享
  • 这里面通过URI定位我们需要共享的数据,数据的结构就是表格的形式,增删改查的操作和操作数据库很相似
    在这里插入图片描述

2、读取系统的电话本数据

public class MainActivity extends AppCompatActivity {private final static String DISPLAY_NAME = ContactsContract.Contacts.DISPLAY_NAME;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);TextView editText = (TextView) findViewById(R.id.et);editText.setText(getQueryData());}private String getQueryData() {ContentResolver resolver = getContentResolver();Cursor cursor = resolver.query(ContactsContract.Contacts.CONTENT_URI, null,null, null, null);StringBuilder builder = new StringBuilder();for (cursor.moveToFirst(); !cursor.isAfterLast(); cursor.moveToNext()) {int index = cursor.getColumnIndex(DISPLAY_NAME);builder.append(cursor.getString(index) + "\n");}return builder.toString();}
}

这篇关于Android 开发(13)数据存储技术的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/665015

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设