uniapp使用sqlite 数据库

uniapp使用sqlite 数据库

傻瓜式使用方式,按步骤,即可使用。

1.开启sqlite
在项目中manifest.json该文件中配置
在这里插入图片描述
2.封装数据库的调用方法

const sqlName = "zmyalh"  //定义的数据库名称
const sqlPath = "_doc/zmyalh.db" //定义数据库的位置在_doc目录下的zmyalh.db文件,zmyalh.db这个可以自己定义名字
//打开数据库,在使用数据库前,必须打开数据库
function openDb(name,path) {return new Promise((resolve,reject)=>{plus.sqlite.openDatabase({name: name,    //这里是数据库的名称path: path,    //_doc是相对路径的应用私有文档目录success: function(e){console.log('数据库打开成功')resolve(e)},fail: function(e){console.log('数据库打开失败:' + JSON.stringify(e))reject(e)}})})
}
//判断是否打开数据库
function isOpened(name,path) {return plus.sqlite.isOpenDatabase({name:name,path:path})
}//关闭数据库
function closeDb(name) {return new Promise((resolve,reject)=>{plus.sqlite.closeDatabase()({name: name,    //这里是数据库的名称success: function(e){console.log('数据库关闭成功')resolve(e)},fail: function(e){console.log('数据库关闭失败')reject(e)}})})
}//查询sql 所有的查询都用该方法
function selectSql(name,sqlText) {return new Promise((resolve,reject)=>{plus.sqlite.selectSql({name: name,    //这里是数据库的名称sql: sqlText,success: function(e){// console.log('查询成功:' + sqlText)resolve(e)},fail: function(e){console.log('查询失败:' + sqlText + "-异常信息:" + JSON.stringify(e))reject(e)}})})
}
//执行增删改查都使用该方法
function executeSql(name,sqlText) {return new Promise((resolve,reject)=>{plus.sqlite.executeSql({name: name,    //这里是数据库的名称sql: sqlText,success: function(e){console.log('操作成功')resolve(e)},fail: function(e){console.log('执行失败:' + sqlText + '-异常信息:' + JSON.stringify(e))reject(e)}})})
}
export  {sqlName,sqlPath,openDb,isOpened,closeDb,selectSql,executeSql
}

3.创建数据库方式

import {sqlName,executeSql} from "./sqllite.js"
let createSql = {//用户表name:"user",sql:"id INTEGER PRIMARY KEY AUTOINCREMENT,userId VARCHAR(255) NOT NULL,userName VARCHAR(255) NOT NULL,admin  VARCHAR(20) NOT NULL,loginIp   VARCHAR(255) NOT NULL,nickName VARCHAR(255) NOT NULL,password  VARCHAR(255) NOT NULL,dept json not null,roles json not null"
}
executeSql(sqlName,`create table if not exists ${createSql.name} (${createSql.sql})`)

4.操作数据库正删改查

import {sqlName,openDb,isOpened,closeDb,selectSql,executeSql
} from "./sqllite.js"
const name = sqlNameexport function userAll() {//查询全部let sql = "SELECT * FROM user"return selectSql(name,sql) 
}export function userItem(names) {//按名字查询let sql = `select * from user where userName = '${names}'`return selectSql(name,sql) 
}export function userAdd(row) {//新增let sql = `INSERT INTO user (userId,userName, admin, loginIp, nickName, password, dept, roles)  VALUES ('${row.userId}','${row.userName}','${row.admin}','${row.loginIp}','${row.nickName}','${row.password}','${row.dept}','${row.roles}')`return executeSql(name,sql) 
}export function userUpdata(row) {//修改一条let sql = `UPDATE user SET userId = '${row.userId}', userName = '${row.userName}', admin ='${row.admin}', loginIp = '${row.loginIp}',nickName = '${row.nickName}', password= '${row.password}',dept= '${row.dept}' ,roles= '${row.roles}'  WHERE id = ${row.id}`return executeSql(name,sql) 
}export function userDelete(id) {//删除一条let sql = `DELETE FROM user WHERE id = ${id}`return executeSql(name,sql) 
}export function userDeletes() {//删除全部let sql = `DELETE FROM user `return executeSql(name,sql) 
}

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

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

相关文章

如何通过人工智能和自动化提高供应链弹性?

全球供应链中的数字化转型已经引起了广泛关注,尽管在过去的十年中,这一话题被广泛讨论,但许多公司仍然对如何实现这一不明确的目标感到困惑。人们普遍认识到这种转变的重要性,而新冠疫情及其带来的巨大影响也为行业向数字化转型方…

【Go 基础篇】Go语言分支结构:掌握 if 和 switch,灵活控制程序逻辑

介绍 在编程中,分支结构是一种重要的控制流程,它允许程序根据不同的条件选择不同的执行路径。Go语言提供了两种主要的分支结构:if 和 switch,用于在程序中实现条件判断和多重选择。本篇博客将深入探讨Go语言中的if和switch分支结…

EureKa快速入门

EureKa快速入门 远程调用的问题 多个服务有多个端口,这样的话服务有多个,硬编码不太适合 eureKa的作用 将service的所有服务的端口全部记录下来 想要的话 直接从注册中心查询对于所有服务 每隔一段时间需要想eureKa发送请求 保证服务还存活 动手实践 …

后端开发有哪几种语言? - 易智编译EaseEditing

后端开发是构建应用程序的一部分,负责处理服务器端的逻辑、数据库交互和数据处理。有许多编程语言可用于后端开发,以下是一些常见的后端开发语言: Java: Java是一种广泛使用的面向对象编程语言,具有强大的跨平台能力。…

常见前端面试之VUE面试题汇总八

22. Vue 子组件和父组件执行顺序 加载渲染过程: 1.父组件 beforeCreate 2.父组件 created 3.父组件 beforeMount 4.子组件 beforeCreate 5.子组件 created 6.子组件 beforeMount 7.子组件 mounted 8.父组件 mounted 更新过程: 1. 父组件 befor…

Unity 之transform.LookAt() 调整一个物体的旋转,使其朝向指定的位置

文章目录 总的介绍补充(用于摄像机跟随的场景) 总的介绍 transform.LookAt 是 Unity 引擎中 Transform 组件的一个方法,用于调整一个物体的旋转,使其朝向指定的位置。通常情况下,它被用来使一个物体(如摄像…

cpolar做一个内网穿透

因为不在公司,需要访问公司的数据库,所以做一个内网穿透 下载安装 下载地址: https://dashboard.cpolar.com/get-started 下载后是个压缩包,解压后傻瓜式安装 操作隧道 安装后打开Cpolar Web UI 登录账号,查看隧…

Linux内核学习(九)—— 虚拟文件系统(基于Linux 2.6内核)

虚拟文件系统(VFS)作为内核子系统,为用户空间程序提供了文件和文件系统相关的接口。通过虚拟文件系统,程序可以利用标准的 Unix 系统调用对不同的文件系统(甚至不同介质上的文件系统)进行读写操作。 一、通…

分享几个 Selenium 自动化常用操作

最近工作会用到selenium来自动化操作一些重复的工作,那么在用selenium写代码的过程中,又顺手整理了一些常用的操作,分享给大家。 常用元素定位方法 虽然有关selenium定位元素的方法有很多种,但是对于没有深入学习,尤…

直播平台源码搭建协议讲解篇:传输控制协议TCP

简介: 由于直播平台在当今时代发展的越来越迅速,使得直播平台的技术功能越来越智能,让用户在直播平台中能够和其他用户进行实时互动,让用户可以获取到全世界最新的资讯,让一些用户可以作为主播获得工作,让…

【Hadoop】Hadoop入门概念简介

🍁 博主 "开着拖拉机回家"带您 Go to New World.✨🍁 🦄 个人主页——🎐开着拖拉机回家_Linux,Java基础学习,大数据运维-CSDN博客 🎐✨🍁 🪁🍁 希望本文能够给您带来一定的…

个人记录:划分

原始数据展示 每五个大图移动一次所有的大图名称的小图片。 读取指定图片格式的图片名称,内置函数map执行,文件移动 图片01-17[:27] 图片17-70要改27为25 import os import shutil # source dataset/sat_train/ source_path "/mnt/sdb1/fenghaixia/dsm/da…