Rumah pangkalan data tutorial mysql 我的Java链接数据库,以及做添删查改所用的工具包--源代码_MySQL

我的Java链接数据库,以及做添删查改所用的工具包--源代码_MySQL

Jun 01, 2016 pm 01:07 PM



package com.msit.util;

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 Administrator
 *
 */
public class SqlHelper {
 // 链接需要的数据(这些数据直接写到加密后的数据文件中)。
 private static String url = "jdbc:mysql://127.0.0.1:3306/msitdb";
 private static String user = "root";
 private static String password = "root";
 private static String driverName = "com.mysql.jdbc.Driver";
 // 声明静态链接对象
 private static Connection connection = null;

 // 编写静态代码块(比构造函数先加载) 用来加载驱动类
 static {
  try {
   Class.forName(driverName);
  } catch (ClassNotFoundException e) {
   e.printStackTrace();
  }
 }

 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 executeNotQuery(String sql) {
  int num = 0;
  // 1.得到链接对象
  Connection conn = getConnection();
  // 2.创建命令执行对象
  Statement stm = null;
  try {
   stm = conn.createStatement();
   num = stm.executeUpdate(sql);
  } catch (SQLException e) {
   e.printStackTrace();
  } finally {
   close(null, stm, conn);
  }
  return num;
 }

 /**
  * 关闭资源的方法
  *
  * @param rs
  *            结果集
  * @param stm
  *            执行对象
  * @param conn
  *            链接对象
  */
 private static void close(ResultSet rs, Statement stm, Connection conn) {
  if (null != rs) {
   try {
    rs.close();
   } catch (SQLException e) {
    System.out.println("关闭结果集异常!");
    e.printStackTrace();
   }
  }
  if (null != stm) {
   try {
    stm.close();
   } catch (SQLException e) {
    System.out.println("关闭执行对象异常!");
    e.printStackTrace();
   }
  }
  if (null != conn) {
   try {
    conn.close();
   } catch (SQLException e) {
    System.out.println("关闭链接对象异常!");
    e.printStackTrace();
   }
  }
  rs = null;
  stm = null;
  conn = null;
 }// end

 /**
  * 执行查询语句的方法
  *
  * @param sql
  * @return 返回结果集
  */
 public static ResultSet executeQuery(String sql) {
  ResultSet rs = null;
  // 1.得到链接对象
  Connection conn = getConnection();
  // 2.创建命令对象
  try {
   Statement stm = conn.createStatement();
   // 3.执行查询方法 得到结果集
   rs = stm.executeQuery(sql);
  } catch (SQLException e) {
   e.printStackTrace();
  } finally {
   // 4.关闭资源
   //close(rs, stm, conn);
  }
  return rs;
 }
 /**
  * 执行预编译sql的方法
  * @param sql
  * @param pams
  * @return
  */
 public static int executPreStm(String sql,String[] pams){
  int num = 0;
  PreparedStatement pstm= null;
  try {
   //创建编译对象
   pstm = getConnection().prepareStatement(sql);
   //添加占位符的数据
   for (int i = 0; i     pstm.setString(i, pams[i-1]);
   }
   //执行sql语句
   num=pstm.executeUpdate();//只能执行非查询语句
   //关闭资源
   pstm.close();
   connection.close();
  } catch (SQLException e) {
   e.printStackTrace();
  }
  return num;
 }
}

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table? Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table? Mar 19, 2025 pm 03:51 PM

Artikel ini membincangkan menggunakan pernyataan jadual Alter MySQL untuk mengubah suai jadual, termasuk menambah/menjatuhkan lajur, menamakan semula jadual/lajur, dan menukar jenis data lajur.

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL? Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL? Mar 18, 2025 pm 12:01 PM

Artikel membincangkan mengkonfigurasi penyulitan SSL/TLS untuk MySQL, termasuk penjanaan sijil dan pengesahan. Isu utama menggunakan implikasi keselamatan sijil yang ditandatangani sendiri. [Kira-kira aksara: 159]

Bagaimana anda mengendalikan dataset besar di MySQL? Bagaimana anda mengendalikan dataset besar di MySQL? Mar 21, 2025 pm 12:15 PM

Artikel membincangkan strategi untuk mengendalikan dataset besar di MySQL, termasuk pembahagian, sharding, pengindeksan, dan pengoptimuman pertanyaan.

Apakah beberapa alat GUI MySQL yang popular (mis., MySQL Workbench, phpmyadmin)? Apakah beberapa alat GUI MySQL yang popular (mis., MySQL Workbench, phpmyadmin)? Mar 21, 2025 pm 06:28 PM

Artikel membincangkan alat MySQL GUI yang popular seperti MySQL Workbench dan PHPMyAdmin, membandingkan ciri dan kesesuaian mereka untuk pemula dan pengguna maju. [159 aksara]

Bagaimana anda menjatuhkan jadual di MySQL menggunakan pernyataan jadual drop? Bagaimana anda menjatuhkan jadual di MySQL menggunakan pernyataan jadual drop? Mar 19, 2025 pm 03:52 PM

Artikel ini membincangkan jadual menjatuhkan di MySQL menggunakan pernyataan Jadual Drop, menekankan langkah berjaga -jaga dan risiko. Ia menyoroti bahawa tindakan itu tidak dapat dipulihkan tanpa sandaran, memperincikan kaedah pemulihan dan bahaya persekitaran pengeluaran yang berpotensi.

Bagaimana anda mewakili hubungan menggunakan kunci asing? Bagaimana anda mewakili hubungan menggunakan kunci asing? Mar 19, 2025 pm 03:48 PM

Artikel membincangkan menggunakan kunci asing untuk mewakili hubungan dalam pangkalan data, memberi tumpuan kepada amalan terbaik, integriti data, dan perangkap umum untuk dielakkan.

Bagaimana anda membuat indeks pada lajur JSON? Bagaimana anda membuat indeks pada lajur JSON? Mar 21, 2025 pm 12:13 PM

Artikel ini membincangkan membuat indeks pada lajur JSON dalam pelbagai pangkalan data seperti PostgreSQL, MySQL, dan MongoDB untuk meningkatkan prestasi pertanyaan. Ia menerangkan sintaks dan faedah mengindeks laluan JSON tertentu, dan menyenaraikan sistem pangkalan data yang disokong.

Bagaimanakah saya menjamin MySQL terhadap kelemahan biasa (suntikan SQL, serangan kekerasan)? Bagaimanakah saya menjamin MySQL terhadap kelemahan biasa (suntikan SQL, serangan kekerasan)? Mar 18, 2025 pm 12:00 PM

Artikel membincangkan mendapatkan MySQL terhadap suntikan SQL dan serangan kekerasan menggunakan pernyataan yang disediakan, pengesahan input, dan dasar kata laluan yang kuat. (159 aksara)

See all articles