[转]html5 js 访问 sqlite 数据库的操作类
本文转自:http://blog.csdn.net/tsxw24/article/details/7613815
webkit 核心的浏览器提供了 3个 api接口,用于访问本地sqlite数据,但使用起来很不方便 故而做这个js封装,以方便使用
参考文章:
sqlite API 说明
另外的操作类
sqlite 语法
http://blog.csdn.net/ejzhang/article/details/6224915
- /**
- * js 操作数据库类
- *
- * @author 肖武<phpxiaowu@gmail.com>
- */
- /**
- * 1、数据库名(mydb)
- 2、版本号(1.0)
- 3、描述(Test DB)
- 4、数据库大小(2*1024*1024)
- */
- var DB = function( db_name, size ){
- var _db = openDatabase(db_name, '1.0.0','', size );
- return {
- /**
- * 执行sql,回调返回影响条数
- */
- execute:function( sql, param, callback ) {
- //参数处理
- if( !param ){
- param = [];
- }else if(typeof param == 'function' ){
- callback = param;
- param = [];
- }
- this.query( sql, param, function(result){
- if( typeof callback == 'function' ){
- callback(result.rowsAffected);
- }
- });
- },
- /**
- * 执行sql,回调返回sql查询对象
- * 查询时,有数据返回数组,无数据返回0
- * 增删改时:返回int,影响条数
- * void query( string[, function])
- * void query( string[, array[, function]])
- */
- query:function(sql, param, callback){
- //参数处理
- if( !param ){
- param = [];
- }else if(typeof param == 'function' ){
- callback = param;
- param = [];
- }
- var self=this;
- //只有一个参数
- _db.transaction(function (tx) {
- //4个参数:sql,替换sql中问号的数组,成功回调,出错回调
- tx.executeSql(sql,param,function(tx,result){
- if (typeof callback == 'function' ){
- callback(result);
- }
- },self.onfail) ;
- })
- },
- /**
- * 插入,回调返回last id
- * void insert( string, object[, function])
- */
- insert:function( table, data, callback ){
- if( typeof data != 'object' && typeof callback == 'function' ){
- callback(0);
- }
- var k=[];
- var v=[];
- var param=[];
- for(var i in data ){
- k.push(i);
- v.push('?');
- param.push(data[i]);
- }
- var sql="INSERT INTO "+table+"("+k.join(',')+")VALUES("+v.join(',')+")";
- this.query(sql, param, function(result){
- if ( typeof callback == 'function' ){
- callback(result.insertId);
- }
- });
- },
- /**
- * 修改,回调返回影响条数
- * void update( string, object[, string[, function]])
- * void update( string, object[, string[, array[, function]]])
- */
- update:function( table, data, where, param, callback ){
- //参数处理
- if( !param ){
- param = [];
- }else if(typeof param == 'function' ){
- callback = param;
- param = [];
- }
- var set_info = this.mkWhere(data);
- for(var i=set_info.param.length-1;i>=0; i--){
- param.unshift(set_info.param[i]);
- }
- var sql = "UPDATE "+table+" SET "+set_info.sql;
- if( where ){
- sql += " WHERE "+where;
- }
- this.query(sql, param, function(result){
- if( typeof callback == 'function' ){
- callback(result.rowsAffected);
- }
- });
- },
- /**
- * 删除
- * void toDelete( string, string[, function]])
- * void toDelete( string, string[, array[, function]])
- */
- toDelete:function( table, where, param, callback ){
- //参数处理
- if( !param ){
- param = [];
- }else if(typeof param == 'function' ){
- callback = param;
- param = [];
- }
- var sql = "DELETE FROM "+table+" WHERE "+where;
- this.query(sql, param, function(result){
- if( typeof callback == 'function' ){
- callback(result.rowsAffected);
- }
- });
- },
- /**
- * 查询,回调返回结果集数组
- * void fetch_all( string[, function] )
- * void fetch_all( string[, param[, function]] )
- */
- fetchAll:function( sql, param, callback ){
- //参数处理
- if( !param ){
- param = [];
- }else if(typeof param == 'function' ){
- callback = param;
- param = [];
- }
- this.query( sql, param, function(result){
- if (typeof callback == 'function' ){
- var out=[];
- if (result.rows.length){
- for (var i=0;i<result.rows.length;i++){
- out.push(result.rows.item(i));
- }
- }
- callback(out);
- }
- });
- },
- /**
- * 查询表的信息
- * table_name: 表名称,支持 % *,
- */
- showTables:function( table_name, callback){
- this.fetchAll("select * from sqlite_master where type='table' and name like ?", [table_name], callback);
- },
- /**
- * 组装查询条件
- */
- mkWhere:function(data){
- var arr=[];
- var param=[];
- if( typeof data === 'object' ){
- for (var i in data){
- arr.push(i+"=?");
- param.push(data[i]);
- console.log('data.i:'+i);
- }
- }
- return {sql:arr.join(' AND '),param:param};
- },
- /**
- * 错误处理
- */
- onfail:function(tx,e){
- console.log('sql error: '+e.message);
- }
- }
- }
- /*
- //使用示例:
- //1.获取db对象,连接数据库 test,分配2M大小
- var db = new DB('test',1024*1024*2);
- //2.创建表
- d.query("CREATE TABLE ids (id integer primary key autoincrement , ctime integer)");
- //3.查看已经创建的表,支持表名通配符搜索。如:"%"查询所有表,"user_%"查询"user_"开头的表
- db.showTables("%",function(ret){console.log(ret)})
- //4.查询表里数据
- db.fetchAll('select * from ids',function(ret){console.log(ret)});
- //5.修改
- db.update('ids',{ctime:123},"id=?",[1],function(ret){console.log(ret)});
- //6.删除
- db.toDelete('ids',"id=?",[1],function(ret){console.log(ret)});
- //7.其它,如删表
- db.query('drop table ids');
- */
[转]html5 js 访问 sqlite 数据库的操作类的更多相关文章
- 从C#到Objective-C,循序渐进学习苹果开发(7)--使用FMDB对Sqlite数据库进行操作
本随笔系列主要介绍从一个Windows平台从事C#开发到Mac平台苹果开发的一系列感想和体验历程,本系列文章是在起步阶段逐步积累的,希望带给大家更好,更真实的转换历程体验.本篇主要开始介绍基于XCod ...
- 【Android】13.2 使用自定义的CursorAdapter访问SQLite数据库
分类:C#.Android.VS2015: 创建日期:2016-02-26 一.简介 SQliteDemo1的例子演示了SimpleCursorAdapter的用法,本节我们将使用用途更广的自定义的游 ...
- 【Android】13.1 用Android自带的API访问SQLite数据库
分类:C#.Android.VS2015: 创建日期:2016-02-26 一.简介 这一节我们先来看看如何直接用Android自带的API创建和访问SQLite数据库. 1.创建SQLite数据库 ...
- 【Android】13.0 第13章 创建和访问SQLite数据库—本章示例主界面
分类:C#.Android.VS2015: 创建日期:2016-02-26 一.简介 Android 内置了三种数据存取方式:SQLite数据库.文件.SharedPreferences. 这一章我们 ...
- 并发访问sqlite数据库出现databse is locked的错误的一个解决办法
作者:朱金灿 来源:http://blog.csdn.net/clever101 在并发访问sqlite数据库会出现这样一个错误:databseis locked,这是sqlite数据库对并发支持不太 ...
- 使用iOS原生sqlite3框架对sqlite数据库进行操作
摘要: iOS中sqlite3框架可以很好的对sqlite数据库进行支持,通过面向对象的封装,可以更易于开发者使用. 使用iOS原生sqlite3框架对sqlite数据库进行操作 一.引言 sqlit ...
- 【C#】使用EF访问Sqlite数据库
原文:[C#]使用EF访问Sqlite数据库 1. 先上Nuget下载对应的包 如图,搜索System.Data.SQLite下载安装即可,下载完之后带上依赖一共有这么几个: EntityFramew ...
- 以EntifyFramework DBFirst方式访问SQLite数据库
前面一直在找EF Code First方式来访问SQLite数据库,后面得出的结论是SQLite不支持 Code First, 虽然有非官方的库SQLite.CodeFirst可以使用,但一直没搞成功 ...
- Qt5 开发 iOS 应用之访问 SQLite 数据库
开发环境: macOS 10.12.1 Xcode 8.1 Qt 5.8 iPhone 6S+iOS 10.1.1 源代码: 我在 Qt 程序里指定了数据库的名称来创建数据库,在 Win10.An ...
随机推荐
- web性能优化——代理(nginx)
简介 一个很好的原则是调优时每次只个性一个配置.如果对配置的个性不能提高性能的话,改回默认值 优化必须要通过性能测试.不能意淫,需要前后对比,真实说明问题. 场景 优化nginx. 确保每次请求控制一 ...
- FormsAuthentication身份认证源代码
使用FormsAuthentication类可以实现身份认证功能,这里提供一个asp.net项目的源代码,项目名称KWS.项目实现了登录.退出和判断身份的功能. 关于项目 点击这里下载源代码 http ...
- Spring(2) ------ 依赖注入
spring框架为我们提供了三种注入方式,分别是set注入,构造方法注入,接口注入. 1.set注入: 采用属性的set方法进行初始化,就成为set注入. 1)给普通字符类型赋值. public cl ...
- Egret白鹭H5小游戏开发入门(三)
前言: 在上一篇文章中着重介绍了H5小游戏开发的起步阶段,如Wing面板的使用,素材的处理,类的说明等等,那么今天主要是涉及到场景的创建,loading的修改等等的代码编写. 对于这一节,我在讲解的过 ...
- 每日一博 | 用 Ionic2 创建 App 启动页滑动欢迎界面
原文 https://my.oschina.net/qinphil/blog/777787 效果如下,图片来自网络 本文例子和上图稍有不同,主要功能如下: 每滑动一下展示一张全屏图片: 滑动到最后一 ...
- android调试工具DDMS的使用详解
具体可见http://developer.android.com/tools/debugging/ddms.html. DDMS为IDE和emultor.真正的android设备架起来了一座桥梁.开发 ...
- webView 显示一段 html 代码
1.布局文件 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:and ...
- Mark一下,Android ListView的上下间隙
困扰很久的问题,怎么给ListView上下加padding,可以跟随滚动的那种 android:paddingTop="10dp" android:paddingBottom=&q ...
- iOS 开发之路(AES/DES加密实现) 三
最近接触的这个项目由于以前服务器上用的是DES/CBC/PKCS5Padding加密方式,为了让在iOS上的加密结果与服务器端保持一致,我做了很多尝试,现在分享给大家.PS:现在不推荐用DES了,只是 ...
- 【Gson】2.2.4 StackOverflowError 异常
正文 错误: 08-09 09:56:51.904: E/AndroidRuntime(16384): java.lang.StackOverflowError 08-09 09:56:51.904: ...