一起學Android之Sqlite

来源:https://www.cnblogs.com/hsiang/archive/2019/04/05/10660480.html
-Advertisement-
Play Games

本文主要講解Andriod開發中Sqlite的簡單應用(增刪改查),僅供學習分享使用 ...


概述

Android對Sqlite提供了完全友好的支持,在應用程式內部,都可以通過名稱訪問任何的資料庫。建議通過SQLiteOpenHelpe的子類並通過重寫onCreate() 方法進行創建數據表。本文主要講解Andriod開發中Sqlite的簡單應用(增刪改查),僅供學習分享使用。

涉及知識點

  1. SQLiteOpenHelper 管理創建資料庫和版本管理的幫助類(抽象類)。
  2. onCreate 創建數據表的方法
  3. execSQL 執行一個非Select的語句,沒有返回信息。
  4. SQLiteDatabase 管理Sqlite數據的對象,顯示提供一組方法來管理資料庫(CRUD)。
  5. SimpleCursorAdapter 一個簡易的適配器,用來將Cursor適配數據到控制項上。
  6. ContentValues 存儲一組數據值(key-value)。

示例效果圖

如下圖所示:

資料庫幫助類

代碼如下:

 1 package com.hex.demosqlite;
 2 
 3 import android.content.Context;
 4 import android.database.sqlite.SQLiteDatabase;
 5 import android.database.sqlite.SQLiteOpenHelper;
 6 
 7 /**
 8  * Created by Administrator on 2019/4/4.
 9  */
10 public class DatabaseHelper extends SQLiteOpenHelper {
11 
12     private static final String DB_NAME="persons.db";
13 
14     private static final int DB_VERSION=1;
15 
16     public DatabaseHelper(Context context) {
17         super(context, DB_NAME, null, DB_VERSION);
18     }
19 
20     /**
21      * 創建資料庫,指定資料庫名稱,版本號
22      * @param db
23      */
24     @Override
25     public void onCreate(SQLiteDatabase db) {
26         String sql="create table person(_id integer primary key autoincrement not null, name char(10),nickname char(10))";
27         db.execSQL(sql);
28     }
29 
30     /**
31      * 資料庫升級
32      * @param db
33      * @param oldVersion
34      * @param newVersion
35      */
36     @Override
37     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
38         if(newVersion>oldVersion){
39             onCreate(db);
40         }
41     }
42 }

新增(Insert)

代碼如下:

 1  /**
 2      * 新增
 3      *
 4      * @param v
 5      */
 6     public void add(View v) {
 7         /** //一般不使用此種方法,因為execSQL方法沒有返回值
 8          String sql="insert into person(name,nickname)values('宋江','及時雨')";
 9          db.execSQL(sql);
10          */
11         ContentValues values = new ContentValues();
12         values.put("name", "宋江");
13         values.put("nickname", "及時雨");
14         //返回值為插入行的行號
15         long result = db.insert("person", null, values);
16         if (result > 0) {
17             Toast.makeText(this, "插入成功", Toast.LENGTH_SHORT).show();
18         } else {
19             Toast.makeText(this, "插入失敗", Toast.LENGTH_SHORT).show();
20         }
21     }

查詢(Query)

代碼如下:

 1   /**
 2      * 查詢
 3      *
 4      * @param v
 5      */
 6     public void query(View v) {
 7         /*
 8         String sql="select * from person where name=?";
 9         Cursor cursor = db.rawQuery(sql,new String[]{"宋江"});
10         */
11         //columns 如果為空,則表示所有列
12         Cursor cursor = db.query("person", null, "name=?", new String[]{"宋江"}, null, null, null);
13         while (cursor.moveToNext()) {
14             int nameIndex = cursor.getColumnIndex("name");
15             int nickIndex = cursor.getColumnIndex("nickname");
16             String nameValue = cursor.getString(nameIndex);
17             String nickValue = cursor.getString(nickIndex);
18             String s = "name=" + nameValue + ",nickname=" + nickValue;
19             Toast.makeText(this, s, Toast.LENGTH_SHORT).show();
20         }
21         adaper.swapCursor(cursor);
22         adaper.notifyDataSetChanged();
23     }

修改(Update)

代碼如下:

 1     /**
 2      * 更新
 3      *
 4      * @param v
 5      */
 6     public void update(View v) {
 7         // String sql="update person set nickname=? where name=?";
 8 
 9         ContentValues values = new ContentValues();
10         values.put("nickname", "及時雨2");
11         //更新語句受影響的行數
12         int result = db.update("person", values, "name=?", new String[]{"宋江"});
13         if (result > 0) {
14             Toast.makeText(this, "更新成功", Toast.LENGTH_SHORT).show();
15         } else {
16             Toast.makeText(this, "更新失敗", Toast.LENGTH_SHORT).show();
17         }
18     }

刪除(Delete)

代碼如下:

 1   /**
 2      * 刪除
 3      *
 4      * @param v
 5      */
 6     public void delete(View v) {
 7         //String sql="delete person where name=?";
 8 
 9         //受刪除語句影響的行數
10         int result = db.delete("person", "name=?", new String[]{"宋江"});
11         if (result > 0) {
12             Toast.makeText(this, "刪除成功", Toast.LENGTH_SHORT).show();
13         } else {
14             Toast.makeText(this, "沒有刪除成功", Toast.LENGTH_SHORT).show();
15         }
16     }

備註

千里之行,始於足下!

 


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

-Advertisement-
Play Games
更多相關文章
  • [TOC] 一、進程相關的概念 進程需要瞭解 進程,父進程,進程組,會話和控制終端的相關概念。 1. 進程和父進程:每個進程都有父進程,而所有的進程以init進程為根,形成一個樹狀結構 2. 進程組:每個進程都會屬於一個進程組(process group),每個進程組中可以包含多個進程。進程組會有一 ...
  • SSH服務與tcp wrappers實驗 實驗環境: 一臺linux(ssh client) 一臺linux(ssh server) 實驗步驟: 1.配置IP,測試連通性 2.在客戶端創建用戶yuzly1,登錄創建的用戶,用公鑰生成工具生成公鑰,#註意記得輸入私鑰密語,不設置預設為空 3.查看生成的 ...
  • FTP是有兩種數據連接模式的,主動模式和被動模式。 PORT(主動)方式:客戶端向伺服器的FTP埠(預設是21)發送連接請求,伺服器接受連接,建立一條命令鏈路。當需要傳送數據時,客戶端在命令鏈路上用PORT命令告訴伺服器:“我打開了XXXX埠,你過來連接我”。於是伺服器從20埠向客戶端的XXX ...
  • Laravel 提供了很多 輔助函數,有時候我們也需要創建自己的輔助函數。 這裡介紹了 tinker,一個laravel內置的php互動式控制台,方便調試php代碼 php artisan tinker 我們把所有的『自定義輔助函數』存放於 bootstrap/helpers.php 文件中 首先 ...
  • 背景 現有一個交易系統,每次交易都會更新餘額。出賬扣減餘額,入賬增加餘額。為了保證資金安全,餘額發生扣減時,需要比較現有餘額與扣減金額大小,若扣減金額大於現有餘額,扣減餘額不足,扣減失敗。 餘額表( 省去其他欄位 )結構如下: sql CREATE TABLE ( bigint(20) NOT NU ...
  • 1、編輯一個mysql啟動文件。 在終端裡面輸入: 2、輸入啟動文件內容: 上面xml中的 /usr/local/Cellar/mysql/5.7.20/bin/mysqld_safe 為我的mysql所在目錄。 這個是通過homebrew下載的mysql。 官方下載的路徑為 /usr/local/ ...
  • mongodb對集合文檔的操作,添加文檔、查看文檔、刪除文檔、更新文檔及常用的局部更新運算符 ...
  • 最近想安裝一個本地資料庫, 發現網上寫的沒一個能安裝成功的, 各種蛋疼, 我還是自己寫一個吧 參考鏈接: https://www.cnblogs.com/by330326/p/5608290.html https://blog.csdn.net/baidu_41909653/article/deta ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...