乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      體驗Jasper (轉(zhuǎn) 思?xì)w囈語 )

       快樂學(xué)習(xí) 2007-05-13

       

      在3月份的MVP峰會上,ASP.NET開發(fā)團(tuán)隊給我們示范了Jasper(好像那時還不是這名稱),因為NDA的原因,我們無法透露細(xì)節(jié)。如今Jasper公開推出了,讓我們來體驗一下Jasper。

      1. 安裝所需軟件和建立數(shù)據(jù)庫

      1) Visual Studio Orcas Beta 1。下載細(xì)節(jié)可見:

      http://msdn2.microsoft.com/en-us/vstudio/aa700831.aspx

      2) SQL Server 2005 (Express)版本 Edition。SQL Server 2005 Express版可下載于

      http://www.microsoft.com/downloads/details.aspx?familyid=220549b5-0b07-4448-8848-dcc397514b41&displaylang=en

      3) Iron Python 1.1 (你也可以VB.NET 9)。 下載地址:

      http://www./IronPython/Release/ProjectReleases.aspx?ReleaseId=2573

      4) Jasper CTP。下載地址:

      http://www.microsoft.com/downloads/details.aspx?FamilyId=471BB3AC-B31A-49CD-A567-F2E286715C8F&displaylang=en

      5) 運行 C:\Program Files\Microsoft Codename Jasper CTP\Samples\Create and Populate Northwind.cmd 來創(chuàng)建一個小的Northwind數(shù)據(jù)庫。

      2.Jasper API由三個主要部分組成:

      1. DynamicContext是使用Jasper的起點。應(yīng)用程序調(diào)用該類的靜態(tài)方法CreateDynamicContext()創(chuàng)建一個動態(tài)的上下文對象,該對象封裝了與數(shù)據(jù)庫交互所需的連接和狀態(tài)信息。該對象對從查詢返回的數(shù)據(jù)對象進(jìn)行變化跟蹤(change tracking)和身份確定(identity resolution),可以用來把所作的數(shù)據(jù)對象的變化保存到數(shù)據(jù)庫去。
      2. Query類支持建立和發(fā)出查詢命令,命令可以用Entity SQL查詢語言或LINQ。
      3. 代表數(shù)據(jù)實體的數(shù)據(jù)類,支持讀取和改變屬性值,以及自定義的業(yè)務(wù)邏輯。數(shù)據(jù)類是運行時動態(tài)生成的,其名稱和結(jié)構(gòu)與數(shù)據(jù)庫的數(shù)據(jù)定義或指定的實體數(shù)據(jù)模型相符。 Jasper數(shù)據(jù)類生成器使用約定來建立數(shù)據(jù)類的名稱和它們的屬性。對數(shù)據(jù)庫里的每個表,或?qū)嶓w數(shù)據(jù)模型中的每個實體集合,Jasper會生成一個類。Jasper有個命名組件,可以把名稱為復(fù)數(shù)的表名轉(zhuǎn)換成單數(shù)的類名,譬如,對應(yīng)Products表,Jasper會生成Product類。對應(yīng)數(shù)據(jù)表的每個字段,Jasper會在類中生成一個對應(yīng)的屬性。Jasper會根據(jù)數(shù)據(jù)表的外鍵-主鍵關(guān)系建立引用屬性。DynamicContext.CreateDynamicContext()返回的上下文對象對應(yīng)每個表還含有一個類型是Query的屬性,譬如,Categories屬性和Products屬性等。該上下文對象對數(shù)據(jù)庫中的每個存儲過程還會生成相應(yīng)的方法。你可以在代碼中使用這些動態(tài)生成的數(shù)據(jù)類,即使這些類在你編寫代碼時還不存在。在運行時,延遲綁定機制會確定你對這些數(shù)據(jù)類的引用。

      3. 看一下其中的BuildingUI_Web例子

      GridViewPage.aspx,其顯示是這樣的:

      .aspx內(nèi)容為:

      <%@ Page Language="VB" AutoEventWireup="false" CodeFile="GridViewPage.aspx.vb"

      Inherits="GridViewPage" %>

      <%@ Register Assembly="Microsoft.Jasper.CTP" Namespace="Microsoft.Jasper.Web"

      TagPrefix="jasper" %>

      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

      "http://www./TR/xhtml1/DTD/xhtml1-transitional.dtd">

      <html xmlns="http://www./1999/xhtml">
      <head runat="server">
      <title>Demonstrate Building Web UI with Project Jasper using a GridView

      control</title>
      </head>
      <body>
      <form id="form1" runat="server">
      <div>
      <asp:Button ID="BackToMainButton" runat="server" Text="Back To Main"
      PostBackUrl="Default.aspx" />
      </div>
      <asp:GridView ID="Products" runat="server"

      AutoGenerateDeleteButton="True"
      AutoGenerateEditButton="True" AllowPaging="True">
      </asp:GridView>
      <jasper:AutoDataSource ID="AutoDataSource1" runat="server">
      </jasper:AutoDataSource>
      </form>
      </body>
      </html>

      后臺文件GridViewPage.aspx.vb,是這樣的(注釋被去除了):

      Imports Microsoft.Jasper

      Partial Class GridViewPage
                 Inherits System.Web.UI.Page

      Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
                AutoDataSource1.DynamicContext = GetDynamicContext()
      End Sub

      Private Function GetDynamicContext() As DynamicContext
                Dim context As DynamicContext = Session("DynamicContext")
                If context Is Nothing Then
                        Dim connectionString As String = ConfigurationManager.ConnectionStrings("Northwind").ConnectionString
                        context = DynamicContext.CreateDynamicContext(connectionString)
                        Session("DynamicContext") = context
                End If
               Return context
      End Function
      End Class

      注意,在后臺.vb中只需要設(shè)置前臺數(shù)據(jù)源控件AutoDataSource的DynamicContext屬性。

      Jasper在看到前臺的
      <asp:GridView ID="Products" runat="server" AutoGenerateDeleteButton="True" AutoGenerateEditButton="True" AllowPaging="True">
      </asp:GridView>

      根據(jù)設(shè)置的ID="Products",Jasper會將AutoDataSource1.DynamicContext中的Products查詢屬性綁定到GridView上。注意上面的第一行記錄,Chai2,是在我點擊“Edit”按鈕編輯更新后的結(jié)果。

      再看另一個主從關(guān)系的例子,MasterDetailsPage.aspx,

      后臺MasterDetailsPage.aspx.vb內(nèi)容跟GridViewPage.aspx.vb是一樣的,MasterDetailsPage.aspx 的內(nèi)容是這樣的(除去了前面的一些類似的聲明內(nèi)容):

      <form id="form1" runat="server">
      <asp:ListBox ID="CategoryName" runat="server" AutoPostBack="True"
      Height="223px" Width="175px"></asp:ListBox>
      <asp:GridView ID="Categories_Products" runat="server">
      </asp:GridView>
      <Jasper:AutoDataSource ID="AutoDataSource1" runat="server">
      </Jasper:AutoDataSource>
      </form>

      在這里,Jasper會看到<asp:ListBox>的ID與動態(tài)生成的Category類里的CategoryName屬性一樣,該控件就會綁定到對應(yīng)的數(shù)據(jù)表上,同時顯示指定的屬性值。

      如果控件名是<Name>_<NavigationPropertyName>的形式,Jasper 就會將其綁定到<Name>數(shù)據(jù)表對應(yīng)的類的引用屬性<NavigationPropertyName>之上。同時,AutoDataSource控件會去尋找綁定到<Name>的另一個控件,用它作為這個關(guān)系導(dǎo)航的數(shù)據(jù)源。

      默認(rèn)的綁定機制也可以通過覆蓋AutoDataSource上的各個AutoBind()方法來實現(xiàn)。AutoBind()方法可以把任意查詢對象綁定到可數(shù)據(jù)綁定的控件上。可數(shù)據(jù)綁定的控件既可明確指定,也可以讓AutoDataSource控件自動根據(jù)查詢的返回類型來確定合適的控件。

        本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多