news 2026/4/15 8:06:32

UniApp 集成 SQLite 数据库完整教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UniApp 集成 SQLite 数据库完整教程

一、环境准备

1. 平台支持情况

  • ​App端(Android/iOS)​​: 完全支持SQLite数据库
  • ​H5端​​: 不支持,需使用WebSQL或IndexedDB替代
  • ​小程序端​​: 部分支持,需使用小程序自带的数据库API

2. 插件安装

推荐使用uni-sqlite插件,该插件对原生SQLite进行了封装,提供了统一的API接口:

​安装步骤​​:

  1. 打开HBuilderX,进入项目
  2. 点击菜单"工具"→"插件安装"
  3. 搜索"sqlite",安装"uni-sqlite"插件

二、数据库操作封装

1. 创建数据库工具文件

在项目根目录创建common/sqlite.js文件,封装常用数据库操作方法:

const dbName = "myDatabase"; // 数据库名称 const dbPath = "_doc/myDatabase.db"; // 存储路径 // 打开数据库 export function openDatabase() { return new Promise((resolve, reject) => { plus.sqlite.openDatabase({ name: dbName, path: dbPath, success: function(e) { console.log('数据库打开成功'); resolve(e); }, fail: function(e) { console.error('数据库打开失败:', JSON.stringify(e)); reject(e); } }); }); } // 检查数据库是否打开 export function isOpenDatabase() { return plus.sqlite.isOpenDatabase({ name: dbName, path: dbPath }); } // 执行SQL语句 export function executeSql(sql, args = []) { return new Promise((resolve, reject) => { plus.sqlite.executeSql({ name: dbName, sql: sql, args: args, success: function(e) { resolve(e); }, fail: function(e) { reject(e); } }); }); } // 查询数据 export function selectSql(sql, args = []) { return new Promise((resolve, reject) => { plus.sqlite.selectSql({ name: dbName, sql: sql, args: args, success: function(e) { resolve(e); }, fail: function(e) { reject(e); } }); }); } // 关闭数据库 export function closeDatabase() { return new Promise((resolve, reject) => { plus.sqlite.closeDatabase({ name: dbName, success: function(e) { resolve(e); }, fail: function(e) { reject(e); } }); }); }

三、数据库初始化

在应用启动时初始化数据库:

// 在App.vue的onLaunch中初始化 import { openDatabase, executeSql } from '@/common/sqlite.js'; export default { onLaunch() { this.initDatabase(); }, methods: { async initDatabase() { try { // 打开数据库 await openDatabase(); // 创建用户表 await executeSql(` CREATE TABLE IF NOT EXISTS users ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, email TEXT UNIQUE, age INTEGER, created_at DATETIME DEFAULT CURRENT_TIMESTAMP ) `); console.log('数据库初始化成功'); } catch (error) { console.error('数据库初始化失败:', error); } } } }

四、CRUD操作示例

1. 插入数据

async function insertUser(user) { try { const result = await executeSql( 'INSERT INTO users (name, email, age) VALUES (?, ?, ?)', [user.name, user.email, user.age] ); console.log('插入成功,ID:', result.insertId); return result.insertId; } catch (error) { console.error('插入失败:', error); throw error; } }

2. 查询数据

// 查询所有用户 async function getAllUsers() { try { const result = await selectSql('SELECT * FROM users'); return result; } catch (error) { console.error('查询失败:', error); throw error; } } // 条件查询 async function getUserById(id) { try { const result = await selectSql( 'SELECT * FROM users WHERE id = ?', [id] ); return result.length > 0 ? result[0] : null; } catch (error) { console.error('查询失败:', error); throw error; } }

3. 更新数据

async function updateUser(id, user) { try { const result = await executeSql( 'UPDATE users SET name = ?, email = ?, age = ? WHERE id = ?', [user.name, user.email, user.age, id] ); console.log('更新成功,影响行数:', result.rowsAffected); return result.rowsAffected; } catch (error) { console.error('更新失败:', error); throw error; } }

4. 删除数据

async function deleteUser(id) { try { const result = await executeSql( 'DELETE FROM users WHERE id = ?', [id] ); console.log('删除成功,影响行数:', result.rowsAffected); return result.rowsAffected; } catch (error) { console.error('删除失败:', error); throw error; } }

五、事务处理

async function transferMoney(fromId, toId, amount) { try { // 开始事务 await executeSql('BEGIN TRANSACTION'); // 扣款 await executeSql( 'UPDATE accounts SET balance = balance - ? WHERE id = ?', [amount, fromId] ); // 收款 await executeSql( 'UPDATE accounts SET balance = balance + ? WHERE id = ?', [amount, toId] ); // 提交事务 await executeSql('COMMIT'); console.log('转账成功'); } catch (error) { // 回滚事务 await executeSql('ROLLBACK'); console.error('转账失败:', error); throw error; } }

六、页面中使用示例

<template> <view> <button @click="addUser">添加用户</button> <button @click="getUsers">查询用户</button> <view v-for="user in userList" :key="user.id"> {{ user.name }} - {{ user.email }} </view> </view> </template> <script> import { insertUser, getAllUsers } from '@/common/sqlite.js'; export default { data() { return { userList: [] }; }, methods: { async addUser() { const user = { name: '张三', email: 'zhangsan@example.com', age: 25 }; try { await insertUser(user); uni.showToast({ title: '添加成功' }); } catch (error) { uni.showToast({ title: '添加失败', icon: 'none' }); } }, async getUsers() { try { this.userList = await getAllUsers(); } catch (error) { console.error('查询失败:', error); } } } }; </script>

七、注意事项

  1. ​平台兼容性​​: 确保只在App端使用SQLite,H5和小程序端需使用其他存储方案
  2. ​数据安全​​: 对输入数据进行验证和转义,防止SQL注入攻击
  3. ​性能优化​​: 批量操作时使用事务,避免频繁打开关闭数据库连接
  4. ​错误处理​​: 所有数据库操作都应添加try-catch块进行错误处理
  5. ​资源释放​​: 在应用退出或页面销毁时及时关闭数据库连接

通过以上步骤,你可以在UniApp项目中成功集成SQLite数据库,实现本地数据的持久化存储和高效操作。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 9:04:09

ChromeDriver版本匹配难?AI帮你查找对应关系

ChromeDriver版本匹配难&#xff1f;AI帮你查找对应关系 在自动化测试和爬虫开发的日常中&#xff0c;你是否也遇到过这样的场景&#xff1a;CI流水线突然报错&#xff0c;排查半天才发现是Chrome浏览器悄悄升级了&#xff0c;而本地或服务器上的 chromedriver 还停留在旧版本…

作者头像 李华
网站建设 2026/4/14 5:22:52

低成本训练的秘密:VibeThinker如何实现高数据利用率

低成本训练的秘密&#xff1a;VibeThinker如何实现高数据利用率 在大模型动辄千亿参数、训练成本突破百万美元的今天&#xff0c;一个仅用7,800美元训练出的15亿参数小模型&#xff0c;却能在AIME数学竞赛和编程算法任务中击败数十倍规模的对手——这听起来像技术界的“以小博大…

作者头像 李华
网站建设 2026/4/10 13:53:53

Geckodriver零基础实战指南:告别配置烦恼的终极解决方案

Geckodriver零基础实战指南&#xff1a;告别配置烦恼的终极解决方案 【免费下载链接】geckodriver WebDriver for Firefox 项目地址: https://gitcode.com/gh_mirrors/ge/geckodriver 还在为自动化测试环境的搭建而头疼吗&#xff1f;作为Firefox浏览器的核心WebDriver驱…

作者头像 李华
网站建设 2026/4/13 15:31:07

MTKClient刷机工具V6版本实战指南:常见问题深度解析与优化方案

MTKClient刷机工具V6版本实战指南&#xff1a;常见问题深度解析与优化方案 【免费下载链接】mtkclient MTK reverse engineering and flash tool 项目地址: https://gitcode.com/gh_mirrors/mt/mtkclient MTKClient作为一款专业的联发科芯片设备刷机工具&#xff0c;其L…

作者头像 李华
网站建设 2026/4/10 1:37:14

C#算法题不会做?VibeThinker提供完整解法

VibeThinker-1.5B&#xff1a;小模型如何破解高难度算法题&#xff1f; 在 LeetCode 上卡壳、面试前刷题效率低下、竞赛中思路断片——这些几乎是每个程序员都经历过的窘境。传统上&#xff0c;我们会依赖大模型来生成代码或解释算法&#xff0c;但往往得到的是模糊的伪代码、逻…

作者头像 李华