在Kotlin和Anko中实现SQLite

时间:2017-06-11 17:52:29

标签: android sqlite kotlin anko

我已经创建了我的应用程序数据库,如下所示。我想立即插入记录并检索此链接说https://antonioleiva.com/databases-anko-kotlin/以使用database.use

import android.database.sqlite.SQLiteDatabase
import org.jetbrains.anko.db.*


class AppDbHelpler : ManagedSQLiteOpenHelper(AppApplication.instance(), AppDbHelpler.DB_NAME, null, AppDbHelpler.DB_VERSION) {

    companion object {
        val DB_NAME = "person.db"
        val DB_VERSION = 1
        val instance by lazy { AppDbHelpler() }
    }

    override fun onCreate(db: SQLiteDatabase?) {
        db!!.createTable(PersonTable.Name, true,
                Pair(PersonTable.ID, INTEGER + PRIMARY_KEY + AUTOINCREMENT),
                Pair(PersonTable.PersonName, TEXT),
                Pair(PersonTable.Domain, TEXT),
                Pair(PersonTable.MobileNumber, REAL))
    }

    override fun onUpgrade(db: SQLiteDatabase?, oldVersion: Int, newVersion: Int) {
        db!!.dropTable(PersonTable.Name, true)
        onCreate(db)
    }
}

// Access property for Context
val Context.database: AppDbHelpler
get() = AppDbHelpler()

MainActivity.kt

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)

    insertPerson()
}


fun insertPerson() {
    database.use {

    }
}

任何人都可以提示我val Context.database: AppDbHelpler get() = AppDbHelpler()的行是什么。它做了什么?

2 个答案:

答案 0 :(得分:4)

val Context.database是Kotlin中extensions的用法。只要您使用database进入类(或其他函数),它们就允许访问值Context

下面的get()方法定义了该变量的property。它相当于Java中的getDatabase()方法,它将返回AppDbHelper,如图所示。通过这种方式,您可以使用变量语法检索帮助程序。由于getter是一个函数,它每次都会创建一个新的帮助器,而不是一个实际的变量只用一个赋值就行为。另请注意,由于这是val,因此不提供set方法。

代码相当于

public static AppDbHelper getDatabase(Context context) {
    return new AppDbHelper();
}
Java中的

答案 1 :(得分:0)

这是一个很好的博客,在kotlin中有完整的sqlite示例。

http://easybook4u.com/index.php/2017/08/09/how-to-use-sqlite-in-android-kotlin/