在asp.net中写一个简单的基于c#的web与sql数据库相连的旅游管理系统的动态网站

时间: 2024-03-20 20:41:40 浏览: 18
这是一个简单的基于 C# 和 SQL 数据库的旅游管理系统的动态网站示例。该网站使用 ASP.NET Web Forms 模型,使用 SQL Server 数据库存储数据。 首先,您需要创建一个 ASP.NET Web Forms 项目,并设置好连接到 SQL Server 数据库的连接字符串。可以在 Web.config 文件中设置连接字符串。 接下来,您需要创建一个数据库表来存储旅游信息。以下是一个示例 SQL 脚本,用于创建一个名为“Tour” 的表: ```sql CREATE TABLE Tour ( TourId INT PRIMARY KEY IDENTITY, TourName VARCHAR(50) NOT NULL, TourDescription VARCHAR(500) NOT NULL, TourPrice DECIMAL(10, 2) NOT NULL, TourImageUrl VARCHAR(200) NOT NULL ) ``` 下面是一个示例 ASP.NET 页面,用于显示旅游信息并允许用户添加新的旅游: ```csharp <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Tour.aspx.cs" Inherits="MyWebApp.Tour" %> <!DOCTYPE html> <html> <head> <title>Tour Management</title> </head> <body> <form id="form1" runat="server"> <h1>Tour Management</h1> <hr /> <h2>Add New Tour</h2> <div> <label>Tour Name:</label> <asp:TextBox ID="txtTourName" runat="server"></asp:TextBox> </div> <div> <label>Tour Description:</label> <asp:TextBox ID="txtTourDescription" runat="server" TextMode="MultiLine"></asp:TextBox> </div> <div> <label>Tour Price:</label> <asp:TextBox ID="txtTourPrice" runat="server"></asp:TextBox> </div> <div> <label>Tour Image URL:</label> <asp:TextBox ID="txtTourImageUrl" runat="server"></asp:TextBox> </div> <div> <asp:Button ID="btnAddTour" runat="server" Text="Add Tour" OnClick="btnAddTour_Click" /> </div> <hr /> <h2>Tours</h2> <asp:GridView ID="gvTours" runat="server" AutoGenerateColumns="False" DataKeyNames="TourId" OnRowDeleting="gvTours_RowDeleting"> <Columns> <asp:BoundField DataField="TourId" HeaderText="Tour ID" ReadOnly="True" /> <asp:BoundField DataField="TourName" HeaderText="Tour Name" /> <asp:BoundField DataField="TourDescription" HeaderText="Tour Description" /> <asp:BoundField DataField="TourPrice" HeaderText="Tour Price" /> <asp:BoundField DataField="TourImageUrl" HeaderText="Tour Image URL" /> <asp:CommandField ShowDeleteButton="True" /> </Columns> </asp:GridView> </form> </body> </html> ``` 在代码文件 Tour.aspx.cs 中,您需要编写逻辑来处理添加新旅游和删除旅游的操作。以下是一个示例代码: ```csharp using System; using System.Configuration; using System.Data.SqlClient; namespace MyWebApp { public partial class Tour : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { BindTourData(); } } protected void btnAddTour_Click(object sender, EventArgs e) { string tourName = txtTourName.Text; string tourDescription = txtTourDescription.Text; decimal tourPrice = decimal.Parse(txtTourPrice.Text); string tourImageUrl = txtTourImageUrl.Text; string connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString; SqlConnection connection = new SqlConnection(connectionString); string query = "INSERT INTO Tour (TourName, TourDescription, TourPrice, TourImageUrl) VALUES (@TourName, @TourDescription, @TourPrice, @TourImageUrl)"; SqlCommand command = new SqlCommand(query, connection); command.Parameters.AddWithValue("@TourName", tourName); command.Parameters.AddWithValue("@TourDescription", tourDescription); command.Parameters.AddWithValue("@TourPrice", tourPrice); command.Parameters.AddWithValue("@TourImageUrl", tourImageUrl); connection.Open(); command.ExecuteNonQuery(); connection.Close(); BindTourData(); } protected void gvTours_RowDeleting(object sender, System.Web.UI.WebControls.GridViewDeleteEventArgs e) { int tourId = int.Parse(gvTours.DataKeys[e.RowIndex].Value.ToString()); string connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString; SqlConnection connection = new SqlConnection(connectionString); string query = "DELETE FROM Tour WHERE TourId = @TourId"; SqlCommand command = new SqlCommand(query, connection); command.Parameters.AddWithValue("@TourId", tourId); connection.Open(); command.ExecuteNonQuery(); connection.Close(); BindTourData(); } private void BindTourData() { string connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString; SqlConnection connection = new SqlConnection(connectionString); string query = "SELECT * FROM Tour"; SqlCommand command = new SqlCommand(query, connection); connection.Open(); SqlDataReader reader = command.ExecuteReader(); gvTours.DataSource = reader; gvTours.DataBind(); reader.Close(); connection.Close(); } } } ``` 这只是一个简单的示例,您可以根据需要添加更多的功能和逻辑来创建更复杂的旅游管理系统。

相关推荐

最新推荐

recommend-type

ASP.NET(C#) Web Api通过文件流下载文件的实例

主要介绍了ASP.NET(C#) Web Api通过文件流下载文件的方法,提供源码下载,需要的朋友可以参考下。
recommend-type

asp.net实现的MVC跨数据库多表联合动态条件查询功能示例

主要介绍了asp.net实现的MVC跨数据库多表联合动态条件查询功能,结合实例形式较为详细分析了asp.net基于MVC架构的跨数据库多表联合查询功能实现技巧,需要的朋友可以参考下
recommend-type

ASP.NET课程-学生信息管理系统实验报告.doc

ASP.NET课程-学生信息管理系统实验报告 编写学生信息管理系统,实现以下功能: 1. 学生信息管理:对在校学生信息进行添加、删除、修改、查询等操作。 2. 学生成绩管理:对已经录入的学生信息进行添加、删除、修改...
recommend-type

在IIS上部署ASP.NET Core Web API的方法步骤

主要介绍了在IIS上部署ASP.NET Core Web API的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

ASP.NET中Web API的简单实例

Web API框架是一个面向Http协议的通信框架,Web API 框架是一个面向Http协议的通信框架。Web API 框架目前支持两种数据格式的序列化:Json 及 Xml。在不做任何配置的情况下,则 Web API 会自动把数据使用xml进行序列...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。