在Android上運用Anko和Kotlin開發資料庫:SQLite從來不是一件輕鬆的事(KAD25)

来源:http://www.cnblogs.com/figozhg/archive/2017/06/04/6941909.html
-Advertisement-
Play Games

原作者介紹,在Android上如何運用Anko和Kotlin開發資料庫。 ...


作者:Antonio Leiva

時間:Mar 30, 2017

原文鏈接:https://antonioleiva.com/databases-anko-kotlin/

 

 

事實告訴我們:在Android中編寫資料庫是相當無聊的。

 

使用SQLite時,所需的所有模板在當今世界上都不是一件最令人愉快的事情。

 

所幸的是,在最新一次Google I / O會議上,它們宣佈的其中一項事項(稱其為:Room),就是為簡化這項工作,開發出足夠的庫。

 

然而,運用Anko,我們仍可以繼續像使用低級別框架一樣工作,但是擺脫了實施過程中一些繁瑣的部分。今天我們來看看究竟是怎麼樣做到的。

 

 

運用Anko創建你的資料庫

這裡你將看到如何從頭開始創建資料庫。在Android上,你需要SQLiteOpenHelper,來檢索資料庫。其後,你還需要記住在請求之後關閉它。而這些Anko都為你做了。

 

維持,你需要添加Anko的SQLite依賴關係:

1 compile 'org.jetbrains.anko:anko-sqlite:0.10.0'

 

實現ManagedSQLiteOpenHelper

如果你使用這個繼承SQLiteOpenHelper的類,就可以創建操作資料庫的代碼塊,如下所示:

 

1 database.use { 
2     ...
3 }

 

 

大括弧內是SQLiteDatabase類的擴展函數,這樣你就可以直接調用它的方法。另外,僅在這塊代碼執行前,將此表打開。而在代碼執行結束後將其關閉

 

 

我們如何實現這個類?基於Anko的文檔,推薦的方法是:

 1 class MySqlHelper(ctx: Context) : ManagedSQLiteOpenHelper(ctx, "mydb") {
 2  
 3     companion object {
 4         private var instance: MySqlHelper? = null
 5  
 6         @Synchronized
 7         fun getInstance(ctx: Context): MySqlHelper {
 8             if (instance == null) {
 9                 instance = MySqlHelper(ctx.applicationContext)
10             }
11             return instance!!
12         }
13     }
14  
15     override fun onCreate(db: SQLiteDatabase) {
16     }
17  
18     override fun onUpgrade(db: SQLiteDatabase, oldVersion: Int, newVersion: Int) {
19     }
20  
21 }
22  
23 // Access property for Context
24 val Context.database: MySqlHelper
25     get() = MySqlHelper.getInstance(applicationContext)

 

我們創建一個短小的單常式,它保存helper的實例,用同步的方法使不同的線程不能生成多個實例。

 

另外,我們為上下文創建一個擴展屬性,這樣任何需要Context的類都可以直接訪問資料庫。

 

 

這就是允許我們使用的最初始代碼。

 

 

定義資料庫表結構

 

 

 

為了創建我們的資料庫,我們需要實現helperonCreater方法,並使用Anko提供的createTable擴展函數:

1 override fun onCreate(db: SQLiteDatabase) {
2     db.createTable("Person", true,
3             "_id" to INTEGER + PRIMARY_KEY,
4             "name" to TEXT,
5             "surname" to TEXT,
6             "age" to INTEGER)
7 }

 

這裡第一個參數給出的是資料庫名稱,第二個參數說明是否要在create之前,確定表不存在。

 

 

第三個參數是vararg(變數)對。也就是,你可以添加加任意數量變數。如你所見,這個變數對的格式是 A to B。這個用保留字infix修飾的函數,稱之為中綴函數infix function)。

 

變數對的第二部分是SqlType類常量。由於這很有趣,我建議你看看它的實現。在這裡,它巧妙地使用了操作符重載

 

插入和查詢數據

 

 

運用Anko一切都變得容易多了。在插入過程中,不需要創建自己的ContentValue來添加所有數據,而是用資料庫對象的擴展函數。這樣就可以:

1 database.use {
2     insert("Person",
3             "_id" to 1,
4             "name" to "John",
5             "surname" to "Smith",
6             "age" to 20)
7 }

 

而查詢,可以有幾種方法進行。在其中之一是,你可以為查詢的變數添加名稱,並將作為變數對將值添加上:

 

1 select("Person")
2         .where("(_id = {id}) and (name = {name})",
3                 "id" to 1,
4                 "name" to "John")

 

 

還有另一個方法更類似在Android框架中使用,允許在其後用詢問符號和值。在這種情況下,它們都必須為String

1 select("Person")
2         .whereSimple("(_id = ?) and (name = ?)",
3                 1.toString(), "John")

 

我個人認為第二種方法更簡單。

 

 

你還可以使用所有資料庫常規操作,如limitorderByhavinggroupBy你可以在Anko文檔中看到所有這些操作。

 

為了處理結果游標,Anko還為我們提供了不同的函數,如parseSingle(對一個結果)或者parseList(對於幾個結果)。這些函數接收一個rowParser

 

 

有許多不同的解析器。MapRowParser是其中一個有趣的,它將列映射到一張圖(map)中。

 

 

運用這個解析器和map委托,您可以直接解析圖中的值到類中。可以我的書中看到這個說明。

 

結論

 

儘管有許多的庫可以簡化資料庫的很多工作,而對於簡化工作來說,Anko已足夠了。

 

由於它為我們簡化了許多使用資料庫的帶來痛苦事情,所以它是簡化資料庫工作的很好選擇。

 

 

另外,它向我們展示了用其他方式來使用語言,當您遇到問題時,這些語言非常有用。

 

 

不要忘了看看以前的文章,瞭解更多關於Kotlin

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java併發包的locks包里的鎖基本上已經介紹得差不多了,ReentrantLock重入鎖是個關鍵,在清楚的瞭解了同步器AQS的運行機制後,實際上再分析這些鎖就會顯得容易得多,這章節主講另外一個重要的鎖——ReentrantReadWriteLock讀寫鎖。 ReentrantLock是一個獨占鎖 ...
  • 學到矩陣鍵盤這一塊對網上別人寫的C代碼有些疑問,希望有能看到的大牛幫助解答。 矩陣鍵盤和獨立鍵盤原理圖: 原理:對於圖右側的矩陣鍵盤,把P3口的低四位(P3.0 ~ P3.3)和高四位(P3.4 ~ P3.7)分別置1,只要有按鍵被按下,那麼與之對應的P3口某一位將由高電平被拉低,兩次分別測得了行值 ...
  • @staticmethod 裝飾後,類中的方法轉成靜態方法 靜態方法不可以訪問實例變數或類變數,相當於類中的工具包。如os, system 等 import的模塊一般 @classmethod裝飾後,類中的方法轉成類方法,類方法和普通方法的區別是, 類方法只能訪問類變數,不能訪問實例變數 @prop ...
  • 一、創建一個簡單的Hello World案例 首先需要導入activemq-all-5.14.5.jar包,寫生產端: 寫消費端: 通過http://localhost:8161/admin/queues.jsp路徑查看消息消費情況。 二、ActiveMQ 安全機制 activeMQ的Web管理界面 ...
  • 猴子吃桃問題:猴子第一天摘下若幹個桃子,當即吃了一半,還不過癮,又多吃了一個;第二天早上又將剩下的桃子吃掉一半,而且又多吃了一個。以後每天早上都吃了前一天剩下的一半零一個。到第10天早上想再吃時,就只剩下一個桃子了。求第一天共摘了多少個桃子。 public class Example17 { pub ...
  • 輸出九九乘法表。 public class Example16 { public static void main(String[] args) { table(9); } public static void table(int n) { for (int i = 1; i <= n; i++) ...
  • 異常處理 1、在異常處理中,如果子類覆蓋了父類的一個方法,子類方法中聲明的已檢查異常不能比父類方法聲明的異常更通用,即子類方法可以拋出更特定的異常(不超過父類方法聲明的異常範圍,即由父類方法聲明異常派生的子異常),或者不拋出任何異常。並且,如果父類方法沒有拋出異常,子類也不能拋出任何已檢查異常。 個 ...
  • 代碼: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...