六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

用ASP、VB與XML創建互聯網應用程序(3)

[摘要]假設在我們前面所說的例子中,我們想在應用程序中顯示區域的左半邊顯示客戶的姓名列表,再在每個客戶姓名后面加上兩個鏈接:Purchase History和Recent Purchase。當用戶點擊其中的一個鏈接,客戶程序就會運行一個存儲過程并在右邊區域顯示出結果。 為了顯示這個想法的靈活性,我想讓用于...
假設在我們前面所說的例子中,我們想在應用程序中顯示區域的左半邊顯示客戶的姓名列表,再在每個客戶姓名后面加上兩個鏈接:Purchase History和Recent Purchase。當用戶點擊其中的一個鏈接,客戶程序就會運行一個存儲過程并在右邊區域顯示出結果。 為了顯示這個想法的靈活性,我想讓用于返回數據的三個操作單元執行不同的工作過程,它們都調用getData.asp。首先,通過調用CustOrderHist來運行一個存儲過程,返回客戶的Purchase History,它搜索Northwind數據庫(為了方便起見我使用MS SQL中自帶的數據庫)并返回一個數據集。用于返回Recent Purchase 的查詢語句運行一個叫RecentPurchaseByCustomerID的存儲過程,來接收輸入的CustomerID參數并通過ProductName參數返回最近顧客購買的商品名。定義其處理過程相應SQL語句如下:

  CREATE PROCEDURE RecentPurchaseByCustomerID @CustomerID nchar(5), @ProductName nchar(40) output AS SELECT @ProductName = (SELECT top 1 ProductName FROM Products INNER JOIN ([Order Details] INNER JOIN Orders ON Orders.OrderID=[Order Details].OrderID) ON Products.ProductID = [Order Details].ProductID WHERE Orders.OrderDate = (SELECT MAX(orders.orderdate) FROM Orders
where CustomerID=@CustomerID) AND Orders.CustomerID=@CustomerID) GO

  不管你的查詢語句中含有動態SQL語句還是含有返回記錄集的存儲過程或是輸出一個返回值,其處理POST消息的方法是一樣的:

  set xhttp = createObject ("msxml2.XMLHTTP")
  xhttp.open "POST", "http://localhost/myWeb/ getData.asp", False
  xhttp.send s

  好了,現在讓我們看一看如何發送和接收數據

  客戶端的XML信息是由一個<command>元素和一些子元素組成:<commandtext>元素包含了存儲過程的名稱,<returnsdata>元素告訴服務器,客戶端是否要求接收返回數據,<param>元素包含參數信息。如果不使用參數的話,那么最簡單的發送字符串查詢就象下面這樣:

  <command>
   <commandtext>

  存儲過程或動態SQL語句

  </commandtext>
   <returnsvalues>True</returnsvalues>
  </command>

  你可以為每一個參數使用一個<param>元素,來添加參數。每個<param>元素有五個子元素:name,type,direction,size和value。子元素的順序可以隨意調換,但是所有的元素都應當有不能缺少,我通常按照定義一個ADO對象的值的順序來定義它們。舉例來說,CustOrderHist存儲過程需要一個CustomID參數,所以用來創建發送到getData.asp的XML字符串的代碼為:

  dim s
   s = "<?xml version=""1.0""?>" & vbcrlf
   s = s & "<command><commandtext>"
   s = s & "CustOrderHist"
   s = s & "</commandtext>"
   s = s & "<returnsdata>" &True</returnsdata>"
   s = s & "<param>"
   s = s & "<name>CustomerID</name>"
   s = s & "<type><%=adVarChar%></type>"
   s = s & "<direction>" & <%=adParamInput%></direction>"
   s = s & "<size>" & len(CustomerID)& "</size>"
   s = s & "<value>" & CustomerID &"</value>"
   s = s & "</param>"
   s = s & "</command>"

  注意,前面的代碼都是客戶端代碼,ADO常量是不在客戶端定義的-這就是它們為什么使用<% %>標記圍起來的原因。服務器在發送響應之前使用正確的值取代它們。getData.asp頁有一個Response.ContentType,它的屬性為"text/xml",這樣,你就可以使用ResponseXML屬性來返回結果了。當請求返回紀錄,你就可以創建一個Recordset對象并且使用XMLHTTP來打開它:

  Dim R
   set R = createObject("ADODB.Recordset")
   R.open xhttp.responseXML

  當查詢語句返回數據時,通過設置XMLHTTPRequest對象的responseXML屬性來創建一個DOMDocument:

  Dim xml
   set xml = xhttp.responseXML

  輸出參數的XML字符串的每個返回值都包含一個元素,它們都是根元素<values>的直接子元素,例如:

  <?xml version=""1.0"" encoding=""gb2312""?>
  <values>
  <paramname>value</paramname>
   <paramname>value</paramname>
  </values>

  如果你的數據使用別的國家的文字,你可能需要把編碼屬性用相應的編碼替換,例如對于大部分歐洲語言,可以使用ISO-8859-1

  客戶端頁面使用返回的數據來格式化一個HTML字符串用于顯示,如:

  document.all("details").innerHTML = <一些格式化的HTML字符串>






主站蜘蛛池模板: 天堂色区| 视频福利一区 | 日本一本久 | 天天躁夜夜躁狂狂躁综合 | 中文字幕亚洲综合久久男男 | 婷婷六月久久综合丁香可观看 | 青青在线精品视频 | 中文字幕 一区 婷婷 在线 | 一区二区三区在线免费视频 | 手机看片日韩在线 | 四虎国产精品一区二区 | 亚洲欧美综合色区小说 | 倩女还魂在线观看完整版免费 | 人人干在线观看 | 午夜专区| 婷婷丁香九月 | 四虎影院永久网址 | 中文黄色 | 欧美亚洲桃花综合 | 中文学幕专区 | 午夜视频在线免费观看 | 午夜免费福利在线 | 一级美女黄色片 | 亚洲精品成人久久久影院 | 日韩一区精品视频在线看 | 青青草原伊人网 | 欧美综合另类 | 日韩欧美国产中文字幕 | 亚洲资源在线播放 | 亚洲成a人v| 午夜日 | 欧美中文一区 | 日日噜噜夜夜狠狠久久丁香 | 天堂a免费视频在线观看 | 日韩欧美在线不卡 | 四虎新地址 | 日韩精品一区二区三区中文在线 | 亚洲ccc36 | 色网站在线看 | 日本巨黄视频 | 日比免费视频 |