我已经创建了我的应用程序数据库,如下所示。我想立即插入记录并检索此链接说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()
的行是什么。它做了什么?
答案 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/