ionic3-使用SQLite数据库

安装插件

  • 安装sqlite插件和依赖
npm install --save @ionic-native/sqlite
ionic cordova plugin add cordova-sqlite-storage

在app.moudle.ts中引入SQLite

...
import { SQLite } from '@ionic-native/sqlite';
...
providers: [
...
SQLite
]
...

app.module.ts.png

封装SQLService服务类

封装服务类,每次执行sql语句都调用SQLService的方法

SQLService.png

SQLService代码:

import { Injectable } from '@angular/core';

//原生插件
import { SQLite, SQLiteObject, SQLiteTransaction } from '@ionic-native/sqlite';

//自定义服务
import { NativeService } from "./NativeService";
import { SQLITE } from './Constants';


/**
 * SQLite数据库
 * @export
 * @class SQLService
 */
@Injectable()
export class SQLService {

  //window对象
  private win: any = window;
  //数据库对象
  private database: SQLiteObject;
  //是否android环境
  private isAndroid: boolean;

  constructor(private sqlite: SQLite, private nativeService: NativeService) {

    this.isAndroid = this.nativeService.isAndroid();
  }


  /**
   * 自动判断环境创建sqlite数据库
   * @memberof SQLService
   */
  public initDB()
  {
    if (!this.win.sqlitePlugin)
    {
      //window.openDatabase("数据库名字", "版本","数据库描述",数据库大小);
      this.database = this.win.openDatabase(SQLITE.WINDOW.name, SQLITE.WINDOW.version,
        SQLITE.WINDOW.describe, SQLITE.WINDOW.maxSize);
      return;
    }
    if (this.isAndroid)
    {
      this.sqlite.create({
        name: SQLITE.ANDROID.name,
        location: SQLITE.ANDROID.location
      }).then((db) => {
        this.database = db;
      }).catch(err => {
        console.log(err);
      });
    }
    else
    {
      this.sqlite.create({
        name: SQLITE.IOS.name,
        iosDatabaseLocation: SQLITE.IOS.iosDatabaseLocation,
      }).then((db) => {
        this.database = db;
      }).catch(err => {
        console.log(err);
      });
    }
  }


  /**
   * 执行sql语句
   * @param {string} sql
   * @param {*} [params={}]
   * @returns {Promise<any>}
   * @memberof SQLService
   */
  executeSql(sql: string, params: any = []): Promise<any>
  {
    return new Promise((resolve, reject) => {
      try
      {
        this.database.transaction((tx: SQLiteTransaction) => {
          tx.executeSql(sql, params, (tx, res) => {
            resolve({tx: tx, res: res});
          }, (tx, err) => {
            reject({tx: tx, err: err});
          });
        });
      }
      catch (err)
      {
        reject({err: err});
      }
    });
  }

}

ps: 因为我的代码类与类之间相互依赖,所以就不一一罗列,只贴出核心代码,直接复制代码会出现报错情况,请自行修改。

其中用到的NativeService的方法:

nativeService.png

NativeService用到的代码:

  /**
   * 是否是真机环境
   * @returns {boolean}
   * @memberof NativeService
   */
  isMobile(): boolean
  {
    return this.platform.is("mobile") && !this.platform.is("mobileweb");
  }


  /**
   * 是否android真机环境
   * @returns {boolean}
   * @memberof NativeService
   */
  isAndroid(): boolean
  {
    return this.isMobile() && this.platform.is("android");
  }

使用SQLite

  • app.component.ts文件中导入SQLService依赖
    app.component.ts.png
  • 调用this.sqlService.initDB()初始化SQLite数据库
  • 在要使用数据库的地方使用this.sqlService.executeSql(sql)
    如图:
    使用sqlite.png

代码:

  createTable()
  {
    let sql = 'create table IF NOT EXISTS user(id VARCHAR(32), name VARCHAR(64), sex NUMBER(8))';
    this.sqlService.executeSql(sql).then((data) => {
      console.log(data);
    }).catch((err) => {
      console.log(err)
    });
  }

  deleteTable()
  {
    let sql = 'drop table user';
    this.nativeService.confirm('确定要删除user表吗?', '', () => {
      this.sqlService.executeSql(sql).then((data) => {
        console.log(data);
      }).catch((err) => {
        console.log(err)
      });
    });
  }

  insertUser()
  {
    let id = Utils.getSequence();
    let sql = "insert into user values('"+ id +"', 'JoyoDuan" + id + "', 23)";
    this.sqlService.executeSql(sql).then((data) => {
      console.log(data);
    }).catch((err) => {
      console.log(err)
    });
  }

其中this.nativeService.confirm()是我自己封装的alert方法。

confirm.png

this.nativeService.confirm()代码

/**
   * [确认框]
   * @param {string}    message [消息]
   * @param {string}    title   [标题]
   * @param {any[]) =>      void}        confirmHandler [确认操作]
   * @param {any[]) =>      void}        cancelHandler  [取消操作]
   */
  confirm(message: string, title?: string, confirmHandler?: (...args: any[]) => void, confirmText?: string,
    cancelHandler?: (...args: any[]) => void)
  {
    let confirm = this.alertCtrl.create({
      title: title ? title : this.title,
        message: message,
      buttons:[
            {
                text:"取消",
                role: "cancel",
                handler: () => {
                    if(cancelHandler) cancelHandler();
                }
            },
            {
                text: confirmText || "确定",
                handler: () => {
                    if(confirmHandler) confirmHandler();
                }
            }
      ],
      cssClass: "alert"
    });
    confirm.present();
  }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,911评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,014评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,129评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,283评论 1 264
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,159评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,161评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,565评论 3 382
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,251评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,531评论 1 292
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,619评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,383评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,255评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,624评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,916评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,199评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,553评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,756评论 2 335

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,081评论 25 707
  • Swift版本点击这里欢迎加入QQ群交流: 594119878最新更新日期:18-09-17 About A cu...
    ylgwhyh阅读 25,216评论 7 249
  • 一零年的夏天来的北京,两个箱子两个背包,风风火火来的。 火车。 睡了24小时的油头垢脸,记得好像感冒,鼻涕流出来我...
    灏川阅读 377评论 1 3
  • 昨日10点多,寂静的宿舍,一声手机的消息提示音响起。 习惯性的拿起手机,看着老爸发来的一条微信 —————...
    Charlenemax阅读 400评论 3 0
  • 夏至未至结局:陆之昂入狱 段桥死了 立夏走了…… 结局很悲,而我看完最大的感触是对一个人温柔的最高级别,是信任。 ...
    砚澜阅读 336评论 5 4