用java和MySQL实现访客管理系统的黑名单增删改查功能的代码,并且这个代码里包含了异常处理。

时间: 2023-06-24 20:05:51 浏览: 56
以下是一个简单的访客管理系统的黑名单增删改查功能的Java代码,其中包括异常处理: ```java import java.sql.*; public class Blacklist { private static final String DRIVER = "com.mysql.jdbc.Driver"; private static final String URL = "jdbc:mysql://localhost:3306/guestbook"; private static final String USER = "root"; private static final String PASSWORD = "password"; private Connection connection; private PreparedStatement preparedStatement; private ResultSet resultSet; public void addGuestToBlacklist(int guestId) { try { Class.forName(DRIVER); connection = DriverManager.getConnection(URL, USER, PASSWORD); String sql = "INSERT INTO blacklist(guest_id) VALUES(?)"; preparedStatement = connection.prepareStatement(sql); preparedStatement.setInt(1, guestId); preparedStatement.executeUpdate(); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } finally { closeConnection(); } } public void removeGuestFromBlacklist(int guestId) { try { Class.forName(DRIVER); connection = DriverManager.getConnection(URL, USER, PASSWORD); String sql = "DELETE FROM blacklist WHERE guest_id=?"; preparedStatement = connection.prepareStatement(sql); preparedStatement.setInt(1, guestId); preparedStatement.executeUpdate(); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } finally { closeConnection(); } } public void updateGuestInBlacklist(int guestId, int newGuestId) { try { Class.forName(DRIVER); connection = DriverManager.getConnection(URL, USER, PASSWORD); String sql = "UPDATE blacklist SET guest_id=? WHERE guest_id=?"; preparedStatement = connection.prepareStatement(sql); preparedStatement.setInt(1, newGuestId); preparedStatement.setInt(2, guestId); preparedStatement.executeUpdate(); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } finally { closeConnection(); } } public boolean isGuestInBlacklist(int guestId) { boolean isInBlacklist = false; try { Class.forName(DRIVER); connection = DriverManager.getConnection(URL, USER, PASSWORD); String sql = "SELECT * FROM blacklist WHERE guest_id=?"; preparedStatement = connection.prepareStatement(sql); preparedStatement.setInt(1, guestId); resultSet = preparedStatement.executeQuery(); if (resultSet.next()) { isInBlacklist = true; } } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } finally { closeConnection(); } return isInBlacklist; } private void closeConnection() { try { if (resultSet != null) { resultSet.close(); } if (preparedStatement != null) { preparedStatement.close(); } if (connection != null) { connection.close(); } } catch (SQLException e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们使用了Java的JDBC API来连接MySQL数据库,并使用预处理语句来执行增删改查操作。在每个方法中,我们都使用了try-catch块来捕获可能发生的异常,并在最后使用finally块来关闭连接、语句和结果集。这有助于保持代码的可读性和可维护性。 值得注意的是,上面的代码只是一个示例,可能需要根据具体的需求进行修改和优化。例如,我们可能需要添加更多的方法来处理不同的业务逻辑,或使用连接池来提高性能。

相关推荐

最新推荐

recommend-type

Python+Django+MySQL实现基于Web版的增删改查的示例代码

主要介绍了Python+Django+MySQL实现基于Web版的增删改查的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

JavaWeb JDBC + MySql 通讯录实现简单的增删改查功能案例详解

主要介绍了JavaWeb JDBC + MySql 通讯录实现简单的增删改查功能,结合具体案例形式详细分析了JavaWeb JDBC + MySql数据库连接、增删改查等相关操作技巧与注意事项,需要的朋友可以参考下
recommend-type

SpringBoot+MySQL+Jpa实现对数据库的增删改查和分页详解

主要介绍了SpringBoot+MySQL+Jpa实现对数据库的增删改查和分页详解,需要的朋友可以参考下
recommend-type

Android连接MySQL数据库并进行增删改查操作示例讲解

主要介绍了Android 连接MySQL数据库并进行增删改查操作示例讲解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

基于sqlalchemy对mysql实现增删改查操作

主要介绍了基于sqlalchemy对mysql实现增删改查操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节 线性代数的核心问题是求解方程组。这些方程都是线性的,即未知数仅与数相乘——我们绝不会 遇见 x 乘以 y。我们的第一个线性方程组较小。接下来你来看看它引申出多远: 两个方程 两个未知数 x − 2y = 1 3x + 2y = 11 (1) 我们一次从一个行开始。第一个方程 x − 2y = 1 得出了 xy 平面的一条直线。由于点 x = 1, y = 0 解 出该方程,因此它在这条直线上。因为 3 − 2 = 1,所以点 x = 3, y = 1 也在这条直线上。若我们选择 x = 101,那我们求出 y = 50。 这条特定直线的斜率是 12,是因为当 x 变化 2 时 y 增加 1。斜率在微积分中很重要,然而这是线 性代数! 图 2.1 将展示第一条直线 x − 2y = 1。此“行图”中的第二条直线来自第二个方程 3x + 2y = 11。你 不能错过两条线的交点 x = 3, y = 1。点 (3, 1) 位于两条线上并且解出两个方程。
recommend-type

管理建模和仿真的文件

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

识别MATLAB微分方程求解中的混沌行为:分析非线性方程混沌行为的实用技巧

![matlab求解微分方程](https://img-blog.csdnimg.cn/2021062810300367.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MTQ3OTY3OA==,size_16,color_FFFFFF,t_70) # 1. MATLAB微分方程求解概述 微分方程是描述物理、工程和金融等领域中动态系统的数学模型。MATLAB提供了强大的工具来求解微分方程,包括内置求解器和自定义函数
recommend-type

physon如何做ERP系统

作为一个AI语言模型,我可以给您提供一些基本的建议和思路: 1.明确需求和目标:在开始开发ERP系统之前,需要明确您的业务需求和目标,了解您的业务流程、流程数据、员工角色和权限、财务管理等方面的要求,这样才能更好的设计和开发ERP系统。 2.选择技术框架和开发工具:选择合适的技术框架和开发工具是ERP系统开发的关键。选择一种流行的技术框架和工具可以提高开发效率和质量。 3.设计数据库:ERP系统需要一个功能强大的数据库来存储数据。设计数据库需要考虑数据的完整性、安全性和可扩展性。 4.设计系统架构:系统架构是ERP系统的骨架,需要考虑系统的可扩展性、可维护性和性能。 5.开发和测试:
recommend-type

zigbee-cluster-library-specification

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