首页 > web前端 > js教程 > 正文

React Native中使用Sqlite数据库的实例详解

零下一度
发布: 2017-06-24 14:35:13
原创
3616人浏览过
使用Sqllite可能用不同的环境创建出来的项目,比如说:用Expo创建的就可能和这个不一样!但是具体思路都是一样的,希望这篇文章可以帮助到大家!

1.安装

命令行进入到ReactNative项目根目录下执行

npm install React-native-sqlite-storage --save

 

2.进行全局Gradle设置
编辑 android/settings.gradle文件,添加以下内容
include ':react-native-sqlite-storage'
project(':react-native-sqlite-storage').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-sqlite-storage/src/android')
3.修改android/app/build.gradle文件

dependencies 里面添加  compile project(':react-native-sqlite-storage')


4.编辑MainApplication.Java文件,在MainActivitiy.java中注册sqlite模块

import org.pgsqlite.SQLitePluginPackage;

[java] view plain copy
  1. @Override  

  2.     protected List<ReactPackage> getPackages() {  

  3.       return Arrays.<ReactPackage>asList(  

  4.           new MainReactPackage(),  

  5.           new SQLitePluginPackage(),  

  6.           new BaiduMapPackage(getApplicationContext())  

  7.       );  

  8.     }  

截图如下:

5.使用

编写sqlite.js文件,引入组件     import SQLiteStorage from 'react-native-sqlite-storage';

注意每一个打印异常,不然可能看不到哪里出错了

[javascript] view plain copy
  1. import React,{Component} from 'react';  

  2. import{  

  3.   ToastAndroid,  

  4. } from 'react-native';  

  5. import SQLiteStorage from 'react-native-sqlite-storage';  

  6. SQLiteStorage.DEBUG(true);  

  7. var database_name = "test.db";//数据库文件  

  8. var database_version = "1.0";//版本号  

  9. var database_displayname = "MySQLite";  

  10. var database_size = -1;//-1应该是表示无限制  

  11. var db;  

  12. export default class  SQLite extends Component{  

  13.     componentWillUnmount(){  

  14.     if(db){  

  15.         this._successCB('close');  

  16.         db.close();  

  17.     }else {  

  18.         console.log("SQLiteStorage not open");  

  19.     }  

  20.   }  

  21.   open(){  

  22.     db = SQLiteStorage.openDatabase(  

  23.       database_name,  

  24.       database_version,  

  25.       database_displayname,  

  26.       database_size,  

  27.       ()=>{  

  28.           this._successCB('open');  

  29.       },  

  30.       (err)=>{  

  31.           this._errorCB('open',err);  

  32.       });  

  33.     return db;  

  34.   }  

  35.   createTable(){  

  36.     if (!db) {  

  37.         this.open();  

  38.     }  

  39.     //创建用户表  

  40.     db.transaction((tx)=> {  

  41.       tx.executeSql('CREATE TABLE IF NOT EXISTS USER(' +  

  42.           'id INTEGER PRIMARY KEY  AUTOINCREMENT,' +  

  43.           'name varchar,'+  

  44.           'age VARCHAR,' +  

  45.           'sex VARCHAR,' +  

  46.           'phone VARCHAR,' +  

  47.           'email VARCHAR,' +  

  48.           'qq VARCHAR)'  

  49.           , [], ()=> {  

  50.               this._successCB('executeSql');  

  51.           }, (err)=> {  

  52.               this._errorCB('executeSql', err);  

  53.         });  

  54.     }, (err)=> {//所有的 transaction都应该有错误的回调方法,在方法里面打印异常信息,不然你可能不会知道哪里出错了。  

  55.         this._errorCB('transaction', err);  

  56.     }, ()=> {  

  57.         this._successCB('transaction');  

  58.     })  

  59.     }  

  60.   deleteData(){  

  61.     if (!db) {  

  62.         this.open();  

  63.     }  

  64.     db.transaction((tx)=>{  

  65.       tx.executeSql('delete from user',[],()=>{  

  66.       });  

  67.     });  

  68.   }  

  69.   dropTable(){  

  70.     db.transaction((tx)=>{  

  71.       tx.executeSql('drop table user',[],()=>{  

  72.       });  

  73.     },(err)=>{  

  74.       this._errorCB('transaction', err);  

  75.     },()=>{  

  76.       this._successCB('transaction');  

  77.     });  

  78.   }  

  79.     insertUserData(userData){  

  80.     let len = userData.length;  

  81.     if (!db) {  

  82.         this.open();  

  83.     }  

  84.     this.createTable();  

  85.     this.deleteData();  

  86.     db.transaction((tx)=>{  

  87.        for(let i=0; i<len; i++){  

    动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
    动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

    动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

    动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版 508
    查看详情 动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
  88.         var user = userData[i];  

  89.         let name= user.name;  

  90.         let age = user.age;  

  91.         let sex = user.sex;  

  92.         let phone = user.phone;  

  93.         let email = user.email;  

  94.         let qq = user.qq;  

  95.         let sql = "INSERT INTO user(name,age,sex,phone,email,qq)"+  

  96.         "values(?,?,?,?,?,?)";  

  97.         tx.executeSql(sql,[name,age,sex,phone,email,qq],()=>{  

  98.           },(err)=>{  

  99.             console.log(err);  

  100.           }  

  101.         );  

  102.       }  

  103.     },(error)=>{  

  104.       this._errorCB('transaction', error);  

  105.       ToastAndroid.show("数据插入失败",ToastAndroid.SHORT);  

  106.     },()=>{  

  107.       this._successCB('transaction insert data');  

  108.       ToastAndroid.show("成功插入 "+len+" 条用户数据",ToastAndroid.SHORT);  

  109.     });  

  110.   }  

  111.   close(){  

  112.       if(db){  

  113.           this._successCB('close');  

  114.           db.close();  

  115.       }else {  

  116.           console.log("SQLiteStorage not open");  

  117.       }  

  118.       db = null;  

  119.   }  

  120.   _successCB(name){  

  121.     console.log("SQLiteStorage "+name+" success");  

  122.   }  

  123.   _errorCB(name, err){  

  124.     console.log("SQLiteStorage "+name);  

  125.     console.log(err);  

  126.   }  

  127.     render(){  

  128.         return null;  

  129.     }  

  130. };  

'react';  

  • import {  

  •   AppRegistry,  

  •   Text,  

  •   View,  

  •   Navigator,  

  •   StyleSheet,  

  • } from 'react-native';  

  • import SQLite from './sqlite';  

  • var sqLite = new SQLite();  

  • var db;  

  • class App extends Component{  

  •     compennetDidUnmount(){  

  •     sqLite.close();  

  •   }  

  •   componentWillMount(){  

  •     //开启数据库  

  •     if(!db){  

  •       db = sqLite.open();  

  •     }  

  •     //建表  

  •     sqLite.createTable();  

  •     //删除数据  

  •     sqLite.deleteData();  

  •     //模拟一条数据  

  •     var userData = [];  

  •     var user = {};  

  •     user.name = "张三";  

  •     user.age = "28";  

  •     user.sex = "男";  

  •     user.phone = "18900001111";  

  •     user.email = "2343242@qq.com";  

  •     user.qq = "111222";  

  •     userData.push(user);  

  •     //插入数据  

  •     sqLite.insertUserData(userData);  

  •     //查询  

  •     db.transaction((tx)=>{  

  •       tx.executeSql("select * from user", [],(tx,results)=>{  

  •         var len = results.rows.length;  

  •         for(let i=0; i<len; i++){  

  •           var u = results.rows.item(i);  

  •           //一般在数据查出来之后,  可能要 setState操作,重新渲染页面  

  •           alert("姓名:"+u.name+",年龄:"+u.age+",电话:"+u.phone);  

  •         }  

  •       });  

  •     },(error)=>{//打印异常信息  

  •       console.log(error);  

  •     });  

  •   }  

  •     render(){  

  •         return null;  

  •     }  

 

以上就是React Native中使用Sqlite数据库的实例详解的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号