三层 之 充值

2024-08-26 18:38
文章标签 三层 充值

本文主要是介绍三层 之 充值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在三层的地方也炖了不少时间了,再炖就烂了,找好了时机,趁大家不注意,总结一下:

从上面的这幅导图中,就可以看到,由U层(表示层) 引用 B层(逻辑判断层)和 Entity(实体“层”),由 B层 引用 D层和实体层,由D层引用实体层,也就是


只能单向引用,不可反复

下面,还是由实例来说明耕层之间的关系:

充值之界面:

                     

充值之U层:

<pre name="code" class="vb">Public Class Form1Private Sub btnOK_Click(sender As Object, e As EventArgs) Handles btnOK.ClickTryDim eUser2 As New EntityRecharge.RechargeInfoDim eUser3 As EntityRecharge.RechargeInfoeUser2.IDcard = Trim(txtIDcard.Text)eUser2.AddCash = Trim(txtAddCash.Text)Dim mgr As New RechargeBLL.RechargeManagereUser3 = mgr.RechargeSc(eUser2)Catch ex As ExceptionMessageBox.Show(ex.Message.ToString())End TryEnd SubPrivate Sub btnCancel_Click(sender As Object, e As EventArgs) Handles btnCancel.ClickMe.Close()End Sub
End Class


 

充值之B层:

<pre name="code" class="vb">Public Class RechargeManagerPublic Function RechargeSc(ByVal User As RechargeInfo) As EntityRecharge.RechargeInfoDim rDAO As New RechargeDAL.RechargeDAODim eUser1 As BooleaneUser1 = rDAO.SelectUser(User)        '寻找卡号If eUser1 = False Then                '返回FALSE 代表  查找失败,也就是卡号未注册Throw New Exception("卡号不存在,充值失败")ElseeUser1 = rDAO.UpdateCash(User)     '查找成功,执行充值操作If eUser1 = True ThenMsgBox("充值成功")ElseThrow New Exception("充值失败")End IfEnd IfReturn UserEnd Function
End Class


 

充值之D层:

Public Class RechargeDAOPublic conn As New SqlConnection("server=.;database=Login;user id=sa;password=li")Public Function SelectUser(ByVal User As RechargeInfo) As BooleanDim eUser As New EntityRecharge.RechargeInfoDim reader As SqlDataReader'Dim intNum1 As IntegerDim sql As String = "SELECT * FROM Recharge WHERE IDcard=@IDcard"Dim cmd As New SqlCommand(sql, conn)cmd.CommandText = sql                     '获取SQL语句的具体内容cmd.CommandType = CommandType.Text         '获取上述SQL语句的具体类型,在此为Selectcmd.Parameters.Add(New SqlParameter("@IDcard", User.IDcard)) '若用成eUser.UserName则会出现参数未传递的错误提示'MsgBox(conn.State)conn.Open()reader = cmd.ExecuteReaderWhile reader.ReadeUser.IDcard = reader.GetInt32(0)End Whileconn.Close()If eUser.IDcard = Nothing ThenReturn FalseElseReturn TrueEnd IfEnd FunctionPublic Function UpdateCash(ByVal User As RechargeInfo) As BooleanDim intNum As IntegerDim eUser As New EntityRecharge.RechargeInfoDim sql As String = "INSERT INTO Recharge (IDcard,AddCash,Cash) VALUES (@IDcard,@AddCash,@Cash)"Dim cmd As New SqlCommand(sql, conn)cmd.CommandText = sqlcmd.CommandType = CommandType.Textcmd.Parameters.Add(New SqlParameter("@IDcard", User.IDcard))cmd.Parameters.Add(New SqlParameter("@AddCash", User.AddCash))cmd.Parameters.Add(New SqlParameter("@Cash", 11 + User.AddCash))conn.Open()                   '打开连接intNum = cmd.ExecuteNonQuery()     '返回 受影响行数conn.Close()        '关闭连接If intNum = 1 ThenReturn TrueElseReturn False       '返回 处理结果End IfEnd FunctionEnd Class




 
Entity层: 

<pre name="code" class="vb">Public Class RechargeInfoDim _idcard As IntegerDim _cash As IntegerDim _addcash As IntegerPublic Property IDcard As Integer          '设置IDcard属性GetReturn _idcardEnd GetSet(value As Integer)_idcard = valueEnd SetEnd PropertyPublic Property AddCash As Integer          '设置AddCash属性GetReturn _addcashEnd GetSet(value As Integer)_addcash = valueEnd SetEnd PropertyPublic Property Cash As Integer             '设置Cash属性GetReturn _cashEnd GetSet(value As Integer)_cash = valueEnd SetEnd Property
End Class


 

其实吧,这篇和登录那片是差不多的,不一样的地方是,这次在查询的时候,我都用的是Boolean返回值,也就是说,我不需要你查询的数据,我只需要你查询的结果代表的意义,有没有这条数据,有就直接告诉我有,没有就直接告诉我没有,不需要再去比对

这篇关于三层 之 充值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109365

相关文章

对接话费充值API接口的开发步骤以及各种优势

对接话费充值API接口通常涉及以下步骤: 1.选择API提供商: 研究并选择一个可靠的话费充值API提供商。考虑因素包括覆盖范围、费率、交易限额、客户支持和用户评价。 2.注册和获取API密钥: 在选定的API提供商平台上注册账户,并获取API密钥或访问令牌,这是调用API时进行身份验证的必要信息。 3.阅读API文档: 仔细阅读API文档,了解如何构建请求、需要哪些参数、API的

设计之道:ORM、DAO、Service与三层架构的规范探索

引言: 实际开发中,遵守一定的开发规范,不仅可以提高开发效率,还可以提高项目的后续维护性以及项目的扩展性;了解一下本博客的项目设计规范,对项目开发很有意义 一、ORM思想 ORM(Object-Relational-Mapping)在对象模型和关系型模型之间做一个映射(转换)。 目的是为了解决面向对象编程语言的发展和关系型数据库的发展不匹配的问题 可以理解为: 将Java中的数据结

话费充值API接口的关键步骤与考虑因素

话费充值API接口通常是由电信运营商或第三方支付平台提供的一种服务,允许开发者将话费充值功能集成到自己的应用程序或网站中。通过这种接口,用户可以方便地为他们的手机账户充值。以下是实现话费充值API接口可能涉及的一些关键步骤和考虑因素: 关键步骤: 选择服务提供商:选择一个可靠的话费充值API服务提供商,这可能是电信运营商本身或是一个信誉良好的第三方服务提供商。注册和认证:在选定的服务提供商

Mysql+IIS+三层架构创建网站遇到的过程总结

一.三层架构的创建 1)添加新项,添加类库:实体,业务逻辑,数据库访问,并将新创建的类库添加到网站的引用。 2)为实体类库设置属性,并设置set和get方法。 3)为数据库访问类库新建Connection和DataService类,其中Connection类中包含了数据库连接字符串成员变量以及设置方法,DataService类是数据库操作类,包含了各种数据库的操作,在DataService类

《JavaEE进阶》----10.<SpringMVC应用分层:【三层架构】>

本篇博客我们主要讲解 1.应用的分层:三层架构 2.Spring MVC和三层架构的区别和联系 3.软件设计原则:高内聚低耦合 4.应用分层的好处 5.通过应用分层后的代码示例 一、三层架构简介 阿里开发手册中,关于工程结构部分,定义了常见工程的应用分层结构: 上图的表示层,也叫做表现层。 解释概念  1.表现层(Controller):展示数据结果和接收用户指令的,是最靠近用户

C#三层架构基础

在C#(或更广泛地,在.NET环境)中,三层基础架构是一种常见的软件设计模式,旨在将应用程序分解成三个主要层次:表示层(UI层)、业务逻辑层(BLL层)和数据访问层(DAL层)。这种分层设计有助于提升软件的可维护性、可扩展性和可重用性。下面是这三层的一个基本概述: 1. 表示层(Presentation Layer 或 UI Layer) 作用:这一层主要负责与用户进行交互,通常通过**图形用

三层接口和二层接口 - Vlan之间通信 三层交换机原理介绍

Vlanif逻辑接口来实现 在三层交换机上配置VLANIF接口来实现VLAN间路由 什么是三层交换机 二层交换机和路由器在功能上的集成构成了三层交换机,三层交换机在功能上实现了VLAN的划分、VLAN内部的二层交换和VLAN间路由的功能 三层交换机的原理 就是二层交换机和路由器的结合体,但是会比这种方式更加高效 三层交换机里面有路由引擎和交换引擎当三层交换机识别到主机发送的DMA

路由表和三层转发(ping过程)详解

1、路由表概述        路由表的表项根据设备不同,可能是不同的。但是目的IP地址、网络掩码、网关、接口、标志这几项是必须存在的。例如跃点数metric,引用次数ref等在不同设备上可能不同。 1.1、表项理解的问题 诸如IP地址、网络掩码等很好理解,那么网关和接口表项使用来做什么的呢? (1)      网关:是下一站路由器的IP地址 (2)      接口:是将数据报从哪个接口发出

基于vlan的二层、三层转发原理

开门见山,含有vlan的二层转发原理文字描述和流程图如下: 基于Vlan的二层转发流程主要包括:确定和查找Vlan、查找和学习源MAC、查找目的MAC并转发数据帧。 1) 确定和查找Vlan:交换机端口接收到一个数据帧时,首先通过TPID值判断该帧是否带标签[1]。 若是tagged帧,且Vid≠0,则在端口所属的Vlan表中查找该帧标签中的Vid是否存在,若存在,则进入下一步,否则丢弃该帧(

《探讨——关于三层架构前在前端项目的应用》第一版

《探讨——关于三层架构在前端项目的应用》第一版 前言 本文的阅读需要具备一定的技术知识基础,特别是关于 MVVM 框架(如 Vue)的理解。若您对这些知识尚不熟悉,建议您先行进行相关知识的学习与探索。 本文名词说明: 接口:指一个模块对外暴露的方法,用于与自身通讯。例如类的方法。 HttpApi: 特指前后端交互的 HTTP 请求。 背景 在开发比较复杂的 Vue 项目的时候,我们