ASP编程:动网服装论坛代码剖析 -- 嵌套查询
缺点:安全性不是太差了,还行,只要你充分利用系统自带的工具;唯一缺点就是执行效率慢,如何进行网站优化以后,效果会比较好。动网服装论坛 在动网服装论坛中,用户登录今后,服装论坛菜单下方会多出两条链接,即:“我宣布的主题”和“我介入的主题”。前者的查询复杂一些,只需求查询登录用户宣布的主题就行,可以写成“Select 主题 贴子表 where 作者=登录用户名”就好了,但后一条就费事一些了。这里倘若主题贴和答复贴都是在一个数据表中,每笔记录只用一个字段辨别开来是主题贴和答复贴,我就是如许做的。咱们晓得,凡是情形下,宣布答复的时分,是可以省略题目的,倘若咱们如前一条一样搜刮的话,得出的搜刮了局中是没有题目这一项的,如许就没法显示出来,所以必需显示该答复对对应的贴子的主题。这个查询又是怎样来做的呢?咱们先来看一看动网的代码:
"select top 200 * from topic where topicid in (select top 200 rootid from "&NowUseBBS&" where postuserid="&userid&" order by announceid desc) order by topicid desc"
这个查询中为何有小括号呢?是甚么意思?且听鄙人持续分化。
咱们普通用到的查询都是单层查询,而下面这段查询倒是两层,它请求办事器在处置终究查询任务之前师长教师成一个了局,然后依据以后的查询结查再进一步持续上面的查询任务,也就是说,先履行小括号内的查询(咱们称之为子查询),然后办事器才入手下手履行里面的查询,前往准确的了局,这类查询称为嵌套查询。下面的这个查询,第一层查询是查登录用户在本版宣布过的一切贴子(含答复),然后再查这些贴子的主题。
除下面这个功用以外,嵌套查询还有甚么优点呢?假如请求在搜刮的婚配前提中利用统计函数(这在剖析统计数据中常常用到),可使用嵌套查询。好比说,如今请求查询一切发卖量大于均匀发卖量的书的代号,假如写成上面的查询体例:
SELECT title_id,qty //title_id为书号,qty为发卖量
From sales
Where qty>avg(qty) //avg为均匀数函数,avg(qty)即为均匀发卖量
办事器将会提醒毛病,由于,在where子句中不准直接对本SELECT列表的数据利用统计函数。经由过程在where子句中利用嵌套查询可以处理这个成绩,语法以下:
SELECT title_id,qty
FROM sales
WHERE qty>
(SELECT avg(qty) FROM sales)因为ASP脚本语言非常简单,因此其代码也简单易懂,结合HTML代码,可快速地完成网站的应用程序。还无法完全实现一些企业级的功能:完全的集群、负载均横。 Session:这个存储跟客户端会话过程的数据,默认20分钟失效 Request:从字面上讲就是“请求”,因此这个是处理客户端提交的东东的,例如Resuest.Form,Request.QueryString,或者干脆Request("变量名") 他的语法和设计思路和VB完全相同,导致很多ASP的书都留一句“相关内容请参考VB的相关教材....”更糟糕的是,相当多的ASP教程混合了Javascript,VBscript等等脚本语言,搞的初学者。 代码的可重用性差:由于是面向结构的编程方式,并且混合html,所以可能页面原型修改一点,整个程序都需要修改,更别提代码重用了。 运用ASP可将VBscript、javascript等脚本语言嵌入到HTML中,便可快速完成网站的应用程序,无需编译,可在服务器端直接执行。容易编写,使用普通的文本编辑器编写,如记事本就可以完成。由脚本在服务器上而不是客户端运行,ASP所使用的脚本语言都在服务端上运行。 虽然ASP也有很多网络教程。但是这些都不系统。都是半路出家,只是从一个例子告诉你怎么用。不会深入讨论,更不会将没有出现在例子里的方法都一一列举出来。 Response:从字面上讲是“响应”,因此这个是服务端向客户端发送东西的,例如Response.Write 多看多学多思。多看一些关于ASP的书籍,一方面可以扩展知识面一方面可以鉴借别人是如何掌握、运用ASP的;多学善于关注别人,向同学老师多多学习,不论知识的大小;多思则是要将学到的知识灵活运用。 代码逻辑混乱,难于管理:由于ASP是脚本语言混合html编程,所以你很难看清代码的逻辑关系,并且随着程序的复杂性增加,使得代码的管理十分困难,甚至超出一个程序员所能达到的管理能力,从而造成出错或这样那样的问题。 代码逻辑混乱,难于管理:由于ASP是脚本语言混合html编程,所以你很难看清代码的逻辑关系,并且随着程序的复杂性增加,使得代码的管理十分困难,甚至超出一个程序员所能达到的管理能力,从而造成出错或这样那样的问题。 弱类型造成潜在的出错可能:尽管弱数据类型的编程语言使用起来回方便一些,但相对于它所造成的出错几率是远远得不偿失的。 ASP.Net摆脱了以前ASP使用脚本语言来编程的缺点,理论上可以使用任何编程语言包括C++,VB,JS等等,当然,最合适的编程语言还是MS为.NetFrmaework专门推出的C(读csharp),它可以看作是VC和Java的混合体吧。 ASP(ActiveServerPages)是Microsfot公司1996年11月推出的WEB应用程序开发技术,它既不是一种程序语言,也不是一种开发工具,而是一种技术框架,不须使用微软的产品就能编写它的代码,能产生和执行动态、交互式、高效率的站占服务器的应用程序。 下载一个源代码,然后再下载一个VBScript帮助,在源代码中遇到不认识的函数或是其他什么程序,都可以查帮助进行解决,这样学习效率很高。 我们必须明确一个大方向,不要只是停留在因为学而去学,我们应有方向应有目标. 哪些内置对象是可以跳过的,或者哪些属性和方法是用不到的? 学习ASP其实应该上升到如何学习程序设计这种境界,其实学习程序设计又是接受一种编程思想。比如ASP如何学习,你也许在以前的学习中碰到过。以下我仔细给你说几点: 不能只是将它停留在纸上谈兵的程度上。 如何更好的使自己的东西看上去很不错等等。其实这些都不是问题的实质,我们可以在实践中不断提升自己,不断充实自己。
页:
[1]