Diferencia entre revisiones de «Usuario:ManuelRomero/Android/BBDD»
De WikiEducator
(→SQLiteDatabase) |
|||
Línea 82: | Línea 82: | ||
#'''''openOrCreateDatabase'''' | #'''''openOrCreateDatabase'''' | ||
Los parámetros que se pueden pasar son los siguientes | Los parámetros que se pueden pasar son los siguientes | ||
− | # | + | #'''''String path''''' Es el path y nombre de la base de datos |
− | # | + | #'''''int flag''''' especifica el modo en el que se abre/crea la base de datos. Sus valores se pueden combinar e.j. OPEN_READWRITE|CREATE_IF_NECESSARY (Especificamos los dos modos). |
− | # | + | ##OPEN_READWRITE |
− | # | + | ##OPEN_READONLY |
− | # | + | ##CREATE_IF_NECESSARY |
+ | ##NO_LOCALIZED_COLLATORS. | ||
+ | #SQLLiteDatabase.CursorFactory factory | ||
+ | #DatabaseErrorHandler errorHandler | ||
+ | #File file | ||
+ | |||
+ | En realidad el uso de ambos métodos es similar con el hecho de que en el método '''''openOrCreateDatabase(...)''''' asumimos el flag '''''CREATE_IF_NECESSARY''''' | ||
+ | Ejemplo | ||
+ | <source lang=java> | ||
+ | package com.example.agenda; | ||
+ | |||
+ | import android.app.Activity; | ||
+ | import android.database.sqlite.SQLiteDatabase; | ||
+ | import android.widget.Toast; | ||
+ | |||
+ | public class Contactos extends Activity { | ||
+ | private static final String TAG = "bdagenda"; | ||
+ | private static final String DATABASE_PATH = "/data/data/com.example.agenda/databases/"; | ||
+ | private static final String DATABASE_NAME = "contactos.db"; | ||
+ | private String nombreBD=DATABASE_PATH+DATABASE_NAME; | ||
+ | |||
+ | private SQLiteDatabase baseDatos; | ||
+ | |||
+ | private String crearTablaContacto= "create table if not exists " | ||
+ | + " contacto (codigo integer primary key autoincrement, " | ||
+ | + " nombre text not null, telefono text not null unique);"; | ||
+ | |||
+ | @Override | ||
+ | public void onCreate(Bundle savedInstanceState) { | ||
+ | super.onCreate(savedInstanceState); | ||
+ | setContentView(R.layout.layout_contactos); | ||
+ | if (abrirBaseDatos()){ | ||
+ | Toast.makeText(this,"Base de datos Abierta ok!!",Toast.LENGTH_LONG).show(); | ||
+ | }else{ | ||
+ | Toast.makeText(this,"ERROR no se ha podido abrir la base de datos!!",Toast.LENGTH_LONG).show(); | ||
+ | } | ||
+ | } | ||
+ | |||
+ | //Procedimiento para abrir la base de datos | ||
+ | //si no existe se creará, también se creará la tabla contacto | ||
+ | |||
+ | private boolean abrirBaseDatos(){ | ||
+ | try{ | ||
+ | baseDatos = SQLiteDatabase.openOrCreateDatabase(nombreBD, null); | ||
+ | // baseDatos = openDatabase(nombreBD,null,SQLiteDatabase.CREATE_IF_NECESSARY); | ||
+ | baseDatos.execSQL(crearTablaContacto); | ||
+ | return true; | ||
+ | } | ||
+ | catch (Exception e){ | ||
+ | Log.i(TAG, "Error al abrir o crear la base de datos" + e); | ||
+ | return false; | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | |||
+ | |||
+ | </source> |
Revisión de 14:12 4 ene 2013
Trabajo en proceso, espera cambios frecuentes. Tu ayuda y retroalimentación son bienvenidos. Ver página de charlas. |
Introducción
- Android dentro del API tiene funcionalidad para gestionar una base de datos SQLite
- Esto hace que no requeramos ningún driver ni instalar un gestor de bases de datos adicional
- SQLite es un motor de bases de datos con una características especiales que le hacen muy atractivas para determinados entornos
- Maneja archivos de pequeño tamaño.
- Requiere poco espacio en tiempo de ejecución (250MB apx)
- no necesita un servidor, no permite concurrencia, está basado en funciones no en servicios, lo que le permite presentar tiempos de respuestas rápidos.
- cumple el estándar SQL-92
- Es Open Source
- Página de referencia http://www.sqlite.org/
Características importantes
- Presenta los siguientes tipos de datos
Si escribes esto al editar... ...este será el resultado.
Tipo | Declaración del tipo |
---|---|
TEXTO | "TEXT" |
NUMERO | "NUM" |
ENTERO | "INT" |
REAL | "" |
- No soporta otros tipos
- No valida los valores o sea que podemos insertar cadenas de texto en un campo de enteros y el sistema no se queja
SQLite y Android
- Acceder a la base de datos implica acceder al sistema de ficheros
- Los ficheros que creemos por defecto se ubicarán el en siguiente directoiro
DATA/data/APP_NAME/databases/FILENAME.
- DATA es el directorio donde ubica los ficheros Enviroment.getDataDirectory()
- APP_NAME nombre de la aplicación
- FILENAME es el nombre del fichero de la base de datos
El API SQLLite
- El API para trabajar con base de datos está definido en los siguientes paquetes
- android.database
- contiene todas las clases para trabajar con bases de datos
- android.database.sqlite
- Aquí tenemos las clases específicas para trabajar con sqlite
- el siguiene paquete android.database.sqlite *http://developer.android.com/reference/android/database/sqlite/package-summary.html
- Clases del paquete
- SQLiteClosable
- SQLiteCursor
- SQLiteDatabase
- SQLiteOpenHelper
- SQLiteProgram
- SQLiteQuery
- SQLiteQueryBuilder
- SQLiteStatement
- Y las siguientes interfaces
- SQLiteCursorDriver
- SQLiteDatabase.CursorFactory
- SQLiteTransactionListener
Trabajar con Android y SQLLite
Para trabajar con una base de datos debemos realizar unos pasos clásicos
- Crear la base de datos y gestionarla
- Por crear la base de datos entendemos
- Definir la base de datos
- Definir su estructura (tablas y campos)
- Por gestionarla aludo al hecho de hacer operaciones básicas
- Insertar tuplas
- Borrar
- Modificar
- Consultar
- A continuacion vamos a ver como se realizan estas acciones con Android como lenguje y SQLLite como gestor de bases de datos relacional
Crear una base de datos
- Para administar una base de datos tenemos la clase SQLiteDatabase
- Tenemos dos métodos para abrir / crear una base de datos
- La idea es si existe la base de datos la abro, y si no existe la creo
- Tenemos dos manera de interoperar en esta manera
- Usando métodos concretos de la clase SQLiteDatabase concretamente openDatabase u openOrCreateDatabase
- Extendiendo la clase abstracta SQLOpenHelper que es la forma mas habitual y cómo de realizarlo.
SQLiteDatabase
Presenta los siguientes métodos para crear/abrir una base de datos
- openDatabase
- openOrCreateDatabase'
Los parámetros que se pueden pasar son los siguientes
- String path Es el path y nombre de la base de datos
- int flag especifica el modo en el que se abre/crea la base de datos. Sus valores se pueden combinar e.j. OPEN_READWRITE|CREATE_IF_NECESSARY (Especificamos los dos modos).
- OPEN_READWRITE
- OPEN_READONLY
- CREATE_IF_NECESSARY
- NO_LOCALIZED_COLLATORS.
- SQLLiteDatabase.CursorFactory factory
- DatabaseErrorHandler errorHandler
- File file
En realidad el uso de ambos métodos es similar con el hecho de que en el método openOrCreateDatabase(...) asumimos el flag CREATE_IF_NECESSARY Ejemplo
package com.example.agenda; import android.app.Activity; import android.database.sqlite.SQLiteDatabase; import android.widget.Toast; public class Contactos extends Activity { private static final String TAG = "bdagenda"; private static final String DATABASE_PATH = "/data/data/com.example.agenda/databases/"; private static final String DATABASE_NAME = "contactos.db"; private String nombreBD=DATABASE_PATH+DATABASE_NAME; private SQLiteDatabase baseDatos; private String crearTablaContacto= "create table if not exists " + " contacto (codigo integer primary key autoincrement, " + " nombre text not null, telefono text not null unique);"; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.layout_contactos); if (abrirBaseDatos()){ Toast.makeText(this,"Base de datos Abierta ok!!",Toast.LENGTH_LONG).show(); }else{ Toast.makeText(this,"ERROR no se ha podido abrir la base de datos!!",Toast.LENGTH_LONG).show(); } } //Procedimiento para abrir la base de datos //si no existe se creará, también se creará la tabla contacto private boolean abrirBaseDatos(){ try{ baseDatos = SQLiteDatabase.openOrCreateDatabase(nombreBD, null); // baseDatos = openDatabase(nombreBD,null,SQLiteDatabase.CREATE_IF_NECESSARY); baseDatos.execSQL(crearTablaContacto); return true; } catch (Exception e){ Log.i(TAG, "Error al abrir o crear la base de datos" + e); return false; } } }