Web Dev Notes - 15 - 对于数据库连接的封装

自己写的数据库封装,在使用时只需要使用query和update操作即可



package api.com.servlet;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;


public class DBBean {

	private static Connection con = null;
	private static Statement stmt = null;
	private static ResultSet rs = null;
	private static boolean is_ready = false;
	private static boolean is_driver_loaded = false;

	private DBBean() {

	}

	private static void load() {
		try {
			Class.forName(StaticConfig.db_driver);
		} catch (Exception e) {
			System.err.println("DB Driver Load Error!");
			is_driver_loaded = false;
		}
		is_driver_loaded = true;
	}

	private static void getReady() {
		if (is_driver_loaded == false)
			load();
		if (is_driver_loaded == false) {
			is_ready = false;
			return;
		}

		try {
			con = DriverManager.getConnection(StaticConfig.db_url,
					StaticConfig.db_user, StaticConfig.db_password);
		} catch (Exception e) {
			System.err.println("DB Connection Fetch Error!");
			con = null;
			is_ready = false;
			return;
		}

		is_ready = true;

	}

	public static ResultSet query(String sql) {

		if (is_ready == false) {
			getReady();
		}

		if (is_ready == false)
			return null;
		
		try {
			stmt = con.createStatement();
		} catch (Exception e) {
			System.err.println("DB Statement Fetch Error!");
			stmt = null;
			return null;
		}
		
		try {
			rs = stmt.executeQuery(sql);
		} catch (Exception e) {
			System.err.println("DB Query Error!");
			rs = null;
		}
		return rs;
	}

	public static int update(String sql) {
		
		if (is_ready == false) {
			getReady();
		}

		if (is_ready == false)
			return -1;
		
		try {
			stmt = con.createStatement();
		} catch (Exception e) {
			System.err.println("DB Statement Fetch Error!");
			stmt = null;
			return -1;
		}
		int inflenced_row = -1;
		if (stmt == null) {
			System.err.println("DB Statement Fetch Error!");
			return -1;
		}
		try {
			inflenced_row = stmt.executeUpdate(sql);
		} catch (Exception e) {
			System.err.println("DB Update Error!");
			inflenced_row = -1;
		}
		return inflenced_row;
	}

	public void disconnect() {
		try {
			if (null == rs) {
				rs.close();
			}
			if (null == stmt) {
				stmt.close();
			}
			if (null == con) {
				con.close();
			}
		} catch (Exception e) {
			System.err.println("DB Resource Release Error!");
		}
	}

}

为了防止乱码可以指定读取的输入库的编码,修改如下


private static void getReady() {
		if (is_driver_loaded == false)
			load();
		if (is_driver_loaded == false) {
			is_ready = false;
			return;
		}

		try {
			Properties prop = new Properties();
			prop.put("user", StaticConfig.db_user);
			prop.put("password",StaticConfig.db_password);
			prop.put("characterEncoding","GBK"); 
			con = DriverManager.getConnection(StaticConfig.db_url,
					prop);
		} catch (Exception e) {
			System.err.println("DB Connection Fetch Error!");
			con = null;
			is_ready = false;
			return;
		}

		is_ready = true;

	}






### 在 Dev-C++ 环境下通过 Redpanda 实现与 MySQL 数据库连接 要在 Dev-C++ 环境中使用 Redpanda 连接 MySQL 数据库,需要完成以下几个关键步骤:配置开发环境、安装必要的库文件以及编写代码实现数据库连接。以下是详细的说明: #### 1. 配置开发环境 Red Panda Dev-C++ 是一个基于经典 Orwell Dev-C++ 的改进版本,支持多种编译器和工具链[^1]。为了连接 MySQL 数据库,需要确保以下条件满足: - 安装了 TDM-GCC 或 MingW64 编译器,并正确配置到 Dev-C++ 中[^2]。 - 下载并安装 MySQL Connector/C 库,这是用于 C/C++ 程序连接 MySQL 数据库的官方库。 #### 2. 安装 MySQL Connector/C MySQL Connector/C 提供了 C API,允许开发者通过标准接口访问 MySQL 数据库。下载地址为 [MySQL 官方网站](https://dev.mysql.com/downloads/connector/c/)。选择适合操作系统的版本并安装。 安装完成后,将以下路径添加到 Dev-C++ 的编译器设置中: - **包含路径**:指向 MySQL Connector/C 的 `include` 文件夹。 - **库路径**:指向 MySQL Connector/C 的 `lib` 文件夹。 - **链接库**:在编译选项中添加 `-lmysqlclient`,以链接 MySQL 客户端库[^3]。 #### 3. 编写代码实现连接 以下是一个简单的示例代码,展示如何使用 MySQL Connector/C 在 Dev-C++ 中连接 MySQL 数据库: ```cpp #include <mysql/mysql.h> #include <iostream> using namespace std; int main() { MYSQL* conn; MYSQL_RES* res; MYSQL_ROW row; // 初始化 MySQL 连接 conn = mysql_init(NULL); if (!mysql_real_connect(conn, "localhost", "root", "password", "testdb", 0, NULL, 0)) { cout << "Error connecting to database: " << mysql_error(conn) << endl; return 1; } cout << "Connected to database successfully!" << endl; // 执行查询 if (mysql_query(conn, "SELECT * FROM users")) { cout << "Query error: " << mysql_error(conn) << endl; return 1; } res = mysql_use_result(conn); // 输出查询结果 while ((row = mysql_fetch_row(res)) != NULL) { cout << "ID: " << row[0] << ", Name: " << row[1] << endl; } // 清理资源 mysql_free_result(res); mysql_close(conn); return 0; } ``` #### 4. 编译与运行 确保在 Dev-C++ 的项目设置中正确配置了 MySQL Connector/C 的路径和链接库。然后编译并运行上述代码,如果一切正常,程序将成功连接到 MySQL 数据库并输出查询结果。 --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值