查看完整版本: 在ASP中使用SQL语句之10:视图

豹子 2007-6-23 10:29

在ASP中使用SQL语句之10:视图

假如页面上有很多条记录,很多情况下,对这些信息按照字母表降序排序会比传统的升序排序显示效率更高。采用你熟悉的ORDER BY 子句,你可以很容易地在页面上增加这一功能,让用户控制其记录显示的视图。 $AFd~Z"lo
U;M f+vH7IY
  %h6G:X,RT^N

$F ZG9Iu4@7@ 假设你有个页面的名字叫customers.asp ,页面执行会从Customers表内选取全部记录并按照字母表顺序对客户姓氏排序。先前我们已经看到过排序的代码了,为了实现反向排序,你只需要在ORDER BY 表达式之后加上desc 即可:9ef([i@
SQL = "SELECT c_lastname, c_firstname, c_email FROM Customers ORDER BY c_lastnamedesc"  0Hn,]}V
.vH2L*i#\4nYEfe
要在静态模式下这也不赖。但是,也许你想修改以上代码使之提供新的GUI功能:[:M4SWN4l
A HREF="customers.asp "Sort Ascending/A | A HREF="customers.asp?sort=desc"Sort Descending/A
6W|dA$ul:k6CR P5na:hN5{u2UQV4y
%
/A;x4M)H*E9~ SQL = "SELECT c_lastname, c_firstname, c_email FROM Customers ORDER BY c_lastname "  sort  " "  0v `TU\)z N
P6in;z?7zF
set objRec = objConn.Execute(SQL)  cBlm6M t

M IZ+d z;TD4I+x/C While Not objRec.EOFpa*U7J/@Z F
Response.WriteobjRec("c_lastname")  ", "  objRec("c_firstname")  "x'_[(Bjp
"  objRec("c_email")  "P"wska,b
objRec.MoveNext
P3X1Nmi/w)]P Wend  8Y)OeSrU K/|Q
o;F%B9D^u5O? K`
%  
1q1k!C7P^`,{ U ?!X/hL6^d#zd
以上代码最开头的链接允许用户修改页面的视图。你可以重载同一页面来查看这些信息,但是,在Sort Descending链接的情况下,页面会给sort 变量赋值。然后,在SQL语句内就没有指定desc而是采用 sort 变量的值。  "Y u RyK+n+n4z

+_ @ c&`RaE;c 下面要做的就是读取页面顶部sort 的值。W8F0c-H\{$h"jo
%
e^A gQE Z{+C sort = Request.Querystring("sort")
a!D` qb l ? q?m %   a;] _!Qgrr~qo/[
dK{)t D{ S
以上代码从URL中检出sort的可用值。  ;Hz9Z_v2^Z _
xv(_2VVS oZZ"W
并没有令你费太多的功夫,你还可以调整同一页面允许用户对特定的列排序。简单的SELECT 菜单表单控件列出SORT BY 选项可能是一个更方便的措施。
页: [1]
查看完整版本: 在ASP中使用SQL语句之10:视图