ASP.NET网上车辆档案管理系统

 摘  要

本文采用基于Web的Asp.net技术,并与sql server 2000数据库相结合,研发了一套车辆档案管理系统。该系统扩展性好,易于维护。简化了车辆档案设计流程,去除了冗余信息。汽车销售企业可以通过本系统完成整个销售及售后所有档案的信息化管理,轻松的完成添加,查询及维护等工作。 因此将发挥计算机的庞大的存储空间,高性能的处理能力,高度可靠的数据安全,清晰的可视化数据等这些优势让企业对车辆档案进行管理,实现了计算机资源的合理利用,真正实现了减少劳动力提高劳动质量的目的。

关键词:Asp.net,处理能力,Web,数据安全

2.1 Asp.net

ASP.NET又叫ASP+,但并不仅仅是ASP的简单升级,而是Microsoft推出的新一代Active Server Pages脚本语言。ASP.NET是微软发展的新型体系结构.NET的一部分,它的全新技术架构会让每一个人的网络生活都变得更简单。

ASP.NET 是一种建立动态Web应用程序的技术。它是.NET 框架的一部分,您可以使用任何.NET兼容的语言来编写ASP.NET应用程序。 使用Visual Basic .NET, C#, J#, ASP.NET 页面(Web Forms) 进行编译可以提供比脚本语言更出色的性能表现。Web Forms 允许您在网页基础上建立强大的窗体。当建立页面时, 您可以使用ASP.NET 服务端控件来建立常用的UI元素,并对它们编程来完成一般的任务。这些控件允许您使用内建可重用的组件和自定义组件来快速建立Web Form,使代码简单化。ASP.NET 提供了一种编程模型和结构,对比原来的Web技术来说,它能更快速、容易地建立灵活、安全和稳定的应用程序。 

ASP.NET 可以用来承载多个 Web 应用程序,其中每个应用程序由 Web 站点(Web 站点在 Web 服务器上表现为一个唯一的主机名/端口组合)内的一个唯一的 URL 前缀来标识。

 2.2 Sql server2000

SQL Server是由Microsoft开发和推广的关系数据库管理系统(DBMS),它最初是由MicrosoftSybaseAshton-Tate三家公司共同开发的,并于1988年推出了第一个OS/2版本。 SQL Server近年来不断更新版本,1996年,Microsoft 推出了SQL Server 6.5版本;1998年,SQL Server 7.0版本和用户见面;SQL Server 2000Microsoft公司于2000年推出的最新版本。

2.3 Microsoft Office Visio 2003

Visio 2003是一个图表绘制解决方案,可以帮助人们将业务和技术概念转化为可视化图表。 使用Visio 2003 表达、记录和传达重要的信息,给您的读者留下专业化的印象。

Visio 2003 中的新增特性包括:增强的图表绘制功能、新的模板、最新的导入和导出功能、同其它应用程序进行协作的改进方法、以及众多面向开发人员和高级用户的新增高级特性。

2.4 PowerDesigner Trial

PowerDesignerSybase公司的CASE工具集,使用它可以方便地对管理信息系统进行分析设计,它几乎包括了数据库模型设计的全过程。利用PowerDesigner可以制作数据流程图、概念数据模型、物理数据模型,可以生成多种客户端开发工具的应用程序,还可为数据仓库制作结构模型,也能对团队设计模型进行控制。它可与许多流行的数据库设计软件,例如:PowerBuilderDelphiVB等相配合使用来缩短开发时间和使系统设计更优化。

4.1登录

    当用户登录时,有普通管理员和系统管理员之分。登录界面如下所示:

                         图4-1登录界面

用户名密码不能为空,系统管理员用户名和密码均为sadmini,普通管理员均为admini。此时,系统将会连接到数据库。

连接数据库主要代码:

Private Sub Page_Load(ByVal sender As System.Object, ByVal e System.EventArgs) Handles MyBase.Load

conn = New SqlConnection("data source=127.0.0.1;integrated security=SSPI;initial catalog=车辆档案管理")

da = New SqlDataAdapter("select * from 车辆基本信息表", conn)

da.FillSchema(ds, SchemaType.Source, "车辆基本信息表")

da.Fill(ds, "车辆基本信息表")

If Not Page.IsPostBack Then

DataGrid1.DataSource = ds

DataGrid1.DataMember = "车辆基本信息表"

DataGrid1.DataBind()

End If

End Sub

 当系统管理员登录时界面如下(普通管理员不能登录此界面):

图4-2系统管理员初始界面

在系统管理员界面中,系统管理员可以对各种用户进行管理。

4.2 车辆购车档案功能的运行

当点击车辆购车档案时,界面如下所示:在车辆购车档案中可以进行添加、查询、更新、删除的操作,用来对车辆信息表(编号,车辆名称,车型,颜色,车牌号码,发动机号,底盘号码,车架号码,座位数,载重,购车价格,购车日期,初始公里数,保修期至,客户名)的信息进行更改。

   图4-3  车辆购车档案界面

   在界面中的文本框,填入相应信息,然后点击“添加”按钮,就会在下面的dategrid中显示出添加的记录。

  例如,添加编号为4的这条记录,执行效果如下所示:

图4-4 添加实例图

添加主要代码:

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles addBtn.Click, Button1.Click

Dim id, count As Integer

Dim bh, clmc, cx, ys, cphm, fdjh, dphm, cjhm, zws, zz, gcjg, gcrq, csgls, bzqz, khm As String

        bh = CStr(Trim(Me.bh.Text))

        clmc = CStr(Trim(Me.clmc.Text))

        cx = CStr(Trim(Me.cx.Text))

        ys = CStr(Trim(Me.ys.Text))

        cphm = CStr(Trim(Me.cphm.Text))

        fdjh = CStr(Trim(Me.fdjh.Text))

        dphm = CStr(Trim(Me.dphm.Text))

        cjhm = CStr(Trim(Me.cjhm.Text))

        zws = CStr(Trim(Me.zws.Text))

        zz = CStr(Trim(Me.zz.Text))

        gcjg = CStr(Trim(Me.gcjg.Text))

        gcrq = CStr(Trim(Me.gcrq.Text))

        csgls = CStr(Trim(Me.csgls.Text))

        bzqz = CStr(Trim(Me.bzqz.Text))

        khm = CStr(Trim(Me.khm.Text))

        Dim rowNew As DataRow = ds.Tables("车辆基本信息表").NewRow

        rowNew("编号") = bh

        rowNew("车辆名称") = clmc

        rowNew("车型") = cx

        rowNew("颜色") = ys

        rowNew("车牌号码") = cphm

        rowNew("发动机号") = fdjh

        rowNew("底盘号码") = dphm

        rowNew("车架号码") = cjhm

        rowNew("座位数") = zws

        rowNew("载重") = zz

        rowNew("购车价格") = gcjg

        rowNew("购车日期") = gcrq

        rowNew("初始公里数") = csgls

        rowNew("保修期至") = bzqz

        rowNew("客户名") = khm

        ds.Tables("车辆基本信息表").Rows.Add(rowNew)

        DataGrid1.DataSource = ds.Tables("车辆基本信息表")

        DataGrid1.DataBind()

        Dim myCBuilder As New SqlCommandBuilder(da)

        da.InsertCommand = myCBuilder.GetInsertCommand

        da.Update(ds, "车辆基本信息表")

End Sub

当点击“查询”按钮时,界面如下所示:

图4-5 查询页面

例如,查询客户名为“张青青”的客户名,其执行结果如下:

图4-6查询实例

查询主要代码:

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

Dim objConn As New SqlConnection

objConn = ConnectionDatabase()

Dim strSQL As String

Dim datatable1 As DataTable

strSQL = "SELECT * FROM 车辆基本信息表 where 客户名='" +TextBox1.Text+ "'"

datatable1 = CreateDataSet(strSQL, "车辆基本信息表").Tables("车辆基本信息表")

   DataGrid1.DataSource = datatable1

   DataGrid1.DataBind()

End Sub

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.LoadConnectionDatabase()

   Dim strSQL As String

   Dim datatable1 As DataTable

   strSQL = "SELECT * FROM 车辆基本信息表 "

datatable1 = CreateDataSet(strSQL, "车辆基本信息表").Tables("车辆基本信息表")

DataGrid1.DataSource = datatable1

DataGrid1.DataBind()

End Sub

当在车辆购车档案中更新信息时,界面如下所示:

图4-7 更新页面

更新代码如下:

Private Sub datagrid1_EditCommand(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs)HandlesDataGrid1.EditCommand

a = CInt(e.Item.Cells(2).Text)

DataGrid1.EditItemIndex = e.Item.ItemIndex

DataGrid1.DataSource = ds

DataGrid1.DataMember = "车辆基本信息表"DataGrid1.DataBind()

End Sub

Private Sub datagrid1_UpdateCommand(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs)HandlesDataGrid1.UpdateCommand

    Dim rowChange As DataRow = ds.Tables("车辆基本信息表").Rows.Find(a)

    rowChange.BeginEdit()

    rowChange("编号") = (CType(e.Item.Cells(2).Controls(0), TextBox)).Text.Trim()

    rowChange("车辆名称") = (CType(e.Item.Cells(3).Controls(0), TextBox)).Text.Trim()

    rowChange("车型") = (CType(e.Item.Cells(4).Controls(0), TextBox)).Text.Trim()

    rowChange("颜色") = (CType(e.Item.Cells(5).Controls(0), TextBox)).Text.Trim()

    rowChange("车牌号码") = (CType(e.Item.Cells(6).Controls(0), TextBox)).Text.Trim()

 rowChange("发动机号") = (CType(e.Item.Cells(7).Controls(0), TextBox)).Text.Trim()

rowChange("底盘号码") = (CType(e.Item.Cells(8).Controls(0), TextBox)).Text.Trim()

    rowChange("车架号码") = (CType(e.Item.Cells(9).Controls(0), TextBox)).Text.Trim()

rowChange("座位数") = (CType(e.Item.Cells(10).Controls(0), TextBox)).Text.Trim()

  rowChange("载重") = (CType(e.Item.Cells(11).Controls(0), TextBox)).Text.Trim()

    rowChange("购车价格") = (CType(e.Item.Cells(12).Controls(0), TextBox)).Text.Trim()

  rowChange("购车日期") = (CType(e.Item.Cells(13).Controls(0), TextBox)).Text.Trim()

rowChange("初始公里数") = (CType(e.Item.Cells(14).Controls(0), TextBox)).Text.Trim()

rowChange("保修期至") = (CType(e.Item.Cells(15).Controls(0), TextBox)).Text.Trim()

 rowChange("客户名") = (CType(e.Item.Cells(16).Controls(0), TextBox)).Text.Trim()

    rowChange.EndEdit()

    DataGrid1.EditItemIndex = -1

    DataGrid1.DataSource = ds.Tables("车辆基本信息表")

    DataGrid1.DataBind()

    Dim myCBuilder As New SqlCommandBuilder(da)

    da.UpdateCommand = myCBuilder.GetUpdateCommandda.Update(ds, "车辆基本信息表")

End Sub

4.3车辆维修档案功能的运行

当点击维修档案时,界面如下所示:

在本界面同样可以进行添加、查询、删除、更新等工作,出现的界面同车辆购车档案雷同的界面,它主要对车辆维修表(编号,车辆,维护日期,维修时公里数,维修单位,维护原因,花费金额,完毕日期,维护结果)进行修改。

图4-8更新界面

  4.4 车辆年检档案功能的运行

当点击车辆年检档案时,界面如下所示:

在本界面同样可以进行添加、查询、删除、更新等工作,出现的界面与车辆购车档案雷同的界面,它主要对车辆年检表(编号,喇叭,车型,灯光,制动刹车,侧滑,废气,车速,是否合格)进行修改。

图4-9车辆年检档案

4.5车辆评估模块功能的运行

当点击车辆评估档案时,会出现如下界面:

这时,需要用户输入汽车原值、使用年限、使用到第几年、折旧年限、维修次数、年检不合格次数、保养次数等基本信息。然后再选择使用强度、技术含量、维修保养水平、市场供求的信息。

点击“评估车辆”按钮在页面底部就会出现该车辆的得分以及评定等级了。

图4-10车辆评估界面

     当操作完毕,点击“退出”按钮即可关闭所有窗口,退出车辆档案管理系统。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/6540.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python爬虫实战

import requests import json yesinput(输入页数:) yesint(yes)headers {"accept": "application/json, text/plain, */*","accept-language": "zh-CN,zh;q0.9","content-type": "application/json",…

一对一WebRTC视频通话系列(三)——leave和peer-leave信令实现

本篇博客主要分为两部分,第一部分为leave信令的实现,即当有客户端离开房间后,服务端和其他在房间内的客户需知晓。第二部分为媒体协商和网络协商相关API。 本系列博客主要记录一对一WebRTC视频通话实现过程中的一些重点,代码全部进…

渗透之sql盲注(时间/boolean盲注)

sql盲注:sql盲注意思是我们并不能在web页面中看到具体的信息,我们只能通过输入的语句的真假来判断。从而拿到我们想要的信息。 我们通常使用ascii值来进行盲注。 目录 手动注入: 时间盲注: 布尔盲注: python脚本注…

【Java】基本程序设计结构(一)

前言:现在,假定已经成功安装了JDK,并且能够运行上篇示例程序。本篇将开始介绍Java程序中的基本设计结构,其中包括:一个简单的Java应用,注释,数据类型,变量与常量,运算符&…

【深度学习基础(3)】初识神经网络之深度学习hello world

文章目录 一. 训练Keras中的MNIST数据集二. 工作流程1. 构建神经网络2. 准备图像数据3. 训练模型4. 利用模型进行预测5. (新数据上)评估模型精度 本节将首先给出一个神经网络示例,引出如下概念。了解完本节后,可以对神经网络在代码上的实现有一个整体的了…

【架构系列】RabbitMQ应用场景及在实际项目中如何搭建可靠的RabbitMQ架构体系

作者:后端小肥肠 创作不易,未经允许禁止转载。 1. 前言 RabbitMQ,作为一款高性能、可靠的消息队列软件,已经成为许多企业和开发团队的首选之一。它的灵活性和可扩展性使得它适用于各种应用场景,从简单的任务队列到复杂的分布式系统…

算法设计与分析——期末1h

目录 第一章 算法的定义 算法的三要素 算法的基本性质 算法的时间复杂度数量级: 第二章 兔子繁殖问题(递推法) 猴子吃桃问题(递推法) 穿越沙漠问题(递推法(倒推)) 百钱百…

解决Maven本地仓库存在依赖包还需要远程下载的问题

背景 公司有自己maven私服,正在在私服可以使用的情况,打包是没问题的。但是这次是由于公司大楼整体因电路检修而停电,所有服务器关机,包括maven私服服务器。然后当天确有一个包需要打,这个时候发现死活打不了&#xf…

线性数据结构-手写链表-LinkList

为什么需要手写实现数据结构? 其实技术的本身就是基础的积累和搭建的过程,基础扎实 地基平稳 万丈高楼才会久战不衰,做技术能一通百,百通千就不怕有再难得技术了。 一:链表的分类 主要有单向,双向和循环链表…

飞书API(7):MySQL 入库通用版本

一、引入 在上一篇介绍了如何使用 pandas 处理飞书接口返回的数据,并将处理好的数据入库。最终的代码拓展性太差,本篇来探讨下如何使得上一篇的最终代码拓展性更好!为什么上一篇的代码拓展性太差呢?我总结了几点: 列…

福布斯AI 50榜单发布!新兴势力颠覆传统,叫板谷歌、微软

整理 | 王轶群 责编 | 唐小引 出品丨AI 科技大本营(ID:rgznai100) ChatGPT带来的生成式人工智能热浪,促使众多企业争先恐后地试图实现生成式人工智能的最新进展。一个新的帮助企业开发和部署人工智能驱动的应用程序的科技经济体系…

NFS共享存储服务

一、NFS概述 1、简介 NFS是一种基于TCP/IP传输的网络文件系统协议。 NFS 服务的实现依赖于 RPC(Remote Process Call,远端过程调用)机制,通过使用 NFS 协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源…

BUUCTF——web题目练习

[极客大挑战 2019]LoveSQL 输入1 123 输入1 123 输入2 123 这里可以看出注入位置为password的后面,开始手动注入 闭合方式为1 [极客大挑战 2019]Secret File 查看页面源代码,发现里面有一个跳转页面的连接,点击进去,查看这个…

Llama改进之——SwiGLU激活函数

引言 今天介绍LLAMA模型引入的关于激活函数的改进——SwiGLU1,该激活函数取得了不错的效果,得到了广泛地应用。 SwiGLU是GLU的一种变体,其中包含了GLU和Swish激活函数。 GLU GLU(Gated Linear Units,门控线性单元)2引入了两个不同的线性层…

83、动态规划-打家劫舍

思路: 首先使用递归方式求出最优解。从每个房屋开始,分别考虑偷与不偷两种情况,然后递归地对后续的房屋做同样的决策。这种方法确保了可以找到在不触发警报的情况下可能的最高金额。 代码如下: public static int rob(int[] nu…

【C++】深入剖析C++中的lambda表达式包装器bind

目录 一、lambda表达式 1、引入 2、lambda表达式 3、lambda表达式语法 ​4、lambda 的底层逻辑 二、包装器 1、包装器的表达式 ​ 2、实例化多份 3、可调用对象类型 4、实操例题 三、bind 1、bind 的表达式 2、调整参数的位置 3、绑定参数 一、lambda表达式 1、引…

wpf线程中更新UI的4种方式

在wpf中,更新UI上面的数据,那是必经之路,搞不好,就是死锁,或者没反应,很多时候,都是嵌套的非常深导致的。但是更新UI的方式,有很多的种,不同的方式,表示的意思…

hadoop学习---基于Hive的教育平台数据仓库分析案例(一)

案例背景: 大数据技术的应用可以从海量的用户行为数据中进行挖掘分析,根据分析结果优化平台的服务质量,最终满足用户的需求。教育大数据分析平台项目就是将大数据技术应用于教育培训领域,为企业经营提供数据支撑。 案例数据产生流…

现代循环神经网络(GRU、LSTM)(Pytorch 14)

一 简介 前一章中我们介绍了循环神经网络的基础知识,这种网络 可以更好地处理序列数据。我们在文本数据上实现 了基于循环神经网络的语言模型,但是对于当今各种各样的序列学习问题,这些技术可能并不够用。 例如,循环神经网络在…

使用OpenCV实现图像平移

使用OpenCV实现图像平移 程序流程效果代码 程序流程 读取图像并获取其高度、宽度和通道数。定义平移量tx和ty,并创建平移矩阵M。使用cv2.warpAffine函数对图像进行仿射变换(平移),得到平移后的图像。显示平移后的图像。等待用户按…