Download presentation
Presentation is loading. Please wait.
1
Android Programming Lecture 7
Testing notes Data Persistence
2
What is Persistence? Persistence is “the continuance of an effect after its cause is removed”. In the context of storing data in a computer system, this means that the data survives after the process with which it was created has ended. In other words, for a data store to be considered persistent, it must write to non- volatile storage.
3
Saving Data in Android App data is private to the application
Internal Storage: Store data on the device memory temporarily Shared Preferences: Lightweight mechanism to store private primitive data in key-value pairs in hard drive File: Open and save files on the device or removable storage SQLite Database: Store structured data in a private database Network Connection: Store data on the web Content provider is used to give the data to other apps
4
Passing Temporal Data using Intent
Activity 1 Intent intent = new Intent(Activity1.this, Activity2.class); Bundle data = new Bundle(); data.putString("key_name", "name"); data.putString("key_age", "age"); intent.putExtras(data); intent.putExtra("key_id", "id"); intent.putExtra("key_address", "address"); startActivity(intent); Intent Activity 2 // In Activity2.java // Retrieve the intent Intent intent = getIntent(); // Retrieve the string data in the intent String name = intent.getStringExtra("key_name"); String age = intent.getStringExtra("key_age"); String id = intent.getStringExtra("key_id"); String address = intent.getStringExtra("key_address");
5
Data Persistence in Orientation
When screen rotation is changed, the activity is destroyed and opened again How to store state information Store state: – onSaveInstanceState(Bundle) Read state: – onRestoreInstanceState(Bundle) This will store data only temporarily for app lifetime! Data will be held in memory until the app is closed! Refer to the Android Developer Site:
6
Saving Data in Android Internal Storage Shared Preferences File
SQLite Database Network Connection
7
Shared Preferences The SharedPreferences interface (in package android.content) provides a general framework that allows you to save and retrieve persistent key-value pairs of primitive data types and strings. similar to saving data in a Bundle Can be used to save the following data types Boolean – float int – long String − Set<String> Shared preference data will persist across user sessions even if the application is killed.
8
public class Example extends Activity {
// Create a preference file with the name specified public static final String PREFS_NAME = "MyPrefsFile"; @Override protected void onCreate(Bundle state){ super.onCreate(state); . . . // Restore the preferences // Get the preference with the name specified SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0); // Read the stored data from the preference int data = settings.getInt(“key", defaultValue); } protected void onStop(){ super.onStop(); // Store the preferences // We need an Editor object to make preference changes. SharedPreferences.Editor editor = settings.edit(); editor.putInt(“key”, value); // Commit the edits! editor.commit();
9
Overview of Shared Preferences
Examples of data stored in shared preferences: user name – password address – high score An application can have multiple sets of application preferences, where each set has a name. Preferences can be stored at the activity level or the application level. In general, they are not shared outside the application. Application preferences are stored in XML files in the Android file system as follows: /data/data/<package name>/shared_prefs/<pref filename>.xml
10
Obtaining a SharedPreferences Object
Two methods that return a SharedPreferences object: getSharedPreferences(String name, int mode) Use if you need multiple preferences files identified by name. Name is specified as the first parameter. If a preferences file by this name does not exist, it will be created when you retrieve an editor. Preferences can be accessed by all activities in the application. getPreferences(int mode) Use if you need only one preferences file for your Activity. Only one preferences file for an Activity – don't supply a name. Calls method getSharedPreferences(String, int) passing in this activity’s class name as the preferences name. Preferences are not shared with other activities in the application.
11
Shared Preference Modes
getSharedPreferences(String name, int mode) getPreferences(int mode) Context.MODE_PRIVATE (or 0) created file can be accessed only by the calling application generally the only preference mode that you should use Context.MODE_WORLD_READABLE (or 1, deprecated in API level 17) other applications have read access to the created file Context.MODE_WORLD_WRITEABLE (or 2, deprecated in API level 17) other applications have write access to the created file Context Class Reference:
12
Writing Shared Preferences
To write shared preference values: Call edit() to get a SharedPreferences.Editor. Add values with editor “put” methods such as putBoolean() and putString(). Commit the new values with apply() or commit(). // Store the preferences // We need an Editor object to make preference changes. SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0); SharedPreferences.Editor editor = settings.edit(); editor.putInt(“key”, value); // Commit the edits! editor.commit();
13
Reading Shared Preferences
To read shared preference values: Use SharedPreferences “get” methods such as getBoolean(String key, boolean defValue) and getString(String key, String defValue). The “get” methods have two parameters key: the preference key string defValue: a default value to return if the preference is undefined // Restore the preferences // Get the preference with the name specified SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0); // Read the stored data from the preference int data = settings.getInt(“key", defaultValue);
14
Selected Methods for Retrieving Shared Preferences
// in interface SharedPreferences boolean getBoolean(String key, boolean defValue) float getFloat(String key, float defValue) int getInt(String key, int defValue) long getLong(String key, long defValue) String getString(String key, String defValue) Set<String> getStringSet(String key, Set<String> defValues) SharedPreferences Class References:
15
Selected Methods for Saving Shared Preferences
// in interface SharedPreferences.Editor void apply() boolean commit() SharedPreferences.Editor putBoolean(String key, boolean value) SharedPreferences.Editor putFloat(String key, float value) SharedPreferences.Editor putInt(String key, int value) SharedPreferences.Editor putLong(String key, long value) SharedPreferences.Editor putString(String key, String value) SharedPreferences.Editor putStringSet(String key, Set<String> values) SharedPreferences.Editor remove(String key) SharedPreferences Class References:
16
Differences Between Methods apply() and commit()
boolean commit() Returns a boolean value to indicate if the new values were successfully written to persistent storage. Writes its preferences out to persistent storage synchronously (can block the UI thread) void apply() Commits its changes to the in-memory SharedPreferences immediately but starts an asynchronous commit to disk. does not block the UI thread, but you won’t be notified of any failures. Use apply() if you don't care about the return value and you’re using this from your application’s UI thread.
17
public class Example extends Activity {
// Create a preference file with the name specified public static final String PREFS_NAME = "MyPrefsFile"; @Override protected void onCreate(Bundle state){ super.onCreate(state); . . . // Restore the preferences // Get the preference with the name specified SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0); // Read the stored data from the preference int data = settings.getInt(“key", defaultValue); } protected void onStop(){ super.onStop(); // Store the preferences // We need an Editor object to make preference changes. SharedPreferences.Editor editor = settings.edit(); editor.putInt(“key”, value); // Commit the edits! editor.commit();
18
Android Debugging ADB (Android Debug Bridge)
A versatile command line tool that lets you communicate with an emulator instance or connected Android-powered device You can find the adb tool in <sdk>/platform-tools Device management, moving and syncing files to the emulator (or device), running a UNIX shell on the device or emulator, interacting with SQLite database for an application. Dalvik Debug Monitor Server (DDMS) Graphical program that communicates with your devices through the ADB. Capture screenshots, gather thread and stack information, monitor heap, spoof incoming calls and SMS messages, etc. Intro to ADB:
19
Saving Data in Android Internal Storage Shared Preferences File
SQLite Database Network Connection
20
Storage Internal storage − for private data
By default, files saved to the internal storage are private to your application and other applications cannot access them. When the user uninstalls an application, files and directories created by that application in internal storage are removed. External storage − for public shared data Every Android-compatible device supports a shared “external storage” that can be used to save files. External storage can be a removable storage media (such as an SD card) an internal (non-removable) storage. Files saved to the external storage are world-readable and can be modified by the user when they enable USB mass storage to transfer files on a computer. Saving Files:
21
// Write String FILENAME = “custom_file.txt"; String fileContent = “This is a test!"; // Create a file to write // Two parameters are passed, file name and mode FileOutputStream fos = openFileOutput(FILENAME, Context.MODE_PRIVATE); fos.write(fileContent.getBytes()); fos.close(); // Read FileInputStream fis = openFileInput(FILENAME); int byteChar; while((byteChar = fis.read()) != -1) { System.out.println((char) byteChar); } fis.close()
22
Using Java I/O for Data Storage
The standard Java I/O capabilities provided in package java.io can be used to read and write data files on an Android device’s internal and external storage. Android provides several helper methods inherited from android.content.Context that can be used access files on the device. Application files are saved in the folder /data/data/<package name>/files DDMS can be used to explore a device’s file system and to transfer files between a computer and an Android device.
23
Get Access to External Storage
In order to read or write files on the external storage, your app must acquire the READ_EXTERNAL_STORAGE or WRITE_EXTERNAL_STORAGE system permissions. For example <manifest ...> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> </manifest>
24
Helper Methods Inherited From android.content.Context
FileInputStream openFileInput(String name) Open a private file for reading. FileOutputStream openFileOutput(String name, int mode) Open a private file for writing or appending. File getFilesDir() Get the absolute path to the file system directory where your internal files are saved (i.e., returns a File object for /data/data/<package name>/files/). File getDir(String name, int mode) Create (or open an existing) directory within your internal storage space.
25
Helper Methods Inherited From android.content.Context
boolean deleteFile(String name) Delete the given private file associated with this application. Returns true if the file was successfully deleted; otherwise returns false. String[] fileList() Returns an array of strings naming the private files associated with this application.
26
File Modes FileOutputStream openFileOutput(String name, int mode)
(Open a private file for writing or appending.) Selected file modes from android.content.Context MODE_APPEND If the file already exists, then write data to the end of the existing file instead of erasing it. MODE_PRIVATE Created file can only be accessed by the calling application (default mode). MODE_WORLD_READABLE (deprecated in API level 17) Allow all other applications read access to the created file. MODE_WORLD_WRITEABLE (deprecated in API level 17) Allow all other applications write access to the created file.
27
Saving Data in Android Internal Storage Shared Preferences File
SQLite Database Network Connection
28
SQLite SQLite is a software library that implements a lightweight SQL database engine. SQLite is the most widely deployed SQL database engine in the world. SQLite is an Open Source Database which is embedded into Android. SQLite is available on every Android device, does not require any database setup or administration. You only have to define the SQL statements for creating and updating the database.
29
SQLite SQLite has the following features: Database-in-a-file
Self-contained Serverless Zero-configuration Concurrent access Open source
30
Intro to Database What is a database? An organized collection of data
Database Operations Insert, delete, query, update data in database ID Name Score 1 Tom 2000s 2 Jerry 100s 3 David 20s Integer Text (String) Integer Data Type
31
Table The data stored in database objects are called tables
Every table is broken up into smaller entities called fields The table is a collection of related data entries and it consists of columns and rows. | ID | NAME | AGE | ADDRESS | SALARY | | 1 | Ramesh | 32 | Ahmedabad | | | 2 | Khilan | 25 | Delhi | | | 3 | kaushik | 23 | Kota | | | 4 | Chaitali | 25 | Mumbai | | | 5 | Hardik | 27 | Bhopal | | | 6 | Komal | 22 | MP | | | 7 | Muffy | 24 | Indore | | | ADDRESS | | Ahmedabad | | Delhi | | Kota | | Mumbai | | Bhopal | | MP | | Indore | | 5 | Hardik | 27 | Bhopal | |
32
SQL Syntax: Create a Table
CREATE TABLE table_name( column1 datatype, column2 datatype, column3 datatype, ..... columnN datatype, PRIMARY KEY( one or more columns ) ); CREATE TABLE CUSTOMERS( ID INT NOT NULL, NAME VARCHAR (20) NOT NULL, AGE INT NOT NULL, ADDRESS CHAR (25) , SALARY DECIMAL (18, 2), PRIMARY KEY (ID) ); | Field | Type | Null | Key | Default | Extra | | ID | int(11) | NO | PRI | | | | NAME | varchar(20) | NO | | | | | AGE | int(11) | NO | | | | | ADDRESS | char(25) | YES | | NULL | | | SALARY | decimal(18,2) | YES | | NULL | |
33
WHERE Clause SELECT column1, column2, columnN FROM table_name
CUSTOMERS table | ID | NAME | AGE | ADDRESS | SALARY | | 1 | Ramesh | 32 | Ahmedabad | | | 2 | Khilan | 25 | Delhi | | | 3 | kaushik | 23 | Kota | | | 4 | Chaitali | 25 | Mumbai | | | 5 | Hardik | 27 | Bhopal | | | 6 | Komal | 22 | MP | | | 7 | Muffy | 24 | Indore | | SELECT column1, column2, columnN FROM table_name WHERE [condition] Fetch ID, Name and Salary fields from the CUSTOMERS table where salary is greater than 2000: | ID | NAME | SALARY | | 4 | Chaitali | | | 5 | Hardik | | | 6 | Komal | | | 7 | Muffy | | SELECT ID, NAME, SALARY FROM CUSTOMERS WHERE SALARY > 2000; Fetch ID, Name and Salary fields from the CUSTOMERS table for a customer with name Hardik | ID | NAME | SALARY | | 5 | Hardik | | SELECT ID, NAME, SALARY FROM CUSTOMERS WHERE NAME = 'Hardik';
34
SQLiteDatabase Class Exposes methods to manage a SQLite database.
SQLiteDatabase has methods to create, delete, execute SQL commands, and perform other common database management tasks. void execSQL(String sql): Execute a single SQL statement that is NOT a SELECT or any other SQL statement that returns data Cursor query(...): Query the given table, returning a Cursor over the result set
35
Example SQL Syntax: Android: CREATE TABLE CUSTOMERS(
ID INT NOT NULL, NAME VARCHAR (20) NOT NULL, AGE INT NOT NULL, ADDRESS CHAR (25) , SALARY DECIMAL (18, 2), PRIMARY KEY (ID) ); void execSQL(“ CREATE TABLE CUSTOMERS( ID INT NOT NULL, NAME VARCHAR (20) NOT NULL, AGE INT NOT NULL, ADDRESS CHAR (25) , SALARY DECIMAL (18, 2), PRIMARY KEY (ID) )”): | Field | Type | Null | Key | Default | Extra | | ID | int(11) | NO | PRI | | | | NAME | varchar(20) | NO | | | | | AGE | int(11) | NO | | | | | ADDRESS | char(25) | YES | | NULL | | | SALARY | decimal(18,2) | YES | | NULL | |
36
Class SQLiteOpenHelper
Class SQLiteOpenHelper is an abstract helper class in package android.database.sqlite that can be used to manage database creation and versioning. Class SQLiteOpenHelper will open the database if it exists create the database if it does not exist upgrade the database as necessary To use class SQLiteOpenHelper, create a subclass that overrides abstract methods onCreate(), onUpgrade(). Note: Database names must be unique within an application, not across all applications.
37
Selected Methods in Class SQLiteOpenHelper
SQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) constructor to initialize a SQLiteOpenHelper object the factory parameter can be null for the default value void close() close an open database SQLiteDatabase getReadableDatabase() create and/or open a database for reading only SQLiteDatabase getWritableDatabase() create and/or open a database for both reading and writing
38
Selected Methods in Class SQLiteOpenHelper
abstract void onCreate(SQLiteDatabase db) called when the database is created for the first time Note: You can “preload” a set of database values in this method. void onOpen(SQLiteDatabase db) called when the database is opened abstract void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) called when the database needs to be upgraded
40
Class SQLiteDatabase Class SQLiteDatabase (in package android.database.sqlite) exposes methods to manage a SQLite database. Class SQLiteDatabase has methods to create, delete, execute SQL commands, and to perform other common database management tasks. Class SQLiteDatabase has several “convenience” methods for constructing SQL queries, inserts, etc. Alternatively, other methods can be used to directly execute SQL commands passed as string parameters.
41
Selected Methods in Class SQLiteDatabase
void beginTransaction() Begins a transaction. int delete(String table, String whereClause, String[] whereArgs) Convenience method for deleting rows in the database. void endTransaction() End a transaction. void execSQL(String sql) Execute a single SQL statement that does not return data. long insert(String table, String nullColumnHack, ContentValues values) Convenience method for inserting a row into the database.
42
Selected Methods in Class SQLiteDatabase
Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy) Query the given table, returning a Cursor over the result set. Cursor rawQuery(String sql, String[] selectionArgs) Runs the provided SQL and returns a Cursor over the result set. int update(String table, ContentValues values, String whereClause, String[] whereArgs) Convenience method for updating rows in the database.
43
Insert Data to a Database
44
Interface Cursor Interface Cursor (in package android.database) is used to iterate over the rows returned by a “select” query. Interface Cursor provides random read-write access to the result set returned by a database query. Methods in interface Cursor can be used to position the cursor within the result set (“move” methods) to retrieve column values from the row (“get” methods) to provide metadata about the query (e.g., getColumnNames()).
45
Selected Methods in Interface Cursor
int getColumnIndex(String columnName) Returns zero-based index for the given column name double getDouble(int columnIndex) int getInt(int columnIndex) long getLong(int columnIndex) String getString(int columnIndex) boolean move(int offset) boolean moveToFirst() boolean moveToNext() boolean moveToPosition(int position) Returns the value of the requested column as the specified type. Moves the cursor as specified.
46
Using a Cursor Initially a cursor is positioned before the first row. The various “move” methods can be used to move the cursor to a row. The moveToNext() method moves the cursor to the next row. Since it returns false when there are no more rows, it can be used in a while loop to iterate through the rows of a cursor. Example while (cursor.moveToNext()) { ... // retrieve/process data for one row } Cursor
47
Query Table
48
Cursor Cursor Cursor Cursor Cursor Cursor Cursor
49
Summary What is purpose of data persistence?
Why would the data persistence be an issue when user changes the orientation in the app? What can SharedPreferences class do? How to write data into an SharedPreferences object? How to read data from an SharedPreferences object? What is the usage of SQLiteOpenHelper class?
50
Video Tutorial Android Studio Tutorial for Beginners (Step by Step tutorial) bb1cYyzZpLFCKvdYV_yJ-E Topics on Android SQLite Database Tutorial
51
Reference Android Programming: The Big Nerd Ranch Guide
Chapter 14 (available on Safari Books Online) Vogella tutorial: Android SQLite database and content provider Android developer site: Save Data Data Storage Class SQLiteDatabase Class SQLiteOpenHelper
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.