Electron那些事10:本地数据库sqlite

Electron那些事10:本地数据库sqlite【前言】上一节讲了本地日志,本地数据(文件)的部分,详见:Electron那些事09:本地数据_uikoo9的博客-CSDN博客虽然本地日志可以记录日志信息,本地数据可以记录简单的配置文件,但是像一些复杂的业务,需要维护一个本地数据库进行查询,本节讲一下本地数据库sqlite【sqlite】sqlite是有名的本地数据库,在很多系统中都有应用,SQLiteHomePage当然也有nodejs的版本,一般配套和electron使用,sqlite3-np…

大家好,又见面了,我是你们的朋友全栈君。

Electron那些事10:本地数据库sqlite

【前言】

上一节讲了本地日志,本地数据(文件)的部分,

详见:Electron那些事09:本地数据_uikoo9的博客-CSDN博客 

虽然本地日志可以记录日志信息,

本地数据可以记录简单的配置文件,

但是像一些复杂的业务,需要维护一个本地数据库进行查询,本节讲一下本地数据库sqlite

【sqlite】

sqlite是有名的本地数据库,在很多系统中都有应用,SQLite Home Page

Electron那些事10:本地数据库sqlite

当然也有nodejs的版本,一般配套和electron使用,sqlite3 – npm

默认的版本是nodejs版本,electron内可以直接使用,

还有node-webkit版本,这个版本是给node-webkit类环境使用,例如nw框架使用

Electron那些事10:本地数据库sqlite

另外还有sqlcipher版本,就是加密的本地数据库版本

Electron那些事10:本地数据库sqlite

【安装和使用】

安装比较简单

npm i sqlite3

先看官网一个例子

var sqlite3 = require('sqlite3').verbose();
var db = new sqlite3.Database(':memory:');

db.serialize(function() {
  db.run("CREATE TABLE lorem (info TEXT)");

  var stmt = db.prepare("INSERT INTO lorem VALUES (?)");
  for (var i = 0; i < 10; i++) {
      stmt.run("Ipsum " + i);
  }
  stmt.finalize();

  db.each("SELECT rowid AS id, info FROM lorem", function(err, row) {
      console.log(row.id + ": " + row.info);
  });
});

db.close();

 也比较简单,创建db,创建table,插入数据,然后查询,效果如下

Electron那些事10:本地数据库sqlite

【创建数据库】 

创建数据库的文档:https://github.com/mapbox/node-sqlite3/wiki/API#new-sqlite3databasefilename-mode-callback

Electron那些事10:本地数据库sqlite

filename,

当传入:memory:时,会将数据库保存在内存中,不会持久化

当传入具体的文件名时,会在对应的位置创建一个文件

例如直接传入test.db时,会在根目录下创建一个test.db文件

Electron那些事10:本地数据库sqlite

当传入具体的文件路径时,会在对应的路径下创建文件,

这样在electron应用下,就可以结合上一节的内容,将db文件创建在应用目录下了

Electron那些事10:本地数据库sqlite

【创建和更新表格】

创建数据库表也比较简单,使用sql创建即可,

db.run("CREATE TABLE lorem (info TEXT)");

 sqlite支持哪些数据类型呢,可以看这里,Datatypes In SQLite

Electron那些事10:本地数据库sqlite

可以需要注意,可以传入callback函数,如果创建失败,会报错,如果成功会返回null

    db.run(sql, (e) => {
        if(e) throw e;
    });

创建表格详细的文档可以看这里,CREATE TABLE 

Electron那些事10:本地数据库sqlite

更新表格可以看这里,ALTER TABLE

Electron那些事10:本地数据库sqlite

创建view,可以看这里,CREATE VIEW

Electron那些事10:本地数据库sqlite

删除表格和view,

DROP TABLE

https://www.sqlite.org/lang_dropview.html

【插入数据】

插入数据需要先使用db.prepare准备好statement语句,然后run,然后finalize写入,如下

Electron那些事10:本地数据库sqlite

详细可以看这里,INSERT 

Electron那些事10:本地数据库sqlite

【查询数据】 

查询数据,可以看这里,SELECT 

Electron那些事10:本地数据库sqlite

这里有三种返回数据的方法,all,each,get

all,返回所有数据

each,多次回调,返回每一个数据

get,返回第一个数据

// 多次回调
db.each('SELECT * FROM t_project', function(err, row) {
    console.log(row);
});

// 返回第一行
db.get('SELECT * FROM t_project', function(err, row) {
    console.log(row);
});

// 返回所有数据
db.all('SELECT * FROM t_project', function(err, row) {
    console.log(row);
});

【删除数据】

删除数据可以看这里,DELETE

Electron那些事10:本地数据库sqlite

【m1下问题】

sqlite3这个npm包,单独使用没有问题,

但是在mac m1+electron环境下使用会报错,如下

Electron那些事10:本地数据库sqlite

报错提示找不到arm64下的文件,但是sqlite3下有x64版本的,

修复的版本,npm i的时候添加指定系统

npm install --target_arch=arm64

 这样即可安装arm64版本的sqlite3

【qiao-sqlite】

将常见的sqlite操作封装了一个npm,qiao-sqlite – npm

create db

Electron那些事10:本地数据库sqlite

create table

Electron那些事10:本地数据库sqlite

drop table

Electron那些事10:本地数据库sqlite 

 

show tables

Electron那些事10:本地数据库sqlite

以及常见的数据操作

insert data

modify data

get data

select data

del data

等操作 

【总结】

1.使用sqlite作为本地数据库

2.创建数据库

3.创建和修改表

4.插入数据,修改数据,查询数据,删除数据等

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/143944.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • Jlink或者stlink用于SWD接口下载程序

    Jlink或者stlink用于SWD接口下载程序最近要使用stm32f103c8t6最小系统板,直接ISP串口下载程序太麻烦,就想着使用swd接口来调试。结果:通过SWD接口下载程序成功,但调试失败,还不知原因,会的的人麻烦交流一下。SWD接口:3.3VDIO(数据)CLK(时钟)GND1.首先声明jlink和stlink都有jtag和swd调试功能。jlink接口如下:如图,我使用的就是VCC…

  • JVM优化[通俗易懂]

    JVM优化[通俗易懂]为什么要进行JVM优化?在本地开发环境中我们很少有需求对JVM进行优化,但是到了生产环境我们的程序可能出现如下问题:运行的引用“卡住了”,日志不输出,程序没反应服务器的CPU负载突然升高在多线程应用下,如何合理的分配线程的数量。。。。。。。。。通过Java-server和java-client设置JVM的运行参数serverVM的初始堆空间会大一些,默认使用的是并行垃圾回…

  • Red Hat Enterprise Linux ISO 全镜像下载

    Red Hat Enterprise Linux ISO 全镜像下载1、iso网盘下载地址:https://wanghualang.pipipan.com/dir/13133650-26232498-a8efb3/2、中国大陆开源镜像站汇总,企业贡献: 搜

  • inputstreamreader和inputstream_FileInputStream

    inputstreamreader和inputstream_FileInputStream我们的机器只会读字节码,而我们人却很难读懂字节码,所以人与机器交流过程中需要编码解码。InputStreamReader及其子类FileReader:(从字节到字符)是个解码过程;OutputStreamWrite及其子类FileWriter:(从字符到字节)是个编码过程。InputStreamReader这个解码过程中,最主要的就是StreamDecoder类 

  • python基础(5)字典「建议收藏」

    python基础(5)字典「建议收藏」字典字典的key和value一一对应的,字典是可变的,也是有序的(python3.6版本开始字典有序),可迭代的增加元素当key不存在时,直接赋值a={"status"

  • JAX-WS手动配置实例

    JAX-WS手动配置实例随着近几年来,SOA,EAI等架构体系的日渐成熟,Webservice越来越炽手可热,尤其是在企业做异质平台整合时成为了首选的技术。Java的Webservice技术更是层出不穷,比较流行的有:  Axis2,SpringWS以及Jaxws。   本人在日常工作和以往工程中,在使用了上述这些Webservice后进行了总结,比较,最终觉得jaxws是目前最标准,需要额外第三方插件

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号