实践三层

2024-08-26 11:58
文章标签 实践 三层

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

短短的80分钟的视频,人家就用一个登陆的例子给我们讲述了三层的概念以及作用,若是还有什么疑惑的,可以看我的前一篇博客。



问题一:


相信大家都看到了那是关于数据库连接的问题,原来实战机房收费系统的时候我只是看着人家如何写的,自己就跟着照抄,完全不知道他到底是什么样的原理。不过今天算是慢慢的看懂了。





相信看到这个真的很熟悉,但是知道今天我才算真正的认识他,其实这一块的连接就跟

下面这幅图是密切联系的。





问题2:

但是为什么我们用sa作为登录名,也能连上呢????

 

在网上一查才知道原来sasuper administrator的简写,翻译过来就是超级管理员账户的意思,他拥有所有的权限。

 

但是我看到这里又有疑惑了,因为我在连接数据库时候就有windows身份验证还有SQLServer身份验证,那在代码上有什么差别吗?

 

从下面的图可以看出我们只要将sa那一串改为 Integrated Security=true就可以了,但是新的问题又出来了虽然在网

上查到说这个可以实现windows验证登录,但是这串代码是什么意思呢?原来他是“集成验证”,我们可以看出他是不

需要在连接字符串中载入用户名和密码的,这对于数据库的本身提高了安全性。




 


 这是实现之后的效果图


问题3:

 

在第一次的验收过程中,师傅给我指出说这个登录输入错误都没有来个提示,这属于界面不友好,因此我又给自己的三层加了点东西将它实现了。




其实这个倒是挺简单的,主要就是要让B层将数据库没有此人存在的信息返回

U层就好了。首先看B层的错误异常抛出



接下来就是让U层捕捉到这个错误,我们可以用Try Catch语句捕捉异常。



 遗留问题

本以为做到这里就三层的例子就差不多了,但是又有一个新的问题出来了。让我们来看看

下面的图:



看到这里相信大家都明白这是这是D层对数据库的操作出了问题。理清思路之后

就不难发现,应该来一个判断,如果是新用户就直接插入,如果是老用户那就直接更新。

有了思路,问题就会有解决掉的方法。但是到目前为止还没有解决好,回头弄好了,我再把它贴上。




收获:


行动上,自己比原来多了一份积极主动去搜索尝试,而不是一味的看人家的。此外就是对于自己的学习出现的问题有个忠实的记录,他督促着我继续坚持克服一个个问题。


思想上,遇见问题就迎难而上,貌似多了一份耐心。


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



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

相关文章

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

SpringBoot整合(ES)ElasticSearch7.8实践

《SpringBoot整合(ES)ElasticSearch7.8实践》本文详细介绍了SpringBoot整合ElasticSearch7.8的教程,涵盖依赖添加、客户端初始化、索引创建与获取、批量插... 目录SpringBoot整合ElasticSearch7.8添加依赖初始化创建SpringBoot项