Sencha Touch 2 结合HTML5的本地存储创建数据库实现增、删、改、查
大家好!我是范范。本人刚接触ST2到现在刚刚两个月,6月1号接的项目,那时才知道有Sencha Touch2这个东西,到现在两个月了期间的幸酸就不说了。今天说说在项目中用到的HTML5的本地存储。可能有的地方不是很合理,大家可以提出宝贵意见。下面开整:
下面是创建数据库的代码:database.js
var initDatabase = function(db,tables){
for(var i=0;i<tables.length;i++){
pmdb.createTable(db,tables[i],
function(){ //成功后回调函数
},
function(tx, error){ //失败后回调函数
console.log(i);
}
);
}
};
var pmdb =
{
//建表,在系统初始化时调用
createTable:function (db,createSql,sucessCallback,failCallBack){
if(!db) {
return ;
}
// 创建表
db.transaction( function(tx) {
tx.executeSql(
createSql, //createSql
[], //参数
sucessCallback, //成功后回调函数
failCallBack //失败后回调函数
);
});
},
//执行,
excute:function (db,sql,param,sucessCallback,failCallBack){
if(!db) {
return ;
}
db.transaction(function(tx) {
tx.executeSql(
sql,
param,
sucessCallback, //成功后回调函数
failCallBack //失败后回调函数
);
});
},
//删除表
drop: function(db,tableName) {
db.transaction(function (tx) {
tx.executeSql('DROP TABLE '+tableName);
});
},
//打开数据库:一个用户一个数据库
openDB: function (userName){
var dbName= "PM_"+userName;
var dbVersion = "1.0" ;
var dbSize = 1024 * 1024;
var alia = "工程质量管理数据库";
var db = openDatabase(dbName, dbVersion, alia, dbSize);
return db;
}
,
//批量根据id删除数据
deleteData: function(db,tableName,id,data,sucessCallback,failCallBack){
if (!db) {
return;
}
if(data.length>0){
var ids = "";
for(var index=0;index<data.length;index++){
if(index==0){
ids="'"+data[index][id]+"'";
}else{
ids+=",'"+data[index][id]+"'";
}
}
var sql = "delete from " + tableName + " where "+id+" in ("+ids+")";
pmdb.excute(db,sql,[],sucessCallback,failCallBack);
}
}
,
// 向数据库插入数据
insertData : function(db,tableName,field,data,sucessCallback,failCallBack) {
if (!db) {
return;
}
for (var index = 0; index < data.length; index++) {
var values = data[index];
var value = pmdb.newArray(values, field); // 将data数据转成Array
var fieldnew=newArrayFilds;
var sql = "INSERT INTO " + tableName + " (" + fieldnew.join(",")
+ ") values " + "("
+ new Array(fieldnew.length + 1).join(",?").substr(1) + ")";
pmdb.excute(db,sql, value,sucessCallback,failCallBack);
};
//
},
// 将data数据转成Array
newArray : function(data, filds) {
var newArray = new Array();
var k=0;
for (i = 0; i < filds.length; i++) {
if(i==0){newArrayFilds.length=0}
name = filds[i];
var fildData=data[name];
if(fildData!=undefined&&fildData!=""){
if(newArray.length>0){
newArray[k+1] = fildData;
newArrayFilds[k+1]=name;
k=k+1;
}else{
newArray[k] = fildData;
newArrayFilds[k]=name;
}
}
}
return newArray;
}
};
var newArrayFilds = new Array();
下面是建表的代码:CreateTable.js
//建表
var creatTables ={
sqls :function(){
var tables = new Array(2);//表的个数
//基础数据表、参数表
tables[0] = "CREATE TABLE IF NOT EXISTS t_Question (question_id int, project_id string,category_id int,pj_node_code string,location string,description string,cs_id int,fix_requirement string,fix_date datetime,question_priority string,submit_user_id int,submit_date datetime,question_status int,amount number,IsSubmit int )";
tables[1] = "CREATE TABLE IF NOT EXISTS t_QuestionUser (question_id string,user_type string,user_id int)";
return tables; } };
下面是存入时的数据集合:
var questionArray = new Array("question_id","project_id","category_id","pj_node_code","location","description","cs_id","fix_requirement","fix_date","question_priority","submit_user_id","submit_date","question_status","amount","IsSubmit");
var questionUserArray = new Array("question_id","user_type","user_id");
Sencha Touch 2 结合HTML5的本地存储创建数据库实现增、删、改、查的更多相关文章
- HTML5 LocalStorage 本地存储
HTML5 LocalStorage 本地存储 说到本地存储,这玩意真是历尽千辛万苦才走到HTML5这一步,之前的历史大概如下图所示: 最早的Cookies自然是大家都知道,问题主要就是太小,大概也就 ...
- (转载)HTML5 LocalStorage 本地存储
原文地址:http://www.cnblogs.com/xiaowei0705/archive/2011/04/19/2021372.html HTML5 LocalStorage 本地存储 说到本地 ...
- HTML5的本地存储 LocalStorage
localStorage顾名思义,就是本地存储的意思,在以前很长一段时间,要想在客户端存 储一些配置及登录信息等数据都只能通过COOKIE或flash的方式,如今html5来临,也 带来了更强大的本地 ...
- 【转】HTML5 LocalStorage 本地存储
原文见:http://www.cnblogs.com/xiaowei0705/archive/2011/04/19/2021372.html 说到本地存储,这玩意真是历尽千辛万苦才走到HTML5这一步 ...
- html5的本地存储localStorage和sessionStorage
html5的本地存储localStorage和sessionStorage html5中新增的比较重要的一个功能就是web storage来实现客户端本地存储数据,之前存储数据都是用cookie来实现 ...
- HTML5 LocalStorage 本地存储总结
存储数据的方法就是直接给window.localStorage添加一个属性,例如:window.localStorage.a 或者 window.localStorage["a"] ...
- HTML5 LocalStorage 本地存储(转)
原文:http://www.cnblogs.com/xiaowei0705/archive/2011/04/19/2021372.html HTML5 LocalStorage 本地存储 说到本地存储 ...
- HTML5 LocalStorage 本地存储原理详解
首先自然是检测浏览器是否支持本地存储.在HTML5中,本地存储是一个window的属性,包括localStorage和sessionStorage,从名字应该可以很清楚的辨认二者的区别,前者是一直存在 ...
- HTML5 LocalStorage 本地存储,刷新值还在
H5的两种存储技术的最大区别就是生命周期. 1. localStorage是本地存储,存储期限不限: 2. sessionStorage会话存储,页面关闭数据就会丢失. 使用方法: localStor ...
随机推荐
- emoji表情字符串 mysql 普通 utf8 格式无法存入
处理方法: 1.在可以忽略emoji表情的情况下,可以选择将emoji表情字符过滤掉,这样不用动mysql 表结构 过滤Java代码参考如下: public static String filt ...
- 提取 ECharts 中的svg地图信息
地图的需求还是蛮大的,全国都要自己画的话,还是需要投入比较大的人力. ECharts中有地图,那我们能不能把里面的地图文件提取出来呢,主要逻辑在map.js中. 看源代码发现,ECharts中地图信息 ...
- php的系统常量
认识一下系统常量 系统常量是PHP已经定义好的常量,我们可以直接拿来使用,常见的系统常量有: (1)__FILE__ :php程序文件名.它可以帮助我们获取当前文件在服务器的物理位置. (2)__LI ...
- 解决PowerDesigner中DBMS设置的问题(Repost)
创建物理模型时DBMS下拉框是空的,没值,以前从来没遇到过这种现象,开始以为PowerDesigner安装软件的问题,不过装了又卸,卸了又装,结果还是那样,现在找到答案了:点击DBMS后面的黄色文件图 ...
- Asp.net MVC学习
一.mvc项目的创建并运行 1.启动vs2010 2.新建项目 3.选择Asp.net mvc应用程序 4.不创建测试用例 5.创建之后的效果 6.运行后的mvc程序
- UltraISO制作U盘系统安装盘(图文教程)
虽然现在的系统盘做的越来越傻瓜化,安装方法也非常多,但是仍然时常有朋友询问怎么安装系统,特别是没有刻录机或不想刻盘,又不懂硬盘安装的朋友,这里特别介绍一种用U盘来安装系统的方法,非量产,量产因U盘芯片 ...
- Referrer 还是 Referer?
上回我写了一篇文章介绍「Referrer Policy」,有小伙伴看完后问我:Referrer 这个单词到底怎么拼,为什么有时候中间有两个 r,有时候只有一个? 是的,这是一个很有趣的问题,这里就给有 ...
- Unix/Linux环境C编程入门教程(17) Gentoo LinuxCCPP开发环境搭建
1. Gentoo Linux是一套通用的.快捷的.完全免费的Linux发行,它面向开发人员和网络职业人员.与其他发行不同的是,Gentoo Linux拥有一套先进的包管理系统叫作Portage.在B ...
- vim-配置文件
" " Last Change: 2010年08月02日 15时13分 " " Version: 1.80 " "============= ...
- [LeetCode][Python]15:3Sum
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 15: 3Sumhttps://oj.leetcode.com/problem ...