安卓中資料庫的搭建與使用

来源:http://www.cnblogs.com/zhangdiIT/archive/2016/09/05/5843752.html
-Advertisement-
Play Games

大家好,前幾天我寫了一篇關於ormlite資料庫的使用方法,對於資料庫的使用是很方便,搭建起來也非常簡單,因為底層的關於資料庫的SQL語言都已經封裝成了方法,所以對於規避錯誤與使用都是很便捷,但是對於剛開始接觸資料庫的同學們來說,沒有弄清楚原理直接就使用,對於接受方面顯然是弊大於利的,所以今天我就帶 ...


  大家好,前幾天我寫了一篇關於ormlite資料庫的使用方法,對於資料庫的使用是很方便,搭建起來也非常簡單,因為底層的關於資料庫的SQL語言都已經封裝成了方法,所以對於規避錯誤與使用都是很便捷,但是對於剛開始接觸資料庫的同學們來說,沒有弄清楚原理直接就使用,對於接受方面顯然是弊大於利的,所以今天我就帶著大家一起在不使用第三方jar包的情況下直接搭建一個資料庫並封裝一個操作資料庫的類,讓大家從基礎瞭解安卓資料庫的構成與使用。好的,下麵就進入正題。

 我就簡單的搭建一個存放新聞(News)的資料庫,新聞屬性類我想大家應該都會建(就是定義幾個屬性和有參構造,無參構造外加get與set方法),我就在這不浪費篇幅了,大家在搭建資料庫之前就先寫好這個屬性類,搭建好之後就跟著我進入下麵的步驟吧:

  第一步:新建一個java類並繼承SQLiteOpenHelper

  1、在這個類中,我們要聲明資料庫的名稱以及資料庫的版本號

1 private static final String  DB_NAME = "NEWS.DB";//資料庫名稱
2 private static final int DB_VERSION = 1;//資料庫版本號

  2、我們還要利用java的方法重載定義三個有參構造並重寫創建資料庫表的onCreate方法

 1 public NewsSQLiteOpenHelper(Context context){
 2 super(context,DB_NAME,null,DB_VERSION);
 3 }
 4 //version  資料庫版本號 context 上下文 name資料庫名字
 5 public NewsSQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
 6 super(context, name, factory, version);
 7 }
 8 public NewsSQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version, DatabaseErrorHandler errorHandler) {
 9 super(context, name, factory, version, errorHandler);
10 }
11     @Override
12     public void **onCreate**(SQLiteDatabase db) {
13         //獲取創建表格的SQL
14         String netNewsSQL =Constant.NewNewsTable.getCreatNetNewsSQL();
15     //Z執行SQL
16     db.execSQL(netNewsSQL);
17 }

  3、重寫父類的更新資料庫方法

1 @Override
2 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
3     db.execSQL("drop table "+ Constant.NewNewsTable.TBL_NAME);
4     onCreate(db);
5 }

至此我們資料庫就算搭建的差不多了,下一步就是創建表了。

  第二步:創建表,在搭建好資料庫後就是往資料庫中添加一張張的表,主要是使用資料庫語言定義一個靜態生成方法

 一定要註意的是在寫資料庫語言生成的時候字母的大小寫以及單詞與單詞之間的空格(這也是資料庫搭建中最最最容易出錯的地方,所以大家在寫的時候一定要註意),代碼如下:

 1 public static final class NewNewsTable {
 2     public static final String TBL_NAME = "NETNEWS";
 3     public static final String COL_ID = "ID";
 4     public static final String COL_TITLE = "TITLE";
 5     public static final String COL_CTIME = "CTIME";
 6     public static final String COL_PICURL = "PICURL";
 7     public static final String COL_URL = "URL";
 8     public static final String COL_DESCRIPTION = "DESCRIPTION";
 9     public static final String COL_NEWSTYPE = "NEWSTYPE";
10 
11     public static String getCreatNetNewsSQL() {
12         String sql = "CREATE TABLE IF NOT EXISTS "
13                 + TBL_NAME + "(" + COL_ID + " INTEGER PRIMARY KEY AUTOINCREMENT,"
14                 + COL_TITLE + " VARCHAR(200),"
15                 + COL_CTIME + " VARCHAR(50),"
16                 + COL_PICURL + " VARCHAR(200),"
17                 + COL_URL + " VARCHAR(200),"
18                 + COL_DESCRIPTION + " TEXT,"
19                 + COL_NEWSTYPE + " integer"
20                 + ")";
21         return sql;
22     }
23 }

那麼資料庫與屬性類都完成之後,我們就要提供一個操作類用來操作資料庫了,所以最後一步就是定義一個操作類。

  第三步:創建一個操作類,為操作資料庫提供增刪改查等功能

下麵為了能夠便於大家的理解,我先把這幾個功能分開寫:

  1、將一條數據寫入資料庫的方法與將一組數據寫入資料庫的方法:

添加一條:

 1 public long addNetNews(NetNews nn){
 2    SQLiteDatabase db = this.openHelper.getReadableDatabase();
 3    ContentValues values = new ContentValues();
 4    values.put(Constant.NewNewsTable.COL_TITLE,nn.getTitle());
 5    values.put(Constant.NewNewsTable.COL_DESCRIPTION,nn.getDescription());
 6    values.put(Constant.NewNewsTable.COL_CTIME,nn.getCtime());
 7    values.put(Constant.NewNewsTable.COL_PICURL,nn.getPicUrl());
 8    values.put(Constant.NewNewsTable.COL_URL,nn.getPicUrl());
 9    values.put(Constant.NewNewsTable.COL_NEWSTYPE, nn.getNewsType());
10    long id = db.insert(
11            Constant.NewNewsTable.TBL_NAME,
12            null,
13            values
14    );
15    db.close();
16    return id;  
17    }

添加一組數據(就是利用for迴圈執行添加一條數據的方法)

1 public  void addNetNews(List<NetNews> netNewsList){
2         for(NetNews nn:netNewsList){
3       addNetNews(nn);
4     }
5 }

  2、根據新聞類型刪除資料庫中的數據

 1 public void removeNewsByType(int type){
 2     SQLiteDatabase DB = this.openHelper.getReadableDatabase();
 3     //根據新聞類型刪除
 4     DB.delete(
 5             Constant.NewNewsTable.TBL_NAME,
 6             Constant.NewNewsTable.COL_NEWSTYPE+" =?",
 7             new String[]{type+""}
 8     );
 9     DB.close();
10 }

  3、根據數據類型查詢數據

 1 public List<NetNews> findNewsByType(int type){
 2     List<NetNews> list = new ArrayList<>();
 3     SQLiteDatabase db = this.openHelper.getReadableDatabase();
 4     Cursor cursor = db.query(
 5             Constant.NewNewsTable.TBL_NAME,
 6             new String[]{
 7                     Constant.NewNewsTable.COL_ID,
 8                     Constant.NewNewsTable.COL_CTIME,
 9                     Constant.NewNewsTable.COL_DESCRIPTION,
10                     Constant.NewNewsTable.COL_TITLE,
11                     Constant.NewNewsTable.COL_PICURL,
12                     Constant.NewNewsTable.COL_URL,
13                     Constant.NewNewsTable.COL_NEWSTYPE
14             },
15             Constant.NewNewsTable.COL_NEWSTYPE+" =?",
16             new String[]{type+""},
17             null,
18             null,
19             null,
20             null
21     );
22     while(cursor.moveToNext()){
23         NetNews nn = new NetNews();
24         nn.setTitle(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_TITLE)));
25         nn.setCtime(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_CTIME)));
26         nn.setDescription(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_DESCRIPTION)));
27         nn.setPicUrl(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_PICURL)));
28         nn.setUrl(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_URL)));
29         nn.setNewsType(cursor.getInt(cursor.getColumnIndex(Constant.NewNewsTable.COL_NEWSTYPE)));
30         list.add(nn);
31     }
32     cursor.close();
33     db.close();
34     return list;
35 }

這樣對資料庫的基本操作就算完成了,下麵再賦一張資料庫操作類的完整代碼,大家在仔細琢磨一下吧:

 1 public class NetNewsDao  {
 2 private NewsSQLiteOpenHelper openHelper;
 3 public NetNewsDao(Context mContext){
 4     this.openHelper = new NewsSQLiteOpenHelper(mContext);
 5 }
 6 public List<NetNews> findNewsByType(int type){
 7     List<NetNews> list = new ArrayList<>();
 8     SQLiteDatabase db = this.openHelper.getReadableDatabase();
 9     Cursor cursor = db.query(
10             Constant.NewNewsTable.TBL_NAME,
11             new String[]{
12                     Constant.NewNewsTable.COL_ID,
13                     Constant.NewNewsTable.COL_CTIME,
14                     Constant.NewNewsTable.COL_DESCRIPTION,
15                     Constant.NewNewsTable.COL_TITLE,
16                     Constant.NewNewsTable.COL_PICURL,
17                     Constant.NewNewsTable.COL_URL,
18                     Constant.NewNewsTable.COL_NEWSTYPE
19             },
20             Constant.NewNewsTable.COL_NEWSTYPE+" =?",
21             new String[]{type+""},
22             null,
23             null,
24             null,
25             null
26     );
27     while(cursor.moveToNext()){
28         NetNews nn = new NetNews();
29         nn.setTitle(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_TITLE)));
30         nn.setCtime(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_CTIME)));
31         nn.setDescription(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_DESCRIPTION)));
32         nn.setPicUrl(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_PICURL)));
33         nn.setUrl(cursor.getString(cursor.getColumnIndex(Constant.NewNewsTable.COL_URL)));
34         nn.setNewsType(cursor.getInt(cursor.getColumnIndex(Constant.NewNewsTable.COL_NEWSTYPE)));
35         list.add(nn);
36     }
37     cursor.close();
38     db.close();
39     return list;
40 }
41 public long addNetNews(NetNews nn){
42    SQLiteDatabase db = this.openHelper.getReadableDatabase();
43    ContentValues values = new ContentValues();
44    values.put(Constant.NewNewsTable.COL_TITLE,nn.getTitle());
45    values.put(Constant.NewNewsTable.COL_DESCRIPTION,nn.getDescription());
46    values.put(Constant.NewNewsTable.COL_CTIME,nn.getCtime());
47    values.put(Constant.NewNewsTable.COL_PICURL,nn.getPicUrl());
48    values.put(Constant.NewNewsTable.COL_URL,nn.getPicUrl());
49    values.put(Constant.NewNewsTable.COL_NEWSTYPE, nn.getNewsType());
50    long id = db.insert(
51            Constant.NewNewsTable.TBL_NAME,
52            null,
53            values
54    );
55    db.close();
56    return id;  
57    }
58    public  void addNetNews(List<NetNews> netNewsList){
59         for(NetNews nn:netNewsList){
60       addNetNews(nn);
61     }
62 }
63 public void removeNewsByType(int type){
64     SQLiteDatabase DB = this.openHelper.getReadableDatabase();
65     //根據新聞類型刪除
66     DB.delete(
67             Constant.NewNewsTable.TBL_NAME,
68             Constant.NewNewsTable.COL_NEWSTYPE+" =?",
69             new String[]{type+""}
70     );
71     DB.close();
72  }
73 }

好了,到現在我們就已經把資料庫搭建完成,也把資料庫的操作類寫好了,在調用的時候就直接生成一個資料庫操作對象對資料庫進行操作就OK了。

  安卓原始資料庫的搭建以及操作類的編寫還是很麻煩的,但是對於大家對於資料庫的運行原理以及SQL語言的理解還是能起到了很大的作用的,對於初學者來說,夯實基礎就顯得尤為重要,而理解了資料庫的原理在對以後的工作學習都有很大的裨益,所以還是建議大家多看看,在熟練了之後再使用ormlite以及greendao等Jar包搭建資料庫的時候就顯得更加的得心應手。好了,關於安卓原始資料庫的搭建加寫到這吧,如果大家感覺看過之後對於自己在資料庫方面的理解起到了一些幫助的話就推薦一下吧,如果有哪些地方寫的不好還希望大家評論指正,謝謝。

 


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

-Advertisement-
Play Games
更多相關文章
  • 如果說XHTML已經開始尋求取代HTML,那麼HTML5的實用性在於,它將兩種語法整合在一起,採用同樣有效的方式來表達HTML的抽象DOM表示。HTML5規範結合了HTML4,XHTML1以及DOM級別2HTML,併進行了相應的更新。 HTML5取代XHTML 1成為HTML規範的XML序列化格式。 ...
  • 通過案例演示開關控制項Switch、滑塊控制項Slider和分段控制項Segmented Control的使用。 ...
  • 本文主要講述了Android 實現圖片畫畫板 設計項目佈局: 首先實現畫圖功能: 接下來完成保存圖片的功能: ...
  • 1:Assertion failure in dequeueReusableCellWithIdentifier:forIndexPath: 上面是在IOS9以下一直報閃退;後來改成下麵解決: 2:CoreTelephony框架不是私有庫 私有框架的目錄為:/Applications/Xcode.a ...
  • Text用於顯示文本的React組件,並且它也支持嵌套、樣式,以及觸摸處理。在下麵的例子里,嵌套的標題和正文文字會繼承來自styles.baseText的fontFamily字體樣式,不過標題上還附加了它自己額外的樣式。標題和文本會在頂部依次堆疊,並且被代碼中內嵌的換行符分隔開。 一:屬性 1:al ...
  • Swift - UIView的無損截圖 效果 源碼 使用 ...
  • ListView 顯示大量相同格式數據 常用屬性: listSelector listView每項在選中、按下等不同狀態時的Drawable divider ListView每項間的間隔Drawable dividerHeight ListView每項間間隔的間隔高度 常用方法: setAdapte ...
  • 系列開篇,準備將方向由安卓開發轉向移動安全,首先需要瞭解的就是Android的逆向工程。 現在簡要介紹初級階段需要的工具以及如何獲取並正確配置他們 如果在資源獲取方面遇到困難,留下郵箱我會將所有東西打包發給你 JRE,JDK,SDK,NDK 關於這些工具包的配置不做贅述。 apktool apkto ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...