[RN] React Native 使用 realm 数据库
React Native 使用 realm 数据库
realm 整体的优点有这么四点:
一、安装依赖
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 数据库的更多相关文章
- [RN] React Native 实现图片预览
		[RN] React Native 实现图片预览 效果预览: 代码如下: 'use strict'; import React, {Component} from 'react'; import {I ... 
- [RN] React Native  常见基本问题归纳总结
		[RN] React Native 常见基本问题归纳总结 本问题总结涉及到版本为: "react": "16.8.3","react-native& ... 
- [RN] React Native 关闭所有黄色警告
		[RN] React Native 关闭所有黄色警告 console.ignoredYellowBox = ['Warning: BackAndroid is deprecated. Please u ... 
- [RN] React Native 下实现底部标签(支持滑动切换)
		上一篇文章 [RN] React Native 下实现底部标签(不支持滑动切换) 总结了不支持滑动切换的方法,此篇文章总结出 支持滑动 的方法 准备工作之类的,跟上文类似,大家可点击上文查看相关内容. ... 
- [RN] React Native 幻灯片效果 Banner
		[RN] React Native 幻灯片效果 Banner 1.定义Banner import React, {Component} from 'react'; import {Image, Scr ... 
- [RN] React Native 常用命令行
		[RN] React Native 常用命令行 1.查看当前版本 react-native --version 或 react-native -v 2.创建指定版本的React Native项目 1) ... 
- [RN] React Native 实现 类似QQ 登陆页面
		[RN] React Native 实现 类似QQ 登陆页面 一.主页index.js 项目目录下index.js /** * @format */ import {AppRegistry} from ... 
- [RN] React Native 使用 阿里 ant-design
		React Native 使用 阿里 ant-design 实例效果如图: 一.安装 npm install antd-mobile-rn --save npm install babel-plugi ... 
- [RN] React Native 获取地理位置
		React Native 获取地理位置 实现原理: 1.用 navigator.geolocation.getCurrentPosition 获取到坐标信息 2.调用 高德地图 接口,解析位置数据 ... 
随机推荐
- 对mglearn库的理解(转)
			https://blog.csdn.net/az9996/article/details/86490496 
- 【新特性速递】单元格导航(上下左右键,TAB键和ENTER键)
			上下左右按键 其实单元格导航(上下左右按键,需要启用表格的ShowSelectedCell属性)一直都存在,只不过之前的版本(v5.5.0)有一些小的BUG. BUG1 比如锁定列存在时,上下左右键只 ... 
- 海边拾贝-A-算法篇
			收集若干算法博客地址,不定期会更新: 算法 陈浩,leetcode 的C++解法 https://github.com/haoel/leetcode 王亮,很多题目讲解的比较详细 https:/ ... 
- HDU 6148 (数位DP)
			### HDU 6148 题目链接 ### 题目大意: 众所周知,度度熊非常喜欢数字. 它最近发明了一种新的数字:Valley Number,像山谷一样的数字. 当一个数字,从左到右依次看过去数字没有 ... 
- MSM8909中LK阶段LCM屏适配与显示流程分析(一)
			1.前言 在驱动开发中,我们往往需要适配一些新的屏幕或者调试一些屏幕的参数等,对于Qualcomm的MSM8909这款SoC,当启动Android系统时,会有一个LK阶段,该阶段用来启动Linux内核 ... 
- RStudio 不中断下载依赖包
			修改下载方式: 
- redis的3种过期键删除策略
			Redis的过期键的过期时间都保存在过期字典中,过期键的删除策略有三种,分别是定时删除.惰性删除和定期删除. 定时删除 定时删除策略,是指在设置键的过期时间的同时,创建一个定时器,让定时器在键的过期时 ... 
- Vue基础框架
			<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- 设置语言为 ... 
- ADO.NET中的5个主要对象
			1.Connection:主要是开启程序和数据库之间的连接.没有利用连接对象将数据库打开,是无法从数据库中取得数据的. Close和Dispose的区别,Close以后还可以Open,Dispose以 ... 
- python常用库简单使用( PyPDF2 )
			PyPDF2学习 1 这个模块的名字对大小写是敏感的,所以,确保y是小写的,其他字母都是大写的 
