Нативная разработка мобильных приложений


Соединение с базой данных



Download 3,69 Mb.
Pdf ko'rish
bet85/228
Sana21.07.2022
Hajmi3,69 Mb.
#834838
1   ...   81   82   83   84   85   86   87   88   ...   228
Bog'liq
Нативная разработка мобильных приложений

127
Соединение с базой данных
В Android (не в традиционном программировании на Java) вы будете пользо
-
ваться в основном классом 
SqliteOpenHelper
. Но это абстрактный класс, поэтому 
нужно определить свой подкласс. Например:
Java
public class DbHelper extends SQLiteOpenHelper {
public DbHelper(Context context) {
super(context, "db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
// пока ничего не делает
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
// пока ничего не делает
}
}
Kotlin
class DbHelper(context: Context) : SQLiteOpenHelper(context, "db", null, 1) {
override fun onCreate(sqLiteDatabase: SQLiteDatabase) {
// пока ничего не делает
}
override fun onUpgrade(sqLiteDatabase: SQLiteDatabase, i: Int, i1: Int) {
// пока ничего не делает
}
}
Метод 
onUpgrade
используется для добавления или миграции (переноса) дан
-
ных при внесении изменений в схему базы данных. Это происходит при из
-
менении номера версии вашей базы данных (четвертый аргумент конструкто
-
ра) и вызывается только один раз для каждого изменения. На самом деле мы 
должны были бы сказать «при увеличении», а не «при изменении», потому что 
попытка использовать БД с версией ниже существующей на устройстве сразу 
же приведет к сбою.
Обратите внимание, что следование соглашениям об использовании обще
-
доступных констант для имен таблиц и столбцов может облегчить чтение или 
запись данных в таблицы в других классах.
Чтобы получить экземпляр базы данных с помощью этого вспомогательного 
класса, нужно вызвать метод 
getWritableDatabase
или 
getReadableDatabase
в зави
-
симости от требуемого режима доступа. В режиме доступа для записи возмож
-
но все то же, что в режиме для чтения, поэтому, планируя выполнять чтение 
и запись, используйте 
getWritableDatabase
. Режим доступа для чтения может 
пригодиться, разве что когда важно гарантировать неизменность содержимого 
базы данных при выполнении операций.


128

Хранение данных
Вот как можно получить экземпляр базы данных для записи:
Java
SQLiteDatabase database = new DbHelper(this).getWritableDatabase();
Kotlin
val database = DbHelper(this).getWritableDatabase()
С этого момента вы будете иметь доступ к экземпляру 
SqliteDatabase
, имею
-
щему методы для выполнения основных операций, таких как чтение и вставка 
данных, а также более универсальные для выполнения произвольных SQL-
запросов, такие как 
execSql
.

Download 3,69 Mb.

Do'stlaringiz bilan baham:
1   ...   81   82   83   84   85   86   87   88   ...   228




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish