- 浏览: 23836 次
- 性别:
- 来自: 吉林
最新评论
-
zhangfan1990:
楼主的文章有启发啊
JavaScript原型链 -
s2640226szm:
写的不错,理解了原型链
JavaScript原型链
TrimQuery引擎是TrimPath开源项目的一个轻量组件,遵守GPL & APL开源协议。 它可以为你的客户端程序提供使用sql的能力。
TrimQuery引擎是使用javascript编写的,源代码大约900多行。最新版本号为1.1.14
项目托管在google code。地址:http://code.google.com/p/trimpath/
TrimQuery引擎支持类似于SQL的语法有:
INSERT, UPDATE, DELETE
SELECT ... FROM
WHERE ...
LIKE ...
ORDER BY ... ASC/DESC
AS ...
GROUP BY ... HAVING ...
SUM, COUNT, AVG 聚合函数
自联接(self join)
LIMIT和偏移量
“?”占位符(类似JAVA JDBC的中的方式)
不支持的SQL语法:
BETWEEN
IN (for lists and for sub-queries or nested SELECT's)
ANY
EXISTS
DISTINCT
AVG DISTINCT, SUM DISTINCT, COUNT DISTINCT
LEFT OUTER JOIN
RIGHT OUTER JOIN
FULL OUTER JOIN
UNION, EXCEPT, INTERSECT
下面通过一个简单的例子了解TrimQuery(代码在附件中文件 TrimQueryDemo.html)
<!DOCTYPE > <html> <head> <title>TrimQuery Demo</title> </head> <script type="text/javascript" src="trimpath-query-1.1.14.js"></script> <script type="text/javascript" src="json.js"></script> <script type="text/javascript"> //定义表结构 var columnDefs = { Invoice : { id : { type: "String" }, total : { type: "Number" }, custId : { type: "String" } }, Customer : { id : { type: "String" }, acctBalance : { type: "Number" } } }; //表数据 var tableData = { Invoice : [{ id: 1, total: 100, custId: 10 },{ id: 2, total: 200, custId: 10 },{ id: 3, total: 300, custId: 10 },{ id: 4, total: 400, custId: 20 } ], Customer : [{ id: 10, acctBalance: 1000 },{ id: 20, acctBalance: 2000 },{ id: 30, acctBalance: 3000 } ] }; //首先我们预编译查询表。 var queryLang = TrimPath.makeQueryLang(columnDefs); // 下面我们做一个查询。 var statement = queryLang.parseSQL( "SELECT Customer.id, Customer.acctBalance, Invoice.total " + "FROM Customer, Invoice " + "WHERE Customer.id = Invoice.custId " + "ORDER BY Customer.id ASC"); // 运行查询语句在指定的数据集中查询结果集。 var results = statement.filter(tableData); //输出查询结果 alert(results.toJSONString()); // 此外我们可可以获取查询语句。 alert(statement.toString()); </script> <body> </body> </html>
通过上例相信大家已经看出了里面的道道,使用TrimQuery首先要有表的定义,然后要有表数据,最后通过查询语句获得结果集。
下面详细介绍下TrimQuery中提供的方法(API)
TrimPath是一个全局对象,在这个对象中包含有TrimQuery方法。
TrimPath.makeQueryLang(表定义) :用于预声明 要操作的表结构。也就是确定操作的范围。该函数返回一个queryLang 对象,这个对象下包括一系列的SQL操作方法。如果多次使用相同的参数调用TrimPath.makeQueryLang方法,将会生成多个不同的queryLang 对象。参数格式如例子中columnDefs定义的格式
queryLang.parseSQL(sqlString,optionalParamsArray):方法用于声明执行的SQL语句。第一个参数是SQL语句字符串,第二个参数为可选参数,支持"?"替换,防止脚本注入。如果SQL语句不符合语法则会抛出异常。方法会返回一个selectStatement 对象,通过这个对象就可以查询了。
包括第二个参数的例子:
selectStatement = queryLang.parseSQL( "SELECT Customer.* FROM Customer " + "WHERE Customer.acctBalance > ? " + "AND Customer.acctBalance < ?" , [ minBalance, maxBalance ]);
selectStatement.filter( tableData, options ):方法用于执行SQL语句。第一个参数是作用的表数据集,格式如例子中的tableData ,第二个参数可选,我这里就不介绍了。返回结果集是一个JSON对象。
selectStatement.toString():方法返回一个String表示selectStatement对象的SQL。
再说说TrimQuery的SQL语法需要注意的点
TrimQuery的所有关键字必须大写。
列必须使用TableName.columnName点缀语法指定
TrimQuery不支持复杂的函数。
下面列出TrimQuery SQL的示例:
//查询全表 SELECT * FROM Invoice //查询全表 SELECT Invoice.* FROM Invoice //查询指定列 SELECT Invoice.id, Invoice.total FROM Invoice //两表联合查询 SELECT Invoice.id, Invoice.total, Customer.acctBalance FROM Invoice, Customer //量表联合查询使用 * SELECT Invoice.*, Customer.* FROM Invoice, Customer //使用AS 为表重命名 SELECT i.* FROM Invoice AS i //使用AS为列重命名 SELECT i.id AS ID_NUM FROM Invoice AS i //量表联合查询中使用AS SELECT Invoice.*, i2.* FROM Invoice, Invoice AS i2 //两表联合查询使用 关联条件 过滤 SELECT Customer.id, Invoice.custId, Invoice.total, Customer.acctBalance FROM Invoice, Customer WHERE Invoice.custId = Customer.id //两表联合查询使用 关联条件 过滤条件 过滤 SELECT Customer.id, Invoice.custId, Invoice.total, Customer.acctBalance FROM Invoice, Customer WHERE Invoice.total < 250 AND Invoice.custId = Customer.id // 使用ORDER BY 语句为结果集排序 SELECT Invoice.id FROM Invoice ORDER BY Invoice.id //指定排序规则 为升序 SELECT Invoice.id FROM Invoice ORDER BY Invoice.id ASC //指定排序规则为降序 SELECT Invoice.id FROM Invoice ORDER BY Invoice.id DESC //使用多列作为排序列 SELECT Invoice.custId, Invoice.id FROM Invoice ORDER BY Invoice.custId DESC, Invoice.id //获取前100条数据 SELECT Refund.* FROM Refund LIMIT 100 //获取从100到 100 + 50的数据 SELECT Refund.* FROM Refund LIMIT 100, 50 //使用集合函数 SELECT Invoice.total, SUM (Invoice.total) AS SUM_total, COUNT (Invoice.total) AS COUNT_total, AVG (Invoice.total) AS AVG_total FROM Invoice //使用GROUP BY 语法 SELECT Invoice.total, SUM (Invoice.total) AS SUM_total, COUNT (Invoice.total) AS COUNT_total, AVG (Invoice.total) AS AVG_total FROM Invoice GROUP BY Invoice.custId //使用 GROUP BY 与 ORDER BY SELECT Invoice.total, SUM (Invoice.total) AS SUM_total FROM Invoice GROUP BY Invoice.custId ORDER BY SUM_total ASC //使用 HAVING SELECT Invoice.total AS TOT, SUM (Invoice.total) AS SUM_total FROM Invoice GROUP BY Invoice.custId HAVING (TOT) > 15000 ORDER BY SUM_total ASC //使用LIKE SELECT * FROM User WHERE User.name LIKE 'P%' //插入数据 INSERT INTO Event (id, date, invoice_id) VALUES (1, '2003-01-31', 43) //更新数据 UPDATE User SET name='Frank Thomas' WHERE User.id = '3' //删除数据 DELETE Thing FROM Thing WHERE Thing.id = '1'
好啦就些这么多。
- TrimQueryDemo.zip (14.8 KB)
- 下载次数: 8
发表评论
-
js 垃圾回收
2012-10-06 11:42 909在IE浏览器下可以由JS程序调用垃圾回收函数CollectGa ... -
open-flash-chart 2
2012-09-22 22:40 799最近研究了open-flash-chart2这个报表组件,组件 ... -
[转]createElement与createDocumentFragment的点点差别
2012-09-08 21:33 2608在DOM操纵里,createElement是创建一个新的节点, ... -
一段优美的正则
2012-09-08 20:42 1298记录下来,一段优美的 ... -
原生的DOM选择器
2012-09-08 15:38 3137说说下面几个方法: getElementById, getEl ... -
IE 中的id 与name
2012-09-07 16:09 2103火星浏览器(IE)又抽风了表现如下,在IE7下,使用docum ... -
compareDocumentPosition与contains
2012-09-07 13:26 1673研究KISSY 1.3RC源代码DOM/traversal 发 ... -
tabindex
2012-09-06 17:26 0http://www.cnblogs.com/rubylouv ... -
IE的href 设值BUG
2012-09-06 17:21 1351今天研究KISSY1.3 RC源代码时看到这样一段代码,如下: ... -
IE下的条件编译
2012-09-06 14:24 969在IE浏览器下,可以把部分只针对IE的javascript代码 ... -
判断IE5~IE7
2012-09-06 14:17 0判断IE5~7可以通过检测:document.document ... -
property 和attribute
2012-09-06 13:22 0aaaasdfaaaaa -
KISSY1.3.0RC源码分析一Kissy.js
2012-08-25 18:28 0kissy.js从名字即可以看出它是kissy框架最核心的文件 ... -
javascript闭包
2011-08-22 19:44 963javascript的闭包特性非常强大,但也常常成为bug的滋 ... -
javascript作用域
2011-08-22 19:37 749今天看到一篇非常帮的文章,博主仅使用几个例子就将javascr ... -
框架结构锁屏实现
2011-08-22 19:30 1858如果大家不知道什么是锁屏,可以去163信箱看一看,用途是你 ... -
SWFObject
2011-08-04 16:17 907SWFObject: 基于Javascript的Flash媒体 ... -
JavaScript原型链
2011-07-29 16:18 1570声明,文章中用到的专业名词可能并不标准。请同学指正。 ...
相关推荐
内容概要:本文全面介绍了Scratch编程语言,包括其历史、发展、特点、主要组件以及如何进行基本和进阶编程操作。通过具体示例,展示了如何利用代码块制作动画、游戏和音乐艺术作品,并介绍了物理模拟、网络编程和扩展库等功能。 适合人群:编程初学者、教育工作者、青少年学生及对编程感兴趣的各年龄段用户。 使用场景及目标:①帮助初学者理解编程的基本概念和逻辑;②提高学生的创造力、逻辑思维能力和问题解决能力;③引导用户通过实践掌握Scratch的基本和高级功能,制作个性化作品。 其他说明:除了基础教学,文章还提供了丰富的学习资源和社区支持,帮助用户进一步提升技能。
mmexport1734874094130.jpg
基于simulink的悬架仿真模型,有主动悬架被动悬架天棚控制半主动悬架 [1]基于pid控制的四自由度主被动悬架仿真模型 [2]基于模糊控制的二自由度仿真模型,对比pid控制对比被动控制,的比较说明 [3]基于天棚控制的二自由度悬架仿真 以上模型,说明文档齐全,仿真效果明显
内容概要:本文档是《组合数学答案-网络流传版.pdf》的内容,主要包含了排列组合的基础知识以及一些经典的组合数学题目。这些题目涵盖了从排列数计算、二项式定理的应用到容斥原理的实际应用等方面。通过对这些题目的解析,帮助读者加深对组合数学概念和技巧的理解。 适用人群:适合初学者和有一定基础的学习者。 使用场景及目标:可以在学习组合数学课程时作为练习题参考,也可以在复习考试或准备竞赛时使用,目的是提高解决组合数学问题的能力。 其他说明:文档中的题目覆盖了组合数学的基本知识点,适合逐步深入学习。每个题目都有详细的解答步骤,有助于读者掌握解题思路和方法。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
操作系统实验 Ucore lab5
基于matlab开发的学生成绩管理系统GUI界面,可以实现学生成绩载入,显示,处理及查询。
老版本4.0固件,(.dav固件包),支持7700N-K4,7900N-K4等K51平台,升级后出现异常或变砖可使用此版本。请核对自己的机器信息,确认适用后在下载。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
YOLO算法-杂草检测项目数据集-3970张图像带标签-杂草.zip
E008 库洛米(3页).zip
内容概要:本文详细阐述了基于西门子PLC的晶圆研磨机自动控制系统的设计与实现。该系统结合了传感器技术、电机驱动技术和人机界面技术,实现了晶圆研磨过程的高精度和高效率控制。文中详细介绍了控制系统的硬件选型与设计、软件编程与功能实现,通过实验测试和实际应用案例验证了系统的稳定性和可靠性。 适合人群:具备一定的自动化控制和机械设计基础的工程师、研究人员以及从事半导体制造的技术人员。 使用场景及目标:本研究为半导体制造企业提供了一种有效的自动化解决方案,旨在提高晶圆研磨的质量和生产效率,降低劳动强度和生产成本。系统适用于不同规格晶圆的研磨作业,可以实现高精度、高效率、自动化的晶圆研磨过程。 阅读建议:阅读本文时,重点关注晶圆研磨工艺流程和技术要求,控制系统的硬件和软件设计方法,以及实验测试和结果分析。这将有助于读者理解和掌握该自动控制系统的实现原理和应用价值。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
深圳建筑安装公司“挖掘机安全操作规程”
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
大题解题方法等4个文件.zip
保障性安居工程考评内容和评价标准.docx
监督机构检查记录表.docx
该项目适合初学者进行学习,有效的掌握java、swing、mysql等技术的基础知识。资源包含源码、视频和文档 资源下载|如果你正在做毕业设计,需要源码和论文,各类课题都可以,私聊我。 商务合作|如果你是在校大学生,正好你又懂语言编程,或者你可以找来需要做毕设的伙伴,私聊我。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。