React Native 使用 realm  数据库

realm 是一款专为移动 ​ 端开发的高性能数据库,其宣称自己是最快的 react-native 数据库。
realm 整体的优点有这么四点:
1.简单易用,
2.跨平台,
3.快速性能优越,
4.提供高级功能。realm 核心数据引擎用 C++ 打造,并不是建立在 SQLite 之上的 ORM。因此性能就是比普通的 ORM 要快很多,甚至比单独无封装的 SQLite 还要快。同时因为是 ORM,本身在设计时也针对移动设备(iOS、Android),所以简单易用,学习成本很低。

一、安装依赖

npm i -S realm

Link

react-native link

二、使用

1)先定义工具文件

RealmUtil.js

import Realm from 'realm';

/***表定义区**/
export const HistoryTableName = 'History';
export const CityTableName = 'City'; const HistorySchema = {
name: HistoryTableName,
primaryKey: 'id',
properties: {
id: 'int',
name: 'string',
}
}; const CitySchema = {
name: CityTableName,
primaryKey: 'city_id',
properties: {
city_id: 'int',
city_name: 'string',
}
}; const instance = new Realm({
schema: [
HistorySchema,
CitySchema,
],
deleteRealmIfMigrationNeeded: true,
inMemory: false,
}); /***表使用区**/
export function writeToRealm(obj,tabName) {
return new Promise((resolve, reject) => {
instance.write(() => {
instance.create(tabName, obj, true)
resolve(true)
})
})
} export function queryAllFromRealm(tabName) {
return new Promise((resolve, reject) => {
let obj = instance.objects(tabName);
let objStr = JSON.stringify(obj);
resolve(JSON.parse(objStr))
})
} export function clearAllFromRealm(tabName) {
return new Promise((resolve, reject) => {
instance.write(() => {
let arrays = instance.objects(tabName);
instance.delete(arrays);
resolve(true)
})
})
} export function clearRowFromRealm(id,tabName) {
return new Promise((resolve, reject) => {
instance.write(() => {
let arrays = instance.objects(tabName);
let row = arrays.filtered('id==' + id);
instance.delete(row);
resolve(true)
})
})
}

2)调用文件

import React, {Component} from "react";
import {StyleSheet, Text, ToastAndroid, TouchableHighlight, View,} from 'react-native';
import {
HistoryTableName,
CityTableName,
clearAllFromRealm,
queryAllFromRealm,
writeToRealm,
clearRowFromRealm
} from "./RealmUtil"; export default class TestRealm extends Component {
componentWillMount() { } //表1操作
_addData() {
clearAllFromRealm(HistoryTableName); let row1 = {"id": , "name": "战狼1"};
writeToRealm(row1, HistoryTableName).then(() => {
ToastAndroid.show('写入完成1', ToastAndroid.SHORT);
});
let row2 = {"id": , "name": "战狼2"};
writeToRealm(row2, HistoryTableName).then(() => {
ToastAndroid.show('写入完成2', ToastAndroid.SHORT);
});
} _readAllData() {
queryAllFromRealm(HistoryTableName).then((list) => {
for (let key in list) {
ToastAndroid.show('id:' + list[key].id + ',name:' + list[key].name, ToastAndroid.SHORT);
}
});
} _updateData() {
let row2 = {"id": , "name": "北京222"};
writeToRealm(row2, HistoryTableName).then(() => {
ToastAndroid.show('修改完成', ToastAndroid.SHORT);
});
} _delRowData() {
//删除第一行
clearRowFromRealm(, HistoryTableName).then(() => {
ToastAndroid.show('删除完成', ToastAndroid.SHORT);
});
} //表2操作
_addData2() {
clearAllFromRealm(CityTableName); let row1 = {"city_id": , "city_name": "上海"};
writeToRealm(row1, CityTableName).then(() => {
ToastAndroid.show('2写入完成1', ToastAndroid.SHORT);
});
let row2 = {"city_id": , "city_name": "北京"};
writeToRealm(row2, CityTableName).then(() => {
ToastAndroid.show('2写入完成2', ToastAndroid.SHORT);
});
} _readAllData2() {
queryAllFromRealm(CityTableName).then((list) => {
for (let key in list) {
ToastAndroid.show('城市ID:' + list[key].city_id + ',城市名:' + list[key].city_name, ToastAndroid.SHORT);
}
});
} render() {
return (
<View style={{flex: }}>
<View style={{padding: }}><Text>表1操作</Text></View>
<TouchableHighlight onPress={() => this._delRowData()} style={styles.button} underlayColor="#a5a5a5">
<Text>删除第一行</Text>
</TouchableHighlight>
<TouchableHighlight onPress={() => this._addData()} style={styles.button} underlayColor="#a5a5a5">
<Text>增加数据</Text>
</TouchableHighlight>
<TouchableHighlight onPress={() => this._updateData()} style={styles.button} underlayColor="#a5a5a5">
<Text>修改数据</Text>
</TouchableHighlight>
<TouchableHighlight onPress={() => this._readAllData()} style={styles.button} underlayColor="#a5a5a5">
<Text>读取全部数据</Text>
</TouchableHighlight> <View style={{padding: , marginTop: }}><Text>表2操作</Text></View>
<TouchableHighlight onPress={() => this._addData2()} style={styles.button} underlayColor="#a5a5a5">
<Text>增加数据</Text>
</TouchableHighlight>
<TouchableHighlight onPress={() => this._readAllData2()} style={styles.button} underlayColor="#a5a5a5">
<Text>读取全部数据</Text>
</TouchableHighlight>
</View>
); }
} const styles = StyleSheet.create({
button: {
margin: ,
backgroundColor: 'white',
padding: ,
borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: '#cdcdcd'
},
});

三、如何查看数据文件

笔者是在Genymotion模拟器里测试的

思路是使用 adb 命令 ,先 复制到本地 windows 下,然后用 Realm Studio 打开 realm 文件即可!

复制步骤如下:

1)先连接远程

adb remount

2)查看对应目录下文件

adb ls /data/data/com.testdemo/files

看到结果如下:

000041f9 00001000 5cece0e8 .
000041e9 00001000 5cece048 ..
000041c0 00001000 5cece0e8 default.realm.management
00008180 00316390 5cece0e7 ReactNativeDevBundle.js
00008180 00000498 5cece0fe default.realm.lock
00008180 00004000 5cece0fc default.realm
00001180 00000000 5cece0fc default.realm.note

3)对,没错,然后复制  default.realm  出来就行

adb pull /data/data/com.testdemo/files/default.realm  d:/m

注意: com.testdemo   为自己的包名,要对应的修改 。 最后的 d:/m  为 自己要复制的win目录。

本博客地址: wukong1688

本文原文地址:https://www.cnblogs.com/wukong1688/p/10935043.html

转载请著名出处!谢谢~~

今日心得:

苦难

[RN] React Native 使用 realm 数据库的更多相关文章

  1. [RN] React Native 实现图片预览

    [RN] React Native 实现图片预览 效果预览: 代码如下: 'use strict'; import React, {Component} from 'react'; import {I ...

  2. [RN] React Native 常见基本问题归纳总结

    [RN] React Native  常见基本问题归纳总结 本问题总结涉及到版本为: "react": "16.8.3","react-native& ...

  3. [RN] React Native 关闭所有黄色警告

    [RN] React Native 关闭所有黄色警告 console.ignoredYellowBox = ['Warning: BackAndroid is deprecated. Please u ...

  4. [RN] React Native 下实现底部标签(支持滑动切换)

    上一篇文章 [RN] React Native 下实现底部标签(不支持滑动切换) 总结了不支持滑动切换的方法,此篇文章总结出 支持滑动 的方法 准备工作之类的,跟上文类似,大家可点击上文查看相关内容. ...

  5. [RN] React Native 幻灯片效果 Banner

    [RN] React Native 幻灯片效果 Banner 1.定义Banner import React, {Component} from 'react'; import {Image, Scr ...

  6. [RN] React Native 常用命令行

    [RN] React Native 常用命令行 1.查看当前版本 react-native --version 或 react-native -v 2.创建指定版本的React Native项目 1) ...

  7. [RN] React Native 实现 类似QQ 登陆页面

    [RN] React Native 实现 类似QQ 登陆页面 一.主页index.js 项目目录下index.js /** * @format */ import {AppRegistry} from ...

  8. [RN] React Native 使用 阿里 ant-design

    React Native 使用 阿里 ant-design 实例效果如图: 一.安装 npm install antd-mobile-rn --save npm install babel-plugi ...

  9. [RN] React Native 获取地理位置

    React Native 获取地理位置 实现原理: 1.用  navigator.geolocation.getCurrentPosition 获取到坐标信息 2.调用 高德地图 接口,解析位置数据 ...

随机推荐

  1. windows/tomcat 修改java虚拟机JVM以utf-8字符集加载class文件的两种方式

      1.情景展示 做了这么长时间的java开发,但是,你知道JVM是以怎样的编码加载.解析class文件的吗? 我们知道,通常情况下,我们会将java文件的字符集修改成utf-8,这样,理所当然地就认 ...

  2. 多台Linux 7.x服务器具有相同的UUID网络链接参数,肿么办?

    1.查看多台服务器的UUID网络链接参数是否相同 我这里使用SecureCRT的全部交互功能,直接批量输出  /etc/sysconfig/network-scripts/ifcfg-ens33 的内 ...

  3. VBA基础 - 数据类型

    概要 学习一种新语言, 数据类型和关键字是第一步. 数据类型 常用的数据类型如下: 类型 存储空间 范围 Boolean 2 bytes True 或者 False Byte 1 byte 0 ~ 2 ...

  4. QQ音乐2019客户端-获取任意歌单完整歌曲列表和下载音乐文件方法

    步骤 1.在web网站上搜搜任意歌单 https://y.qq.com/#type=index/ 例如:中国好声音4.5.6.7.8季 打开后显示网址:  https://y.qq.com/n/yqq ...

  5. 一文读懂前端技术演进:盘点Web前端20年的技术变迁史

    本文原文由作者“司徒正美”发布于公众号“前端你别闹”,即时通讯网收录时有改动,感谢原作者的分享. 1.引言 1990 年,第一个Web浏览器的诞生:1991 年,WWW诞生,这标志着前端技术的开始. ...

  6. 从游击队到正规军:马蜂窝旅游网的IM系统架构演进之路

    本文引用自马蜂窝公众号,由马蜂窝技术团队原创分享. 一.引言 今天,越来越多的用户被马蜂窝持续积累的笔记.攻略.嗡嗡等优质的分享内容所吸引,在这里激发了去旅行的热情,同时也拉动了马蜂窝交易的增长.在帮 ...

  7. python asyncio 协程调用task步骤

    import asyncio async def compute(x, y): print("Compute %s + %s ..." % (x, y)) await asynci ...

  8. Python自定义注解

    Python3.0之后加入新特性Decorators,以@为标记修饰function和class.有点类似c++的宏和java的注解.Decorators用以修饰约束function和class,分为 ...

  9. 微软宣布.NET Native预览版 C#可编译为本地机器码【转】

    英文原文:Announcing .NET Native Preview 微软在 MSDN 博客上宣布了 .NET Native 的开发者预览版..NET Native 可以将 C# 代码编译成本地机器 ...

  10. 阿里开源 KT Connnect,轻量级云原生测试环境治理平台来啦!

    作者| 阿里云技术专家 郑云龙(砧木) 目前越来越多的开发者开始采纳 Kubernetes 管理基础设施环境,并通过 Kubernetes 完成日常的开发,测试以及生产发布活动,为了能够有效的帮助开发 ...