node の SQLite

2023-11-06

node操作SQLite

之前在做electron桌面制作番茄钟应用时曾经想过用数据库存储数据,一开始打算mongodb,但是发现不能实现无服务器,那么只能使用SQLite了。

介绍:SQLite 是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是在世界上最广泛部署的 SQL 数据库引擎。SQLite 源代码不受版权限制

现在先让我们尝试使用node来操作SQLite

安装sqlite3库

从前面的介绍当中,可以知道,sqlite是免安装的数据库,所以这里使用数据库就只需要添加一个nodesqlite3库就可以了。

安装命令:yarn add sqlite3 -D

在这里插入图片描述

创建sqlite数据库

当前的node项目地址中并没有sqlite数据库,所以可以通过命令先创建一个数据库,这里使用new sqlite3.Database来连接数据库,如果当前没有,会自动创建一个数据库,并且不同于之前操作mongodb,不用再创建一个集合。

const path = require('path');
const sqlite3 = require('sqlite3');

function SQLiteInit() {
    let rootPath = path.join(__dirname, '../sqlite3.db');

    let db = new sqlite3.Database(rootPath, (err)=>{
        if (err) throw err;
        console.log('数据库连接')
    })
}

效果:
在这里插入图片描述

创建表格并插入数据

有了数据库之后,就需要创建一个数据库表格了

可以创建一个sql语句执行方法,此方法可以通过db.run方法来运行数据sql语句

// 执行sql语句
function runSQL(sqlstr) {
    db.serialize(()=>{
        db.run(sqlstr);
    })
}

创建数据表worker

let db = null;
function SQLiteInit() {
    // 连接数据库
    let rootPath = path.join(__dirname, '../sqlite3.db');
    db = new sqlite3.Database(rootPath)
    // 创建表格
    runSQL(`
        create table worker 
        (
            name text not null,
            age int not null,
            hobby text not null
        );
    `)
    // 关闭连接
    db.close();
}

现在数据库表格worker已经存在了。

接下来的操作就是在表中插入数据了,这里可以使用db.run来一次性插入,也可以通过prepare来分步插入。

let doc = [{
        name: '张三',
        age: 18,
        hobby: '打李四',
    },
    {
        name: '李四',
        age: 18,
        hobby: '打王五',
    },
    {
        name: '王五',
        age: 18,
        hobby: '打张三',
    },
]
let insertInfo = db.prepare('insert into worker (name, age, hobby) values (?, ?, ?)')
doc.forEach((item)=>{
    insertInfo.run(item.name, item.age, item.hobby);
})
insertInfo.finalize();

现在数据也已经插入到数据库当中了


vs codesqlite插件

对于数据库,最好使用可视化界面去操作,一般对sqlite都是推荐用navicate http://www.navicat.com.cn/

不过我这里为了操作快捷,就不用了,在vs code当中,也存在插件可以对sqlite数据库进行简单的操作。插件的名称就叫做SQLite
在这里插入图片描述

安装完插件之后,如果想要打开之前创建的sqlite3.db数据库,需要使用Ctrl+Shift+P打开命令面板,然后输入sqlite,找到Open Database选项打开。

在这里插入图片描述

这样在左侧资源管理器界面中会出现SQLITE EXPLORER

这里可以查看之前创建的sqlite3.db数据库中的表格,在右侧选择创建New Query

在这里插入图片描述

会创建一个.sql文件用于执行sql的命令和语句

写入查询表格命令:

-- SQLite
select * from worker

鼠标右键选择数据库并运行此query

在这里插入图片描述
在这里插入图片描述


接下来对于数据的查询、删除和更新操作其实都与插入类似,其实主要就是在于sqlite语句的编写,这里就不详细写了

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

node の SQLite 的相关文章

随机推荐

  • 【腾讯云 Cloud Studio 实战训练营】提升开发效率与协作:探索腾讯云 Cloud Studio 的强大功能与优势

    文章目录 一 前言 二 认识腾讯云 Cloud Studio 2 1 什么是云端开发环境 2 2 CDE 的特点与优点 2 2 1 提高效率 开发环境一键运行 2 2 2 提高生产力 可以并行的工作 2 2 3 开发更加规范 2 2 4 提
  • vscode设置sdk_1 visual studio code 配置C++开发环境 (windows 开发环境)

    0 引言 最近帮GF 不幸变成ex了 配置C 开发环境 一开始想给她装个visual studio13完事 但是一想到自己安装以及使用时的诸多麻烦 就有点退却 觉得没有这个必要 正好了解到vscode大行其道 决定按照官网指示配置一版 由于
  • 【STM32】中断与NVIC以外部中断为例

    前言 在stm32中姑且可以认为 异常就是中断 单片机上电之后 首先执行启动文件 开辟堆栈之后 开始初始化中断向量表 NVIC NVIC NVIC是嵌套向量中断控制器 控制着整个芯片中断相关的功能 它跟内核紧密耦合 是内核里面的一个外设 三
  • 专家PID控制matlab程序

    专家PID控制matlab程序 1 专家PID控制 专家PID控制的实质是 基于受控对象和控制规律的各种知识 无须知道被控对象的精确模型 利用专家经验来设计PID参数 专家PID控制是一种直接型专家控制器 典型的二阶系统单位阶跃响应误差曲线
  • 【Linux】这篇文章让你彻底搞懂什么是环境变量

    深入理解环境变量 一 什么是环境变量 二 常见的环境变量 2 1 PATH 2 2 HOME 2 3 SHELL 三 查看与设置变量 四 如何理解命令行带参 五 如何通过代码如何获取环境变量 一 什么是环境变量 总述 环境变量 enviro
  • Win10安装Linux虚拟机-安装与使用

    Win10安装Linux虚拟机 安装与使用 1 VMware 的下载 VMWare虚拟机软件是一个 虚拟PC 软件 它使你可以在一台机器上同时运行二个或更多Windows DOS LINUX系统 下载地址 https customercon
  • ie浏览器打不开闪退_教你修复win7IE浏览器闪退的问题

    使用win7系统的朋友不少会使用IE浏览器来访问网页的时候 经常会出现IE浏览器自动退出了 另外在闪退前会有个提示 出现一个问题导致程序停止正常工作 那么这样的问题该怎样解决呢 下面就跟小编来了解一下怎样修复IE浏览器问题吧 Win7 IE
  • Flex3.2 Lists & Grids 内存泄漏

    所有继承于ListBase的类List DataGrid AdvancedDataGrid and TileList 在选中列表中的一项后 增加了鼠标相关Listener 导致泄漏 SDK3 3中已经修改 Sdk3 2中修复补丁http w
  • 使用plsql访问远程数据库

    1 plsql输入ip端口数据库实例名直接登录 Username 用户名 如 scott Password 用户对应密码 如 tiger Database 数据库位置 语法为 ip 端口号 数据库实例名 如 192 168 1 156 15
  • Nand Flash的同步、异步、ONFI、Toggle

    1 SDR和DDR SDR Single Data Rate 写读数据使用上升沿或下降沿来触发 因为只用上升沿或下降沿 对信号准确性要求较低 DDR Double Data Rate 写数据时通过MCU来控制DQS信号跳变沿来触发 即上升沿
  • android fragment 重复创建的问题

    解决fragment重复创建目前用到有两个方法 1 fragment同viewpager一起使用 vp setOffscreenPageLimit 3 设置缓存页面的个数 2 fragment单独使用 在onCreateView 方法中加入
  • 用C语言写UTF-8编码的文件

    原文地址 http blog csdn net zaffix article details 7217701 为实现用C语言写UTF 8编码的文件 测试了以下两种情况 第一种情况 为 fopen 指定一个编码 然后写入 wchar t 字符
  • Flink笔记14:Flink之window起始点的确定与watermark使用详解

    1 window起始时间的确定 在TimeWindow java中有如下方法来确定window的起始时间 public static long getWindowStartWithOffset long timestamp long off
  • win32 API函数大全

    1 API之网络函数 WNetAddConnection 创建同一个网络资源的永久性连接 WNetAddConnection2 创建同一个网络资源的连接 WNetAddConnection3 创建同一个网络资源的连接 WNetCancelC
  • Python网络爬虫之数美滑块的加密及轨迹之动态js参数分析

    前言 数美滑块的加密及轨迹等应该是入门级别的吧 用他们的教程和话来说 就一个des 然后识别缺口位置可以用cv2或者ddddoc 轨迹 也可以随便模拟一个 这些简单的教程 在csdn已经有一大把可以搜到的 但是却很少人告诉你 它的js好像是
  • CMake 命令

    1 Usage cmake options
  • MAC安装渗透测试靶机

    1 mac 安装docker 直接到docker官网下载docker dmg 下载前先要注册docker 下载后直接安装就可以了 docker version 就能看见安装的版本 我的版本17 03 1 ce 2 下载docker镜像ima
  • 了解l电源纹波PSRR----转摘

    PSRR 就是 Power Supply Rejection Ratio 的缩写 中文含意为 电源纹波抑制比 也就是说 PSRR 表示把输入与电源视为两个独立的信号源时 所得到的两个电压增益的比值 基本计算公式为 PSRR 20log Ri
  • 【C语言】-- 整型数据的存储

    目录 1 数据类型的分类 2 基本类型 2 1 基本类型大小 2 2 整型家族 2 3 数据的存储形式 2 4 整形数据的存储方式 1 数据类型的分类 在C语言中有如下类型 2 基本类型 2 1 基本类型大小 一个变量的创建是要在内存中开辟
  • node の SQLite

    node操作SQLite 之前在做electron桌面制作番茄钟应用时曾经想过用数据库存储数据 一开始打算mongodb 但是发现不能实现无服务器 那么只能使用SQLite了 介绍 SQLite 是一个软件库 实现了自给自足的 无服务器的