62、网页应用中的数据库使用指南

网页应用中的数据库使用指南

1. 主 - 明细数据表单的创建

在网页应用中,完成简单和复杂数据绑定的学习后,接下来深入探讨数据库处理,以主 - 明细数据表单为例。主 - 明细数据表单是指用户在列表框中点击单个项目时,应用程序会显示该项目多个字段的数据。

创建主 - 明细数据表单的步骤如下:
1. 创建 Web 应用 :创建一个名为 MasterDetailWeb 的 Web 应用,并添加所需的控件。
2. 添加数据适配器和数据集 :为 authors 表添加一个 SQL 数据适配器,并生成一个数据集 DataSet11。
3. 填充数据集 :在页面加载时,使用 SQL 数据适配器填充数据集:

Private Sub Page_Load(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles MyBase.Load
    SqlDataAdapter1.Fill(DataSet11)
End Sub
  1. 绑定列表框 :将列表框绑定到 authors 表的 au_lname 字段,设置其 DataSource 属性为 DataSet11,DataMember 属性为 “authors”,DataTextField 属性为 au_lname。同时,将 DataValueField 设置为 au_id,以便在用户点击作者姓氏时获取作者的 ID 值。
' 设置列表框属性
ListBox1.DataSource = DataSet11
ListBox1.DataMember = "authors"
ListBox1.DataTextField = "au_lname"
ListBox1.DataValueField = "au_id"
  1. 实现加载数据按钮 :使用一个“加载数据”按钮来加载数据到列表框,避免在服务器往返过程中丢失用户的选择。
Private Sub Button1_Click(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles Button1.Click
    ListBox1.DataBind()
End Sub
  1. 设置自动回发属性 :将列表框的 AutoPostBack 属性设置为 True,以便在用户进行选择时触发 SelectedIndexChanged 事件。
  2. 显示所选作者的数据 :使用数据视图来存储所选作者的记录,设置数据视图的 RowFilter 属性以指定要显示的作者记录。
Private Sub ListBox1_SelectedIndexChanged(ByVal sender _
    As System.Object, ByVal e As System.EventArgs) _
    Handles ListBox1.SelectedIndexChanged
    DataView1.RowFilter = "au_id = '" & ListBox1.SelectedValue & "'"
    TextBox1.DataBind()
    TextBox2.DataBind()
    TextBox3.DataBind()
    TextBox4.DataBind()
End Sub

以下是创建主 - 明细数据表单的流程图:

graph LR
    A[创建 Web 应用 MasterDetailWeb] --> B[添加控件和数据适配器]
    B --> C[生成数据集 DataSet11]
    C --> D[页面加载填充数据集]
    D --> E[绑定列表框]
    E --> F[实现加载数据按钮]
    F --> G[设置自动回发属性]
    G --> H[显示所选作者的数据]
2. 在 Internet Explorer 中本地使用数据集

在之前的示例中,使用导航按钮浏览数据集需要完整的服务器往返。如果只想在客户端本地浏览记录,可以使用 Internet Explorer 的 XML 数据源对象(DSO)将网页中的控件绑定到 XML 文档。

具体步骤如下:
1. 创建 XML 文档 :使用 Visual Basic .NET DataSet 类的 WriteXml 方法将 authors 表的数据写入 XML 文档 dataset.xml。

<?xml version="1.0" standalone="yes"?>
<DataSet1 xmlns="http://www.tempuri.org/DataSet1.xsd">
    <authors>
        <au_id>172 - 32 - 1176</au_id>
        <au_lname>White</au_lname>
        <au_fname>Johnson</au_fname>
        <phone>408 496 - 7223</phone>
        <address>10932 Bigge Rd.</address>
        <city>Menlo Park</city>
        <state>CA</state>
        <zip>94025</zip>
        <contract>true</contract>
    </authors>
    <!-- 其他作者记录 -->
</DataSet1>
  1. 在 HTML 中使用 XML DSO :在 HTML 文件 LocalData.html 中使用 com.ms.xml.dso.XMLDSO.class 对象读取 dataset.xml 文件,并将其绑定到文本字段。
<HTML>
<HEAD>
    <TITLE>
        Binding to Local Data
    </TITLE>
</HEAD>
<BODY>
    <H1>
        Binding to Local Data
    </H1>
    <CENTER>
        <APPLET CODE="com.ms.xml.dso.XMLDSO.class" 
            ID="RecordSet1" WIDTH=0 HEIGHT=0 MAYSCRIPT=true>
            <PARAM NAME="URL" VALUE="dataset.xml">
        </APPLET>
        First name: <INPUT TYPE="TEXT" DATASRC="#RecordSet1" 
            DATAFLD="au_fname" SIZE=10><P>
        Last name: <INPUT TYPE="TEXT" DATASRC="#RecordSet1" 
            DATAFLD="au_lname" SIZE=10><P>
        ID: <INPUT TYPE="TEXT" DATASRC="#RecordSet1" 
            DATAFLD="au_id" SIZE=12><P>
        City: <INPUT TYPE="TEXT" DATASRC="#RecordSet1" 
            DATAFLD="city" SIZE=12><P>
        <BUTTON ONCLICK="RecordSet1.recordset.MoveFirst()">
            &lt;&lt;
        </BUTTON>
        <BUTTON ONCLICK="if (!RecordSet1.recordset.BOF)    
            RecordSet1.recordset.MovePrevious()">
            &lt;
        </BUTTON>
        <BUTTON ONCLICK="if (!RecordSet1.recordset.EOF)       
            RecordSet1.recordset.MoveNext()">
            &gt;
        </BUTTON>
        <BUTTON ONCLICK="RecordSet1.recordset.MoveLast()">
            &gt;&gt;
        </BUTTON>
    </CENTER>
</BODY>
</HTML>

通过这种方式,XML DSO 读取 dataset.xml 文件,并使用 DATASRC 和 DATAFLD 属性将数据绑定到文本字段,用户可以在本地浏览数据,无需服务器往返。

3. 网页应用数据绑定总结

在网页应用中创建数据处理应用程序与 Windows 应用程序有相似之处,但也存在显著差异。例如,在网页应用中需要更多地自行维护数据绑定,包括使用 DataBind 方法刷新数据绑定,以及解决缺乏支持 Position 和 Count 属性的 BindingManagerBase 对象的问题。

  • 简单和复杂数据绑定 :可以使用控件的 (DataBindings) 属性将简单绑定控件的许多属性绑定到数据源。在简单绑定时,由于网页表单在往返服务器之间不维护数据绑定,使用数据视图存储单条记录并将控件绑定到数据视图是一个可行的选择。
  • 复杂绑定 :围绕 DataSource、DataMember、DataKeyField、DataTextField、DataTextFormatString 和 DataValueField 属性进行,可将列表框和复选框列表等复杂绑定控件绑定到数据源。
  • 特殊 Web 服务器控件 :数据网格、数据列表和重复器是专门为与数据源一起使用而设计的 Web 服务器控件。数据网格类似于 Windows 应用程序中的数据网格,使用 HTML 表格显示数据;数据列表可以自定义显示列表;重复器则更加自由,需要完全使用 HTML 元素创建模板。
  • 主 - 明细数据表单 :使用列表框和多个绑定文本框创建主 - 明细 Web 数据表单,用户可以从列表框中选择作者的姓氏,文本框将显示该作者的详细信息。
  • 本地数据集使用 :在 Internet Explorer 中使用 XML DSO 将数据集存储在 XML 文档中并绑定到 HTML 文本字段,实现本地数据浏览,避免服务器往返。
4. Q&A
  • 问题 1:如何自定义数据列表中每行之间使用的 HTML?
    • 答案 :使用 SeparatorTemplate 模板,该模板包含每行之间使用的 HTML 元素,例如
      元素。
  • 问题 2:能否在网页应用中使用数据读取器?
    • 答案 :可以使用命令对象的 ExecuteReader 方法创建在网页应用中工作的数据读取器。示例代码如下:
Private Sub Page_Load(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles MyBase.Load
    Dim Reader1 As System.Data.SqlClient.SqlDataReader
    DataReader1 = SqlCommand1.ExecuteReader()
    DataGrid1.DataSource = DataReader1
    DataGrid1.DataBind()
    DataReader1.Close()
End Sub
5. 工作坊
5.1 测验
  1. 在网页应用中将文本框绑定到数据集中的字段,但运行应用程序时文本框为空,可能是什么问题?
    • 答案 :可能有两个问题,一是需要使用数据适配器的 Fill 方法填充数据集,二是需要使用文本框的 DataBind 方法刷新数据绑定。
  2. 在属性窗口中使用什么属性将简单绑定控件绑定到数据源?
    • 答案 :使用 (DataBindings) 属性。
  3. 在网页应用中支持复杂数据绑定使用哪些属性?
    • 答案 :使用 DataSource、DataMember、DataKeyField、DataTextField、DataTextFormatString 和 DataValueField 属性。
  4. 假设有一个绑定到 authors 表的数据列表,要将数据列表项模板中的标签绑定到 au_fname 字段,可以使用什么自定义绑定表达式?
    • 答案 :可以使用 DataBinder.Eval(Container, “DataItem.au_fname”)。
  5. 在重复器中使用什么元素来格式化交替行?
    • 答案 :使用 元素。
5.2 练习
  1. 创建一个新的 Web 应用,将文本框绑定到 pubs 数据库的 publishers 表中的字段,并实现导航按钮,让用户可以浏览该表中的记录。如果无法访问 pubs 数据库,可以使用其他数据库表进行相同的练习。
  2. 创建一个新的 Web 应用,让用户在文本字段中输入作者的姓氏并点击“查找”按钮,搜索 authors 表中的特定作者。如果找到匹配项,在绑定的文本框中显示作者的信息。可以使用数据视图并设置其 RowFilter 属性来查找所需的作者。如果无法访问 pubs 数据库,可以使用其他数据库表进行相同的练习。(额外加分:允许处理具有相同姓氏的多个作者)
6. ADO.NET 回顾

ADO.NET 工作围绕连接对象、数据适配器和数据集对象展开,这三个对象构成了 ADO.NET 的基础。

6.1 连接对象

在 Visual Basic .NET 2003 中,有四种类型的连接对象:
| 连接对象类型 | 适用场景 |
| — | — |
| SqlConnection | 用于 Microsoft SQL Server 7.0 或更高版本的应用程序 |
| OleDbConnection | 用于 Microsoft SQL Server 6.5 或更早版本或任何支持 OLE DB 接口的 OLE DB 提供程序的应用程序 |
| OdbcConnection | 用于开放数据库连接性(ODBC) |
| OracleConnection | 用于使用 Oracle 数据源的应用程序 |

使用连接对象时,需要提供连接字符串。可以使用 IDE 中的可视化工具创建示例连接字符串,示例代码如下:

Dim ConnectionString As String = "Provider=SQLOLEDB.1;Integrated " & _
    "Security=SSPI;Persist Security Info=False;Initial " & _
    "Catalog=pubs;Packet Size=4096;Workstation ID=STEVE;" & _
    "Use Encryption for Data=False"
Dim Connection1 As OleDbConnection = New OleDbConnection(ConnectionString)
6.2 命令对象

创建连接对象后,使用 Open 方法打开连接,并将其分配给命令对象的 Connection 属性。首先创建一个新的命令对象,传递要使用的 SQL 语句,并设置命令类型,示例代码如下:

Dim ConnectionString As String = "Provider=SQLOLEDB.1;Integrated " & _
    "Security=SSPI;Persist Security Info=False;Initial " & _
    "Catalog=pubs;Packet Size=4096;Workstation ID=STEVE;" & _
    "Use Encryption for Data=False"
Dim Connection1 As OleDbConnection = New OleDbConnection(ConnectionString)
Dim Command1 As OleDbCommand = _
    New OleDbCommand("SELECT * FROM authors")
Command1.CommandType = CommandType.Text
Connection1.Open()
Command1.Connection = Connection1
6.3 数据适配器和数据集

将命令对象分配给数据适配器的 SelectCommand 属性,调用数据适配器的 Fill 方法填充数据集,然后可以将数据集绑定到数据网格,示例代码如下:

Dim Command1 As OleDbCommand = _
    New OleDbCommand("SELECT * FROM authors")
Command1.CommandType = CommandType.Text
Connection1.Open()
Command1.Connection = Connection1
Dim OleDbDataAdapter1 As OleDbDataAdapter = New OleDbDataAdapter()
OleDbDataAdapter1.SelectCommand = Command1
OleDbDataAdapter1.Fill(dataset1, "authors")
DataGrid1.SetDataBinding(dataset1, "authors")

通过连接对象连接到数据源,将连接分配给命令对象,将命令对象分配给数据适配器的 SelectCommand 属性,使用数据适配器填充数据集并将其绑定到数据网格,完成数据库操作。使用 ADO.NET 对象需要一定的练习。

7. 高级主题展望

接下来将探讨一些高级主题,包括:
- 创建用户控件 :创建自己的 Windows 控件(用户控件),可以嵌入标准 Windows 控件或从头开始创建全新的用户控件。
- 创建 Web 用户控件 :为 Web 应用程序创建自己的控件。
- 多线程 :使应用程序支持多线程执行,实现同时进行多项任务。
- 创建服务 :创建在 Windows 后台运行的 Windows 服务,并从其他应用程序连接到这些服务;创建 Web 服务,使 Windows 应用程序能够连接到 Web 上的代码。
- 应用程序部署 :将完成的应用程序打包成 Windows 安装程序可以使用的文件,以便在其他计算机上安装应用程序。

网页应用中的数据库使用指南

8. 创建用户控件

在开发过程中,创建自己的 Windows 控件(即用户控件)是一项非常实用的技能。用户控件可以嵌入标准的 Windows 控件,如文本框、按钮和列表框等,也可以完全从头开始创建。以下是创建用户控件的一般步骤:
1. 打开开发环境 :启动 Visual Basic .NET 开发环境。
2. 创建新的用户控件项目 :在菜单栏中选择“文件” -> “新建” -> “项目”,然后选择“Windows 控件库”模板。
3. 设计用户控件界面 :在设计视图中,将需要的标准控件拖放到用户控件上,并进行布局和样式设置。
4. 编写代码逻辑 :在代码视图中,为控件添加事件处理程序和其他必要的代码逻辑。
5. 编译和测试 :编译项目,然后在其他 Windows 应用程序中引用该用户控件进行测试。

以下是一个简单的用户控件示例,包含一个文本框和一个按钮:

Public Class MyUserControl
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        MessageBox.Show("你点击了按钮,文本框内容为:" & TextBox1.Text)
    End Sub
End Class
9. 创建 Web 用户控件

Web 用户控件用于在 Web 应用程序中创建自定义的控件。创建 Web 用户控件的步骤如下:
1. 打开 Web 应用程序项目 :使用 Visual Studio 打开现有的 Web 应用程序项目或创建一个新的项目。
2. 添加新的 Web 用户控件 :在解决方案资源管理器中,右键单击项目,选择“添加” -> “新项”,然后选择“Web 用户控件”模板。
3. 设计 Web 用户控件界面 :在设计视图中,使用 HTML 和 ASP.NET 控件设计控件的界面。
4. 编写代码逻辑 :在代码视图中,为控件添加事件处理程序和其他必要的代码逻辑。
5. 在 Web 页面中使用 Web 用户控件 :在需要使用该控件的 Web 页面中,添加对该控件的引用,并将其放置在页面上。

以下是一个简单的 Web 用户控件示例,包含一个标签和一个按钮:

<%@ Control Language="VB" AutoEventWireup="false" CodeFile="MyWebUserControl.ascx.vb" Inherits="MyWebUserControl" %>
<asp:Label ID="Label1" runat="server" Text="欢迎使用 Web 用户控件"></asp:Label>
<asp:Button ID="Button1" runat="server" Text="点击我" OnClick="Button1_Click" />
Partial Class MyWebUserControl
    Inherits System.Web.UI.UserControl

    Protected Sub Button1_Click(sender As Object, e As EventArgs)
        Label1.Text = "你点击了按钮!"
    End Sub
End Class
10. 多线程的使用

多线程可以使应用程序支持多个线程的执行,从而实现同时进行多项任务。在 Visual Basic .NET 中使用多线程的步骤如下:
1. 定义线程执行的方法 :创建一个方法,该方法将在新线程中执行。
2. 创建线程对象 :使用 Thread 类创建一个新的线程对象,并将步骤 1 中定义的方法作为参数传递给线程对象的构造函数。
3. 启动线程 :调用线程对象的 Start 方法启动线程。

以下是一个简单的多线程示例:

Imports System.Threading

Public Class Form1
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Dim newThread As New Thread(AddressOf DoWork)
        newThread.Start()
    End Sub

    Private Sub DoWork()
        For i As Integer = 1 To 10
            Thread.Sleep(1000) ' 模拟耗时操作
            Console.WriteLine("线程正在执行,当前计数:" & i)
        End For
    End Sub
End Class
11. 创建服务
11.1 创建 Windows 服务

Windows 服务是在 Windows 后台运行的程序。创建 Windows 服务的步骤如下:
1. 创建新的 Windows 服务项目 :在 Visual Studio 中,选择“文件” -> “新建” -> “项目”,然后选择“Windows 服务”模板。
2. 设计服务功能 :在代码视图中,重写 OnStart OnStop 方法,分别实现服务启动和停止时的操作。
3. 安装和配置服务 :使用安装程序类将服务安装到系统中,并进行配置。

以下是一个简单的 Windows 服务示例:

Imports System.ServiceProcess

Public Class MyWindowsService
    Inherits ServiceBase

    Public Sub New()
        Me.ServiceName = "MyWindowsService"
    End Sub

    Protected Overrides Sub OnStart(args() As String)
        ' 服务启动时的操作
        Console.WriteLine("Windows 服务已启动")
    End Sub

    Protected Overrides Sub OnStop()
        ' 服务停止时的操作
        Console.WriteLine("Windows 服务已停止")
    End Sub
End Class
11.2 创建 Web 服务

Web 服务可以使 Windows 应用程序连接到 Web 上的代码。创建 Web 服务的步骤如下:
1. 创建新的 Web 服务项目 :在 Visual Studio 中,选择“文件” -> “新建” -> “项目”,然后选择“ASP.NET Web 服务应用程序”模板。
2. 定义 Web 服务方法 :在代码视图中,创建公共的方法,并使用 WebMethod 属性标记这些方法。
3. 发布和调用 Web 服务 :将 Web 服务发布到 Web 服务器上,然后在其他应用程序中通过 URL 调用该 Web 服务。

以下是一个简单的 Web 服务示例:

Imports System.Web.Services

<WebService(Namespace:="http://tempuri.org/")> _
<WebServiceBinding(ConformsTo:=WsiProfiles.BasicProfile1_1)> _
<Global.Microsoft.VisualBasic.CompilerServices.DesignerGenerated()> _
Public Class MyWebService
    Inherits System.Web.Services.WebService

    <WebMethod()> _
    Public Function AddNumbers(ByVal num1 As Integer, ByVal num2 As Integer) As Integer
        Return num1 + num2
    End Function
End Class
12. 应用程序部署

将完成的应用程序部署到其他计算机上是开发过程的最后一步。以下是应用程序部署的一般步骤:
1. 打包应用程序 :使用 Visual Studio 的发布功能将应用程序打包成 Windows 安装程序可以使用的文件。
2. 复制安装文件 :将打包好的安装文件复制到目标计算机上。
3. 运行安装程序 :在目标计算机上运行安装程序,按照提示完成应用程序的安装。

以下是一个简单的应用程序部署流程图:

graph LR
    A[开发完成应用程序] --> B[使用发布功能打包]
    B --> C[复制安装文件到目标计算机]
    C --> D[运行安装程序]
    D --> E[完成应用程序安装]

通过以上步骤,我们可以将开发好的应用程序成功部署到其他计算机上,让更多的用户使用。在实际开发过程中,需要根据具体的需求和场景,灵活运用这些高级技术,提高应用程序的性能和功能。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值