Java实训日志03

news2025/1/24 22:31:15

文章目录

  • 八、项目开发实现步骤
    • (五)创建数据库连接管理类
      • 1、创建数据库实用工具包
      • 2、创建数据库连接管理类
        • (1)定义数据库连接属性常量
        • (2)创建私有化构造方法
        • (3)编写获取数据库连接静态方法
        • (4)编写关闭数据库连接静态方法
        • (5)在主方法里测试两个静态方法
      • 3、运行数据库连接管理类
      • 4、程序运行可能出现的异常
        • (1)驱动程序不存在或有误
        • (2)数据库服务器端口号有误
        • (3)未知数据库错误
        • (4)数据库用户名错误
        • (5)数据库密码错误

八、项目开发实现步骤

(五)创建数据库连接管理类

  • DAO层对表进行增删改查等操作都必须先获取数据库连接,操作完之后应当及时关闭数据库连接。为此,我们单独创建一个数据库连接管理类,提供两个静态方法,一个是获取数据库连接方法,一个是关闭数据库连接方法。

1、创建数据库实用工具包

  • 创建net.huawei.student.dbutil
    在这里插入图片描述

2、创建数据库连接管理类

  • net.huawei.student.dbutil包里创建ConnectionManager
    在这里插入图片描述

(1)定义数据库连接属性常量

  • 定义四个静态常量
package net.huawei.student.dbutil;

/**
 * 功能:数据库连接管理类
 * 作者:华卫
 * 日期:2023年06月14日
 */
public class ConnectionManager {
    private static final String DRIVER = "com.mysql.jdbc.Driver"; // 数据库驱动程序
    private static final String URL = "jdbc:mysql://localhost:3306/student?useSSL=false&useUnicode=true&characterEncoding=utf8"; // 数据源
    private static final String USER = "root"; // 数据库用户
    private static final String PASSWORD = "903213"; // 数据库密码  
}

(2)创建私有化构造方法

  • 创建私有化构造方法,拒绝实例化
// 私有化构造方法,拒绝实例化                             
private ConnectionManager() {                
}                                            

(3)编写获取数据库连接静态方法

  • 编写getConnection()静态方法(直接通过类名可以访问的方法)
// 获取连接静态方法                                                         
public static Connection getConnection() {                          
    // 定义数据库连接                                                      
    Connection conn = null;                                         
                                                                    
    try {                                                           
        // 加载数据库驱动程序                                                
        Class.forName(DRIVER);                                      
        // 获取数据库连接                                                  
        conn = DriverManager.getConnection(URL, USER, PASSWORD);    
    } catch (ClassNotFoundException e) {                            
        System.err.println(e.getMessage());                         
    } catch (SQLException e) {                                      
        System.err.println(e.getMessage());                         
    }                                                               
                                                                    
    // 返回数据库连接                                                      
    return conn;                                                    
}                                                                   

(4)编写关闭数据库连接静态方法

  • 编写closeConnection(Connection conn)静态方法
// 关闭连接静态方法                                        
public static void closeConnection(Connection conn) {     
    // 判断连接是否为空                                    
    if (conn != null) {                            
        try {                                      
            // 关闭数据库连接                             
            conn.close();   
            // 提示用户                             
			System.out.println("提示:数据库连接已关闭~");                         
        } catch (SQLException e) {                 
            System.err.println(e.getMessage());    
        }                                          
    }                                              
}                                                  

(5)在主方法里测试两个静态方法

  • 测试两个静态方法
// 主方法,测试两个静态方法                                          
public static void main(String[] args) {                 
    // 获取数据库连接                                           
    Connection conn = getConnection();                   
    // 判断连接是否为空                                          
    if (conn != null) {                                  
        System.out.println("恭喜,数据库连接成功~");               
        // TODO 待做                                       
        // 关闭数据库连接                                       
        closeConnection(conn);                           
    } else {                                             
        System.out.println("遗憾,数据库连接失败~");               
    }                                                    
}                                                        

3、运行数据库连接管理类

  • 运行程序,查看结果
    在这里插入图片描述

4、程序运行可能出现的异常

(1)驱动程序不存在或有误

  • 故意将驱动程序名称写错
    在这里插入图片描述

(2)数据库服务器端口号有误

  • 故意将数据库服务器端口号写错
    在这里插入图片描述

(3)未知数据库错误

  • 故意将数据库名写错
    在这里插入图片描述

(4)数据库用户名错误

  • 故意将数据库用户名写错
    在这里插入图片描述

(5)数据库密码错误

  • 故意将数据库密码写错
    在这里插入图片描述

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

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

相关文章

关于C++数组名和指针的一些思考

在学习指针数组与数组指针一节时&#xff0c;了解到数组名其实是指向数组收个元素的指针。如下面代码所示 int main() {int a[5] {1, 2, 3, 4, 5};cout << "*a:" << *a << endl;cout << "*(a 1):" << *(a 1) << e…

注解开发bean

注解开发定义bean 使用component定义bean Component("bookDao") public class BookDaoImpl implements BookDao{} 核心配置文件中通过组件扫描加载bean <context:component-scan base-package"com.tsj"/> Spring提供Component注解的三个衍生注解…

科研人必看 | 学术期刊论文作者署名新规

【SciencePub学术干货】在期刊上发表学术论文&#xff0c;是研究人员发布和传播学术研究成果的重要方式之一。学术期刊论文文献各项著录内容中&#xff0c;作者署名是最主要的组成部分之一。 随着经济的发展和社会的进步&#xff0c;人们面临的科学问题和社会问题日趋复杂&…

KaiwuDB 受邀亮相 IOTE 2023 第十九届国际物联网展

5月17日&#xff0c;IOTE 2023 第十九届国际物联网展在上海拉开序幕&#xff0c;全球超过 350 家参展企业到场展示先进的物联网技术和产品&#xff0c;行业专家、领军企业代表等人物齐聚一堂&#xff0c;共话 IoT 未来趋势。KaiwuDB 受邀亮相参展并就《工业物联网产业数字化转型…

基于SpringBoot+vue的网上图书商城系统设计和实现

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架下…

通用方案px2rem 处理 内联样式、element-ui表头折行、label折行、表单项换行异常

通用方案-处理element-ui 表单项label折行、换行异常&#xff0c;表头折行问题 背景简介&#xff1a;在实际的生产环境中&#xff0c;客户用到的屏幕大大小小分辨率各有异同&#xff0c;但是为了布局的统一和美观&#xff0c;我们采用了postcss-px2rem插件对element-ui进行响应…

仓库拣货标签——仓库16代

6432 全彩 LED 点阵显示屏 ​ 一、产品特性 采用2048 RGB LED全彩显示&#xff0c;亮度可调 无线通信 它可以显示文本、图片或动画 支持24V外置电源 支持系统对接&#xff0c;模板可DIY 二、PTL系统电子标签概述 电子标签拣选系统是利用先进的电子技术和通信技术开发的物…

选择合适的采购系统,实现企业数字化转型

随着数字化技术的飞速发展&#xff0c;企业数字化转型已经成为了当今市场的必然趋势。而采购系统作为企业数字化转型的重要组成部分&#xff0c;选择合适的采购系统对于企业来说至关重要。本文将围绕选择合适的采购系统&#xff0c;实现企业数字化转型展开讨论。 一、企业数字化…

数字门户的创新引擎:小程序容器

小程序容器技术的发展为数字门户带来了许多机会和优势。通过引入第三方生态&#xff0c;数字门户可以快速丰富自身的功能和服务&#xff0c;提高用户留存率&#xff0c;并打造一个开放的生态系统。这种创新的技术手段让数字门户能够更灵活地满足用户多样化的需求&#xff0c;提…

强化学习复现笔记(2)策略迭代

摘要&#xff1a; 上一节的压缩映射在实际迭代时可以分成两种方法&#xff0c;分别称作值迭代和策略迭代。本文用走迷宫的例子&#xff08;将1维迷宫扩展到2维&#xff09;讲这两种迭代。对应第一节参考链接[2]的前4章。 拆分压缩映射 上一节的压缩映射 v f ( v ) vf(v) vf(…

打造科学新高地|2023开放原子全球开源峰会科学智能分论坛圆满举行

6 月 11 日&#xff0c;以“AI 框架助力科学智能&#xff0c;打造科学新高地”为主题的 2023 开放原子全球开源峰会科学智能分论坛在北京圆满举行。北京航空航天大学计算机学院党委书记、教授李建欣参加并致辞&#xff1b;华为昇思 MindSpore 架构师倪宁曦、研究员徐旭升&#…

const用于C++引用(注意事项)

const用于C引用 存在的问题解决方法原理 存在的问题 左值是可以被引用的数据对象&#xff0c;可以通过地址访问它们&#xff0c;例如&#xff1a;变量、数组元素、结构体成员、引用和解引用的指针。 非左值包括字面常量&#xff08;用双引号包含的字符串除外&#xff09;和包含…

公司普通启动VR/AR软件开发虚拟场景游戏

随着元宇宙技术的不断革新&#xff0c;VR作为一种新兴技术&#xff0c;正在迅速普及。VR软件开发技术将用户沉浸到虚拟世界中&#xff0c;让人们可以身临其境地体验一些事物&#xff0c;如元宇宙游戏、商圈、展会、旅游等。而VR虚拟场景的开发&#xff0c;则是实现这一目标的重…

WRF进阶:使用ERA5-land数据驱动WRF/WRF撰写Vtable文件添加气象场

想用WRF模拟地气交换过程&#xff0c;对于WRF的地表数据&#xff0c;尤其是土壤温湿度数据要求便会很大&#xff0c;传统使用ERA5-singledata数据精度也许不足以满足需求&#xff0c;为此&#xff0c;本文尝试使用ERA5-land数据替换驱动WRF。 数据下载 ERA5-land的数据下载与…

2023 届 Java 岗高频面试题盘点,老司机也未必全会

2023&#xff0c;可谓是招聘面试最难季。不少大厂&#xff0c;如腾讯、字节的招聘名额明显减少&#xff0c;面试门槛却一再拔高&#xff0c;如果不用心准备&#xff0c;很可能就被面试官怼得哑口无言。今天不谈其它&#xff0c;就说说我作为面试官面试的那些事儿。 从某电商项…

【笔试强训选择题】Day25.习题(错题)解析

作者简介&#xff1a;大家好&#xff0c;我是未央&#xff1b; 博客首页&#xff1a;未央.303 系列专栏&#xff1a;笔试强训选择题 每日一句&#xff1a;人的一生&#xff0c;可以有所作为的时机只有一次&#xff0c;那就是现在&#xff01;&#xff01;&#xff01;&#xff…

不愧是阿里大牛珍藏的“redis深度笔记(全彩版)”这细节讲解,神了

前言 说到 Redis 相信对于我们这些程序员来说太熟悉了&#xff0c;Redis 凭借着自己超高的超高的性能、完美的文档、简洁易懂的源码和丰富的客户端库支持&#xff0c;很快就在国内的互联网市场占据了一席之地&#xff0c;得到了广大用户的一致好评&#xff0c;随着国内外使用 …

反射---getattr,hasattr,setattr,delattr加插播enumerate

什么是反射&#xff1f; 用字符串数据类型的变量名来访问这个变量的值 反射的方法&#xff1a;getattr&#xff0c;hasattr&#xff0c;setattr&#xff0c;delattr 类&#xff1a;(通过类名反射类名空间里面的内容的) 类&#xff1a;静态属性&#xff0c;类方法&#xff0c;静…

Vue中如何进行代码高亮与语法着色?

Vue中如何进行代码高亮与语法着色&#xff1f; 在Vue的开发过程中&#xff0c;我们经常需要展示代码片段或者进行代码高亮与语法着色。Vue提供了多种方式来实现代码高亮与语法着色&#xff0c;本文将为你详细介绍这些方法。 1. 使用prism.js进行代码高亮与语法着色 prism.js是…

mybatis的一级缓存和二级缓存

目录 1、简介 2、Mybatis缓存 3、一级缓存 3.1、初体验测试 3.2、一级缓存失效的四种情况 4、二级缓存 4.1、使用步骤 4.2、结论 5、缓存原理 1、简介 什么是缓存 [ Cache ]&#xff1f; 存在内存中的临时数据。将用户经常查询的数据放在缓存&#xff08;内存&…