Android下創建一個SQLite資料庫

来源:http://www.cnblogs.com/wuyudong/archive/2016/06/06/5561216.html
-Advertisement-
Play Games

資料庫:SQLite(輕量級,嵌入式的資料庫) 大量的相似結構的數據的儲存,快速的查詢。特殊的文件(按照一定的格式生成) 資料庫的創建 創建文件 1.聲明文件對象,文件是不會被創建出來的。 File file = new File("文件名稱"); 2.寫文件(文件才會被創建出來) FileOutp ...


資料庫:SQLite(輕量級,嵌入式的資料庫)

大量的相似結構的數據的儲存,快速的查詢。特殊的文件(按照一定的格式生成)

資料庫的創建

創建文件

1.聲明文件對象,文件是不會被創建出來的。

File file = new File("文件名稱");

2.寫文件(文件才會被創建出來)

FileOutputStream fos = new FileOutputStream(file);

fos.write("hdahfdsaklfh".getbytes());

創建資料庫

1.實現SQLiteOpenHelper的子類PersonSQLiteOpenHelper

public class PersonSQLiteOpenHelper extends SQLiteOpenHelper {

    public PersonSQLiteOpenHelper(Context context, String name,
            CursorFactory factory, int version) {
        super(context, name, factory, version);
        // TODO Auto-generated constructor stub
    }

    @Override
    public void onCreate(SQLiteDatabase arg0) {
        // TODO Auto-generated method stub

    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }
}

SQLiteOpenHelper的幾個參數的解釋如下:

android.database.sqlite.SQLiteOpenHelper.SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version)

Create a helper object to create, open, and/or manage a database. This method always returns very quickly. The database is not actually created or opened until one of getWritableDatabase or getReadableDatabase is called.

Parameters:
context to use to open or create the database
name of the database file, or null for an in-memory database
factory to use for creating cursor objects, or null for the default
version number of the database (starting at 1); if the database is older, onUpgrade will be used to upgrade the database; if the database is newer, onDowngrade will be used to downgrade the database

2.getWritableDatabase/getReadableDatabase()

新建TestPersonDB.java

package com.wuyudong.db.test;

import com.wuyudong.db.PersonSQLiteOpenHelper;

import android.test.AndroidTestCase;

public class TestPersonDB extends AndroidTestCase {
    public void testCreateDB() throws Exception {
        PersonSQLiteOpenHelper helper = new PersonSQLiteOpenHelper(getContext());
        helper.getWritableDatabase();
    }
}

3.onCreate() 資料庫第一次創建的執行的方法,適合做資料庫表結構的初始化

    // Called when the database is created for the first time.
    // 在資料庫第一次創建的時候執行的方法
    // 如果資料庫已經創建完畢,就不會再去執行了。
    // 適合做資料庫表結構的初始化操作
    // db代表的就是當前的資料庫
    @Override
    public void onCreate(SQLiteDatabase db) {
        // 初始化資料庫的表結構
        db.execSQL("create table person (id integer primary key autoincrement, name varchar(20), number varchar(20))");
    }

註意:

sqlite資料庫是一個嵌入式輕量級的資料庫,內部不區分數據類型的,不對數據的長度校驗。

新建AndroidTest工程test

將AndroidManifest.xml中的如下相關的代碼複製到本項目的AndroidManifest.xml中

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.wuyudong.db.test"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="8" />

    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="com.wuyudong.db" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <uses-library android:name="android.test.runner" />
    </application>

</manifest>

複製後的代碼如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.wuyudong.db"
    android:versionCode="1"
    android:versionName="1.0" >

    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="com.wuyudong.db" />

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <uses-library android:name="android.test.runner" />

        <activity
            android:name="com.wuyudong.db.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

項目結構如下:

PersonSQLiteOpenHelper.java完整代碼如下:

package com.wuyudong.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class PersonSQLiteOpenHelper extends SQLiteOpenHelper {

    /**
     * 定義一個資料庫創建的幫助類,裡面有兩個方法需要實現 相當於 file類
     * 
     * @author Administrator
     * 
     */
    public PersonSQLiteOpenHelper(Context context) {
        // context 上下文
        // person.db 資料庫文件名稱
        // factory 游標工廠
        // version 資料庫的版本號 從1開始
        super(context, "person.db", null, 1);
        // TODO Auto-generated constructor stub
    }

    // Called when the database is created for the first time.
    // 在資料庫第一次創建的時候執行的方法
    // 如果資料庫已經創建完畢,就不會再去執行了。
    // 適合做資料庫表結構的初始化操作
    // db代表的就是當前的資料庫
    @Override
    public void onCreate(SQLiteDatabase db) {
        // 初始化資料庫的表結構
        db.execSQL("create table person (id integer primary key autoincrement, name varchar(20), number varchar(20))");
    }

    // 當資料庫的版本號發生升級的時候調用。
    // 資料庫只能升級不能降級。
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }
}

運行程式

打開person.db


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

-Advertisement-
Play Games
更多相關文章
  • Node.js是一個基於Chrome JavaScript運行時建立的平臺,小巧方便搭建。運行的埠可以在瀏覽器上運行,顯示效果,但每次用瀏覽器也挺麻煩,我們這裡講的是在sublime text2中配置,是的js在sublimetext2中運行,再也不用切換到瀏覽器了。 1.首先安裝node.js, ...
  • ...
  • 下拉框二級聯動效果在日常應用場景中經常會碰到,尤其是涉及地區、品種等有多級選項時。例如:常見的省市聯動下拉框,在選擇省份時,城市列表也會更隨改變。 思路: 1,所謂聯動效果,是指出發父級的數據變化時,會影響到關聯性子級數據元素的變化。 下麵是造的省市的數據: var linkDatas = { pr ...
  • HTML5是最新的HTML標準,或遲或早,所有的web程式員都會發現需要使用到這個最新的標準,而且,很多人都會感覺到,重新開發一個HTML5的網站,要比把一個網站從HTML4遷移到HTML5上容易的多,這是因為這兩個版本之間有很大不同之處。 事實上,HTML5並沒有對HTML4做什麼重大的修改,它們 ...
  • iOS FFmpeg 優秀博客集錦 這篇博客沒有我自己寫的內容: 主要是對FFmpeg一些優秀博客的記錄 隨時更新 1 "iOS編譯FFmpeg、kxmovie實現視頻播放" ...
  • iOS的觸摸事件個人總結,分為兩步: 第一步:是找到哪個視圖上觸摸 第二步:分析由誰去響應(響應者連) 1.尋找被觸摸的視圖原理如下圖 hitText:withEvent:的方法處理流程: 首先會在當前視圖view上調用pointInside:withEvent:方法來判斷觸摸事件是否存在當前vie ...
  • 對android開發有一定瞭解的同學一定或多或少知道android的觸摸事件分發,整個事件的分發消耗流程都可以通過看源碼理解,下麵通過講解demo幫助加深事件分發的理解和在實戰中的應用。首先直接上demo截圖: ...
  • iOS獲取通知需要註意以下三個地方iOS 設備收到一條推送(APNs),用戶點擊推送通知打開應用時,應用程式根據狀態不同進行處理需在 AppDelegate 中的以下兩個方法中添加代碼以獲取apn內容 如果 App 狀態為未運行,此函數將被調用,如果launchOptions包含UIApplicat ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...