JDBC数据库编程操作类(适用于MySQL)_MySQL
package com.msit.Uitll;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
/**
* 数据库帮助类 连接MySQL数据库
*
* @author ruanj_000
*
*/
public class SQLHelp {
private static String dirverName = "com.mysql.jdbc.Driver";
private static String url = "jdbc:mysql://127.0.0.1:3306/misidb";
private static String user = "root";
private static String password = "root";
private static Connection connection = null;
// 编写静态代码块(比构造函数加载更快),用来加载驱动类
static {
try {
Class.forName(dirverName);
// 创建连接对象
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
/**
* 获得连接对象
*
* @return
*/
public static Connection getConnection() {
try {
connection = DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
e.printStackTrace();
}
return connection;
}
/**
* 用来执行 添加、删除、修改的sql语句
*
* @param sql
* @return 受影响的行数
*/
public static int ExecuteNonQuery(String sql) {
int num = 0;
Connection conn = getConnection();
Statement sta = null;
try {
sta = conn.createStatement();
} catch (SQLException e) {
e.printStackTrace();
}
try {
num = sta.executeUpdate(sql);
} catch (SQLException e) {
e.printStackTrace();
} finally {
Close(null, sta, conn);
}
return num;
}
/**
* 执行查询语句方法
* @param sql 数据查询SQL脚本语言
* @return 返回结果集
*/
public static ResultSet ExecuteQuery(String sql){
ResultSet rs=null;
Connection con=getConnection();
Statement sta=null;
try {
sta=con.createStatement();
} catch (SQLException e) {
e.printStackTrace();
}
try {
rs=sta.executeQuery(sql);
} catch (SQLException e) {
e.printStackTrace();
}
finally{
//Close(rs, sta, con);
}
return rs;
}
/**
* 关闭资源的方法
*
* @param rs
* 结果集
* @param sta
* 执行对象
* @param conn
* 连接对象
*/
private static void Close(ResultSet rs, Statement sta, Connection conn) {
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
System.out.println("数据结果集关闭异常..!");
e.printStackTrace();
}
}
if (sta != null) {
try {
sta.close();
} catch (SQLException e) {
System.out.println("执行对象关闭异常、、!");
e.printStackTrace();
}
}
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
System.out.println("数据连接关闭异常、、!");
e.printStackTrace();
}
}
rs=null; sta=null; conn=null;
}
/**
* 执行预编译sql语句的方法
* @param sql
* @param prgm
* @return
*/
public static int pstm(String sql,String prgm[]){
int num=0;
PreparedStatement pstm=null;
try {
pstm =getConnection().prepareStatement(sql);
for (int i =1; i pstm.setString(i, prgm[i-1]);
}
num=pstm.executeUpdate();
pstm.close();
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
return num;
}
}

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

記事では、外部キーを使用してデータベース内の関係を表すことで、ベストプラクティス、データの完全性、および避けるべき一般的な落とし穴に焦点を当てています。

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

記事では、準備されたステートメント、入力検証、および強力なパスワードポリシーを使用して、SQLインジェクションおよびブルートフォース攻撃に対するMySQLの保護について説明します。(159文字)
