SQLLite and Java CS-328 Dick Steflik. SQLLite Embedded RDBMS ACID Compliant Size – about 257 Kbytes Not a client/server architecture –Accessed via function.

Slides:



Advertisements
Similar presentations
Programming with Android: Data management
Advertisements

Bruce Scharlau, University of Aberdeen, 2012 Data storage options for mobiles Mobile Computing.
SQLite. Command line sqlite3 The command line sqlite3 is not installed on all devices To install, get sqlite3 from web page, and $ adb push sqlite3 /sdcard/
CE881: Mobile and Social Application Programming Flexible Data Handling with Integrity: SQLite Simon M. Lucas.
SQLite is a software library. It is: self-contained + Serverless + zero-configuration transactional = SQL database engine. Most widely deployed. The source.
SQLite in Mobile Apps by Dan Youberg. Overview Many well known applications and Internet browsers use SQLite due to its very small size (~250 Kb). Also.
CONTENT PROVIDER. Content Provider  A content provider makes a specific set of the application's data available to other applications => Share data to.
Cosc 5/4730 Android and Blackberry SQLite. For the sql language syntax, please see SQlite documentation –
SQLite 1 CS440. What is SQLite?  Open Source Database embedded in Android  SQL syntax  Requires small memory at runtime (250 Kbytes)  Lightweight.
Phonegap Bridge – File System CIS 136 Building Mobile Apps 1.
CS378 - Mobile Computing Persistence - SQLite. Databases RDBMS – relational data base management system Relational databases introduced by E. F. Codd.
The Java Persistence API Edel Sherratt. Contents Revisit applications programming Using Java Persistence API.
Data Persistence in Android
SQLite Database. SQLite Public domain database – Advantages Small (about 150 KB) – Used on devices with limited resources Each database contained within.
Advance Computer Programming Java Database Connectivity (JDBC) – In order to connect a Java application to a database, you need to use a JDBC driver. –
Database Rung-Hung Gau Department of Computer Science and Engineering
Data Storage: Part 3 (SQLite)
Data Storage: Part 4 (Content Providers). Content Providers Content providers allow the sharing of data between applications. Inter-process communication.
COMP 365 Android Development.  Manages access from a central database  Allows multiple applications to access the same data.
Stored Procedures, Triggers, Program Access Dr Lisa Ball 2008.
SQLite Android Club SQLite About onCreate Insert Select Update Delete onUpdate.
Creating and using Persistent Data From before – Where does the data come from? – Why is it kept? – How is it used? Affects design and implementation choices.
Android Storage. There are several options for storage of data with Android We can put data into a preferences file. We can put data into a ‘normal’ file.
Address Book App 1. Define styles   Specify a background for a TextView – res/drawable/textview_border.xml.
9 Persistence - SQLite CSNB544 Mobile Application Development Thanks to Utexas Austin.
Programmatic SQL Shaista Khan CS 157B. Topic Embedded SQL statements in high-level programming languages.
CS499 Project #3 XML mySQL Test Generation Members Erica Wade Kevin Hardison Sameer Patwa Yi Lu.
Persistence Dr. David Janzen Except as otherwise noted, the content of this presentation is licensed under the Creative Commons Attribution 2.5 License.
Mobile Software Development ISCG 7424 Department of Computing UNITEC John Casey and Richard Rabeder SQLite and Permissions.
SQLite DB Storing Data in Android RAVI GAURAV PANDEY 1.
Android - SQLite Database 12/10/2015. Introduction SQLite is a opensource SQL database that stores data to a text file on a device. Android comes in with.
SQlite. SQLite is a opensource SQL database that stores data to a text file on a device. Android comes in with built in SQLite database implementation.
CP476 Internet Computing Perl CGI and MySql 1 Relational Databases –A database is a collection of data organized to allow relatively easy access for retrievals,
1 Principles of Database Systems With Internet and Java Applications Today’s Topic Chapter 8: Applications Programming for Relational Databases Instructor’s.
1 JDBC – Java Database Connectivity CS , Spring 2010.
SQL pepper. Why SQL File I/O is a great deal of code Optimal file organization and indexing is critical and a great deal of code and theory implementation.
Address Book App 1 Fall 2014 CS7020: Game Design and Development.
CS 440 Database Management Systems Stored procedures & OR mapping 1.
CHAPTER 9 File Storage Shared Preferences SQLite.
Android Storage MAY 2013 Hu.Cai. NAME OF PRESENTATION [CHANGE IN SLIDE MASTER] MONTH, YEAR [CHANGE IN SLIDE MASTER] Outline 1.Storage In General 2.SharedPreferences.
By: Eliav Menachi.  On Android, all application data (including files) are private to that application  Android provides a standard way for an application.
CMPE419 Mobile Application Development Asst.Prof.Dr.Ahmet Ünveren SPRING Computer Engineering Department Asst.Prof.Dr.Ahmet Ünveren
Introduction to Database Programming with Python Gary Stewart
Data Storage in Android Димитър Н. Димитров. Why talk about data? Why not 3D graphics or network connectivity? Data as fundamental term in computer science.
Making content providers
Data Storage: Part 3 (SQLite)
Database: JDBC Overview
Cosc 5/4730 Sqlite primer.
Mobile Applications (Android Programming)
SQL – Python and Databases
SQLite in Android Landon Cox March 2, 2017.
Mobile Software Development for Android - I397
Mobile Application Development BSCS-7 Lecture # 18, 19
CIS 136 Building Mobile Apps
Mobile Applications (Android Programming)
Android Application SQLite 1.
Reactive Android Development
Database JDBC Overview CS Programming Languages for Web Applications
Mobile Computing With Android ACST Android Database Storage Part 2
Client Access, Queries, Stored Procedures, JDBC
CMPE419 Mobile Application Development
CIS 136 Building Mobile Apps
CMPE419 Mobile Application Development
Mobile Computing With Android ACST 4550 Android Database Storage
Android Developer Fundamentals V2
ListView A view that shows items in a vertically scrolling list. The items come from the ListAdapter associated with this view. ListAdapter is used to.
Department of School of Computing and Engineering
SQLLite and Android.
Mobile Programming Dr. Mohsin Ali Memon.
JDBC II IS
Presentation transcript:

SQLLite and Java CS-328 Dick Steflik

SQLLite Embedded RDBMS ACID Compliant Size – about 257 Kbytes Not a client/server architecture –Accessed via function calls from the application Writing (insert, update, delete) locks the database, queries can be done in parallel

SQLLite Datastore – single, cross platform file (kinda like an MS Access DB) –Definitions –Tables –Indicies –Data

SQLite Data Types This is quite different than the normal SQL data types so please read:

Storage classes NULL – null value INTEGER - signed integer, stored in 1, 2, 3, 4, 6, or 8 bytes depending on the magnitude of the value REAL - a floating point value, 8-byte IEEE floating point number. TEXT - text string, stored using the database encoding (UTF-8, UTF-16BE or UTF-16LE). BLOB. The value is a blob of data, stored exactly as it was input.

android.database.sqlite Contains the SQLite database management classes that an application would use to manage its own private database.

android.database.sqlite - Classes SQLiteCloseable - An object created from a SQLiteDatabase that can be closed. SQLiteCursor - A Cursor implementation that exposes results from a query on a SQLiteDatabase. SQLiteDatabase - Exposes methods to manage a SQLite database. SQLiteOpenHelper - A helper class to manage database creation and version management. SQLiteProgram - A base class for compiled SQLite programs. SQLiteQuery - A SQLite program that represents a query that reads the resulting rows into a CursorWindow. SQLiteQueryBuilder - a convenience class that helps build SQL queries to be sent to SQLiteDatabase objects. SQLiteStatement - A pre-compiled statement against a SQLiteDatabase that can be reused.

android.database.sqlite.SQLiteDatabase Contains the methods for: creating, opening, closing, inserting, updating, deleting and quering an SQLite database These methods are similar to JDBC but more method oriented than what we see with JDBC (remember there is not a RDBMS server running)

openOrCreateDatabase( ) This method will open an existing database or create one in the application data area import android.database.sqlite.SQLiteDatabase; SQLiteDatabase myDatabase; myDatabase = openOrCreateDatabase ("my_sqlite_database.db", SQLiteDatabase.CREATE_IF_NECESSARY, null);

SQLite Database Properties Important database configuration options include: version, locale, and thread-safe locking. import java.util.Locale; myDatabase.setVersion(1); myDatabase.setLockingEnabled(true); myDatabase.SetLocale(Locale.getDefault());

Creating Tables Create a static string containing the SQLite CREATE statement, use the execSQL( ) method to execute it. String createAuthor = "CREAT TABLE authors ( id INTEGER PRIMARY KEY AUTOINCREMENT, fname TEXT, lname TEXT); myDatabase.execSQL(createAuthor);

insert( ) long insert(String table, String nullColumnHack, ContentValues values) import android.content.ContentValues; ContentValues values = new ContentValues( ); values.put("firstname", "J.K."); values.put("lastname", "Rowling"); long newAuthorID = myDatabase.insert("tbl_authors", "", values);

update( ) int update(String table, ContentValues values, String whereClause, String[ ] whereArgs ) public void updateBookTitle(Integer bookId, String newTitle) { ContentValues values = new ContentValues(); values.put("title", newTitle); myDatabase.update("tbl_books", values, "id=?", new String[ ] {bookId.toString() } ); }

delete( ) int delete(String table, String whereClause, String[] whereArgs) public void deleteBook(Integer bookId) { myDatabase.delete("tbl_books", "id=?", new String[ ] { bookId.toString( ) } ) ; }

android.database ackage-summary.htmlhttp://developer.android.com/reference/android/database/p ackage-summary.html Contains classes and interfaces to explore data returned through a content provider. The main thing you are going to use here is the Cursor interface to get the data from the resultset that is returned by a query

Queries Method of SQLiteDatabase class and performs queries on the DB and returns the results in a Cursor object Cursor c = mdb.query(p1,p2,p3,p4,p5,p6,p7) –p1 ; Table name (String) –p2 ; Columns to return (String array) –p3 ; WHERE clause (use null for all, ?s for selection args) –p4 ; selection arg values for ?s of WHERE clause –p5 ; GROUP BY ( null for none) (String) –p6 ; HAVING (null unless GROUP BY requires one) (String) –p7 ; ORDER BY (null for default ordering)(String) –p8 ; LIMIT (null for no limit) (String)

Simple Queries SQL - "SELECT * FROM ABC;" SQLite - Cursor c = mdb.query(abc,null,null,null,null,null,null); SQL - "SELECT * FROM ABC WHERE C1=5" SQLite - Cursor c = mdb.query( abc,null,"c1=?", new String[ ] {"5"},null,null,null); SQL – "SELECT title,id FROM BOOKS ORDER BY title ASC" SQLite – String colsToReturn [ ] {"title","id"}; String sortOrder = "title ASC"; Cursor c = mdb.query("books",colsToReturn, null,null,null,null,sortOrder);

Tutorial Here is a good tutorial: