ionic保存到mysql_ionic sqlite 存取数据封装(兼容真机与webkit浏览器)

不管是真机还是H5,都有提供sqlite数据库进行存储数据。那么我们只要封装好函数就能随意调用了。

如果只是存储简单的键值对形式的话,ionic官网也提供了一个兼容网页的storage,https://ionicframework.com/docs/storage,但只能key/value ,当然value可以是Json。

但是很多时候为了前后端数据保存一致,所以前端也采用多字段存储,那么只能自己封装函数处理了。

*如果websql支持的浏览器无法满足自己的需求,请使用IndexedDB

1. 安装数据库操作插件

$ ionic cordova plugin add cordova-sqlite-storage

$ npm install --save @ionic-native/sqlite

所有的原生插件和自定义provider都要在app.module的providers中声明

import { SQLite } from '@ionic-native/sqlite';

@NgModule({

declarations: [

MyApp

],

imports: [

HttpModule,

JsonpModule,

BrowserModule,

IonicModule.forRoot(MyApp, {

})

],

bootstrap: [IonicApp],

entryComponents: [

MyApp

],

providers: [

SQLite

]

})

export class AppModule { }

2. 封装调用函数

控制台输入命令创建provider

$ ionic g provider native

执行后目录如下:

0116e6a8a4f2?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

1.png

填入//异步问题进行修改

import { SQLite, SQLiteObject } from '@ionic-native/sqlite';

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

import { Platform , Events } from 'ionic-angular';

import { StorageServiceProvider } from '../../providers/storage-service/storage-service';

@Injectable()

export class NativeProvider {

database: SQLiteObject;

win_db: any;//H5数据库对象

win: any = window;//window对象

constructor( private platform: Platform,

private sqlite: SQLite,

private events: Events,

private storage: StorageServiceProvider) { }

/**

* 创建数据库

*/

createDb() {

if (this.isMobile()) {

this.sqlite.create({

name: 'data.db',

location: 'default'

})

.then((db: SQLiteObject) => {

this.database = db;

//创建表如果已存在就创建

if (this.storage.read('db:create') != "Yes") {

//创建表

this.createTable();

} else {

this.events.publish('db:create');

}

})

.catch(e => {

this.showAlert(this.text.CREATE_DB);

this.events.publish('db:create');

});

} else {

//H5数据库存储,注意测试浏览器兼容,websql w3c没维护

try {

this.win_db = this.win.openDatabase("data.db", '1.0', 'database', 5 * 1024 * 1024);//声明H5 数据库大小

this.createTable();

} catch (err) {

console.log('创建数据库失败')

}

}

}

/**

* 创建表

*/

async createTable() {

// this.querySql('', []);

//可能存在多个执行创建表语句,只需最后一个使用await

await this.executeSql('CREATE TABLE remindMaster(remind_id INTEGER PRIMARY KEY AUTOINCREMENT,user_id TEXT,state TEXT , content TEXT,remind_time TEXT,create_time TEXT)', []);

this.events.publish('db:create');

this.storage.write('db:create', "Yes");

}

/**

* 执行语句

*/

executeSql(sql: string, array: Array): Promise {

return new Promise((resolve, reject) => {

if (this.isMobile()) {

if (!!!!this.database) {

this.database.executeSql(sql, array).then((data) => {

resolve(data);

}, (err) => {

reject(err);

console.log('Unable to execute sql: ' + err);

});

} else {

return new Promise((resolve) => {

resolve([]);

});

}

} else {

if (this.win_db) {

return this.execWebSql(sql, array).then(data => {

resolve(data);

}).catch(err => {

console.log(err);

});

}

}

});

}

/**

* 查询H5数据库

*/

execWebSql(sql: string, params: Array): Promise {

return new Promise((resolve, reject) => {

try {

this.win_db.transaction((tx) => {

tx.executeSql(sql, params,

(tx, res) => resolve(res),

(tx, err) => reject(err));

},

(err) => reject(err));

} catch (err) {

reject(err);

}

});

}

/**

* 是否真机环境

* @return {boolean}

*/

isMobile(): boolean {

return this.platform.is('mobile') && !this.platform.is('mobileweb');

}

}

3. 调用

删除app.html里的默认root属性

0116e6a8a4f2?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图片.png

在程序初始化的时候调用创建数据库(即app.component.ts里)

constructor(

private statusBar: StatusBar,

private splashScreen: SplashScreen,

private nativeProvider: NativeProvider) {

platform.ready().then(() => {

// Okay, so the platform is ready and our plugins are available.

// Here you can do any higher level native things you might need.

this.init();//初始化

});

}

init(){

//确保异步执行完后才隐藏启动动画

this.events.subscribe('db:create', () => {

//创建数据库与表成功后才关闭动画跳转页面

this.statusBar.styleDefault();

this.splashScreen.hide();

this.nav.setRoot(TabsPage);

})

//初始化创建数据库

this.nativeProvider.createDb();

}

在所需页面引入调用即可

//插入数据

this.nativeProvider.executeSql('INSERT INTO remindMaster(user_id,state,content,remind_time,create_time) VALUES (?,?,?,?,?)',

['1', '0', 'haha', '2017-12-14', new Date().getTime().toString()]);

//查询数据

//如果使用直接拼接sql查询,需要注意参数加 '',否则真机sqlite查看不到数据 例如:(`SELECT remind_id,state,user_id,content,remind_time,create_time FROM remindMaster WHERE state='0' AND user_id = '${user_id }' ORDER BY remind_time ASC`, []

this.nativeProvider.executeSql('SELECT remind_id,state,user_id,content,remind_time,create_time FROM remindMaster WHERE state=? AND user_id = ? ORDER BY remind_time ASC', ['0','1']).then(data => {

if (!!!!data && !!!!data.rows && data.rows.length > 0) {

for (let i = 0; i < data.rows.length; i++) {

console.log(data.rows.item(i));

}

}

});

4. 浏览器查看

0116e6a8a4f2?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/534226.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sql plus 表的总记录数是多少_直播回顾 | 亿级并发丝毫不虚,TDSQL-SQL引擎是如何炼成的...

腾讯云数据库国产数据库专题线上技术沙龙正在火热进行中&#xff0c;3月19日唐颢的分享已经结束&#xff0c;没来得及参与的小伙伴不用担心&#xff0c;以下就是直播的视频和文字回顾。关注“腾讯云数据库”公众号&#xff0c;回复“0319唐颢”&#xff0c;即可下载直播分享PPT…

运放放大倍数计算公式_19.运算放大器的特性与应用,不得不掌握的知识点(一)...

运算放大器&#xff0c;简称“运放”&#xff0c;是电力电子中最重要的器件之一&#xff0c;主要作用为&#xff1a;信号放大、信号运算、信号处理、波形的产生和变换。一、运算放大器的内部结构集成运算放大器内部结构集成运算放大器内部一般由四个单元组成&#xff0c;各单元…

java选项设置_java环境配置

javac无法执行检查&#xff1a;看看java 相关的java相关路径有没有多余的符号&#xff0c;比如多出分号&#xff0c;逗号(笔者上面是正确的路径展示形式)Win10下 Java环境变量配置首先&#xff0c;你应该已经安装了 Java 的 JDK 了(如果没有安装JDK&#xff0c;请跳转到此网址&…

teleport 组件的作用_人脸识别综述! 覆盖人脸检测,预处理和特征表示三大核心组件!...

The Elements of End-to-end Deep Face Recognition: A Survey of Recent Advances 人脸识别是计算机视觉社区中最基础和历史悠久的话题之一。随着深度卷积网络和大尺度数据集发展&#xff0c;深度人脸识别取得极大进步并且应用到许多领域。给定一个自然图像或者视频帧作为输入…

feko软件_计算电磁学各种方法和电磁仿真软件简述

计算电磁学中有众多不同的算法&#xff0c;如时域有限差分法(FDTD)、时域有限积分法(FITD)、有限元法(FE)、矩量法(MoM)、边界元法(BEM)、 谱域法(SM)、传输线法(TLM)、模式匹配法(MM)、横向谐振法(TRM)、线方法(ML)和解析法等等。在频域&#xff0c;数值算法有&#xff1a;有限…

出租车管理系统java_基于jsp的出租车管理系统-JavaEE实现出租车管理系统 - java项目源码...

基于jspservletpojomysql实现一个javaee/javaweb的出租车管理系统, 该项目可用各类java课程设计大作业中, 出租车管理系统的系统架构分为前后台两部分, 最终实现在线上进行出租车管理系统各项功能,实现了诸如用户管理, 登录注册, 权限管理等功能, 并实现对各类出租车管理系统相…

cad常青藤插件_原来还有这么好用的CAD插件,半小时就能做完一张图

作为一名优秀的设计师或者建筑师&#xff0c;如果你没用过逆天的CAD插件&#xff0c;我觉得不行&#xff0c;所以下面小编就给大家推荐几个非常好用的CAD插件&#xff0c;希望可以帮助大家大幅提升工作效率。接下来小编就带大家一起看看吧&#xff01;1、天正建筑天正建筑顾名思…

java main是标识符吗_main方法的认识 、通配符、java的注释、java的符(标识符)【Java基础】...

main方法的认识print()和println()的区别print()打印不换行println()打印并换行通配符\n换行符\t制表符都应用于控制台\n换行\t以表格的形式显示System.out.println("----------英雄排行榜------------");System.out.println("\t|编号\t|名字\t|战力值\t|"…

对于半圆形的点击区域该怎么做_十堰混合型塑胶跑道怎么选,橡胶跑道卷材型号...

河北迈弘体育设施有限公司为您详细解读hVgkXc十堰混合型塑胶跑道怎么选的相关知识与详情&#xff0c;校园跑道、体育馆田径跑道等都是体育活动的首先场合。由于终年正在室外遭到风吹日晒&#xff0c;还要接受日常体育活动的摩擦、描写、化学物量腐蚀或重物挤压等因素&#xff0…

希望得到学术会议的及时回复该怎么说_张烨:在“选矿”博士的世界里,脚踏实地从来都不是说说而已!| 中南达人NO.188...

张烨资源加工与生物工程学院矿业工程2017级博士中南大学2019年大学生年度人物之一获奖经历(部分)2016年中南大学FMG奖励金优秀学生奖2017年中南大学优秀毕业生2018年中南大学优秀学生2019年中南大学优秀学生博士研究生国家奖学金中南大学大学生年度人物2017-2019年博士一等学业…

java编写一个集合类_Java集合类

数组是一种很常见的数据结构&#xff0c;开始接触编程的时候多数程序都和数组相关。刚开始接触Java时也是一直使用数组写一些程序&#xff0c;后来越来越觉得数组这东西没法满足需求了&#xff0c;这时一位“前辈”对我说了一句&#xff1a;不会用集合类就等于没学过Java。然后…

pdf不支持64位浏览器_4MLinux 31.0 发布,不支持32位

Zbigniew Konojacki宣布发布4MLinux 31.0&#xff0c;这是该项目极简发行版的新稳定版本&#xff0c;专注于四个功能&#xff1a;维护(作为系统救援Live CD)&#xff0c;多媒体(用于播放视频DVD和其他多媒体文件)&#xff0c;迷你服务器(使用inetd守护程序)和神秘的版本(提供几…

java期末考试2013及答案_java笔试经典(题及答案)2013.doc

java笔试经典(题及答案)2013.doc Java笔试经典(基础部分及答案和分析)1、一个“.java“源文件中是否可以包括多个类(不是内部类)&#xff1f;有什么限制&#xff1f;7答:可以包括多个类&#xff0c;但是最多只能有一个public修饰的类。2、Java有没有goto?7答&#xff1a;java中…

datatables 行分组信息展开与折叠的功能实现_[LaTeX 尝试] fancyvrb - 修复行引用的超链接跳转位置

本文已加入专栏文章目录&#xff0c;归入「进阶使用」文章系列。本文可以看作对这个发生于 2019 年 7 月中旬的 TeX-SX 上自问自答的展开说明。那个回答中避免了 python 的使用&#xff0c;而是利用 zref 宏包把位置信息以文本形式在 pdf 中呈现&#xff0c;好处是不用引入 pyt…

qtcreator摄像头显示时间_三星Galaxy S11 +渲染器展现出巨大的相机凹凸和四边形曲面显示...

我们正接近一年中三星宣布其Galaxy S系列最新设备的时间。Galaxy S10系列被认为是三星发布的最好的版本之一&#xff0c;因此在这方面他们有很多重要的事情。我们已经看到了Galaxy S11和Galaxy S11e的渲染&#xff0c;但是现在我们首先来看看Galaxy S11 。三星Galaxy S11 与其他…

页面错误!请稍后再试_微信内嵌H5页面授权和分享

近期新上线项目&#xff0c;用到了微信授权获取用户信息和分享&#xff0c;掉坑无数次&#xff0c;遂写此篇&#xff0c;为后人指路项目情况技术选型项目语言&#xff1a;HTML、CSS、JavaScript项目框架&#xff1a;Vue.js项目搭建脚手架&#xff1a;vue-cli工程化工具&#xf…

电脑打字手指正确姿势_正确的弹琴手型,应该是怎样的?

手型是基础&#xff0c;手型规范才有助于练习出正确的指法&#xff0c;指法正确就可以提高练习质量。刚入门的时候&#xff0c;不能刻意的要求手型&#xff0c;但是我们要有一个基本的要求&#xff0c;就是手要保持放松。弹琴的时候&#xff0c;没有多余的身体的力量参与到触键…

php 开源 采集,迅睿CMS 火车头内容采集

采集工具&#xff1a;火车采集器 v7.6采集模块&#xff1a;新闻 News一、编写采集入库脚本接口新建&#xff1a;./api/caiji.php/*** 数据采集*/define(IS_API, basename(__FILE__, .php)); // 项目标识define(SELF, pathinfo(__FILE__, PATHINFO_BASENAME)); // 该文件的名称r…

英文数据集txt_YOLOv5在建筑工地中安全帽佩戴检测的应用(已开源+数据集)

点击上方“计算机视觉cv”即可“进入公众号”重磅干货第一时间送达前言随着人工智能的发展&#xff0c;现在越来越多的场景需要人工智能。在工厂的厂区中以安全为首&#xff0c;但工人普遍缺乏佩戴安全帽意识&#xff1b;工厂环境复杂&#xff0c;有各种各样的禁止进入的区域&a…

检测到目标url存在内部ip地址泄露_Cendertron,动态爬虫与敏感信息泄露检测

Cendertron&#xff0c;动态爬虫与敏感信息泄露检测Cendertron Crawler RendertronCendertron https://url.wx-coder.cn/HinPM 是基于 Puppeteer 的 Web 2.0 动态爬虫与敏感信息泄露检测工具。其依托于 xe-crawler 的通用爬虫、调度与缓存模型&#xff0c;新增了 Monkey Test…