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. sql语句优化的30种方法

    转载于:https://www.cnblogs.com/Little-Li/p/8031295.html 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的 ...

  2. 【ECharts】1.学习ECharts从现在开始:第一个Echart图形

    首先,你需要下载ECharts所需的文件,我使用的是echarts-2.0.2版本,点击这里下载:echarts-2.0.2 下载解压后,下面有一系列文件夹,其中build中有我们需要引入的JS文件, ...

  3. svn merge操作

    使用SVN做Merge操作时,会包含6个选项,下面就这6个选项给出详细的说明: 1.Merge a range of revisions 此类型应用最为广泛,主要是把源分支中的修改合并到目标分支上来. ...

  4. (三十四)golang--接口

    golang的多态特性主要体现在接口上: 主要优势:高内聚低耦合: package main import ( "fmt" ) type usb interface { start ...

  5. python-9-列表的增删改查

    前言 本节是:列表(list)的增删改查.什么是列表? 列表(list)是最常用的Python数据类型,它可以作为一个方括号[]内的逗号分割值出现.如:[1,5,"b"] 一.增 ...

  6. Ubuntu 16.04上源码编译和安装pytorch教程,并编写C++ Demo CMakeLists.txt | tutorial to compile and use pytorch on ubuntu 16.04

    本文首发于个人博客https://kezunlin.me/post/54e7a3d8/,欢迎阅读最新内容! tutorial to compile and use pytorch on ubuntu ...

  7. ubuntu16.04 下anaconda3安装教程

    贴一个成功的连接: https://blog.csdn.net/u012243626/article/details/82469174

  8. 原生PHP和MYSQL练习登陆验证和查询数据到表格

    直接上代码吧 <?php header("Content-type: text/html; charset=utf-8"); //数据量链接 $conn=mysqli_con ...

  9. Triangulation by Ear Clipping(耳切法处理多边形三角划分)(转载)

    转载自: https://www.cnblogs.com/xignzou/p/3721494.html 使用EarClipping三角化多边形(翻译) ---Triangulation by Ear ...

  10. IIS 503错误解决办法 HTTP Error 503

    今天在win7上部署一个IIS网站,莫名出现HTTP Error 503,于是对比了一下之前的网站配置,依然无果. 无奈之下,挨个查看IIS配置.查看“事件查看器”,尝试修改应用程序池 - 高级设置 ...