JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC为数据库开发人员提供了一个标准的API,使数据库开发人员能够用纯 Java API 编写数据库应用程序,并且可跨平台运行,并且不受数据库供应商的限制。其优点:

  • 操作便捷:开发人员不需要再使用复杂的驱动器调用命令和函数;
  • 可移植性强:JDBC支持不同的关系数据库
  • 通用性好:JDBC-ODBC桥接驱动器将JDBC函数换成ODBC;
  • 面向对象:可以将常用的JDBC数据库连接封装成一个类,在使用的时候直接调用即可
package DAO;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import com.mysql.jdbc.Statement; public class JDBC {
protected Connection conn;
protected Statement statement; public static Connection getConnection() throws Exception {
Connection connection = null; // 创建用于连接数据库的Connection对象
try {
Class.forName("com.mysql.jdbc.Driver");// 加载Mysql数据驱动
/**
* 127.0.0.1指本机,若是链接远程服务机器,则填写远程机器的ip 3306 mysql默认的端口号 test 数据库名称
* user 数据库用户名称 password 密码
*/
connection = DriverManager.getConnection(
"jdbc:mysql://127.0.0.1:3306/test", "user", "password");// 创建数据连接 } catch (Exception e) {
e.printStackTrace();
throw new Exception("链接mysql数据失败");
}
return connection; // 返回所建立的数据库连接
} /**
* 向mysql插入数据记录 返回插入数据的个数
*
* @param sql
* 要插入的sql语句
* @return count 插入数据的个数
* @throws Exception
*/
public int insert(String sql) throws Exception {
conn = getConnection(); // 连接到数据库
try {
statement = (Statement) conn.createStatement(); // 创建用于执行静态sql语句的Statement对象
int count = statement.executeUpdate(sql); // 执行插入操作的sql语句
conn.close(); // 关闭数据库连接
return count;// 返回插入数据的个数
} catch (SQLException e) {
e.printStackTrace();
throw new Exception("插入数据失败");
}
} /**
* 更新符合要求的记录 返回更新的记录数目
*
* @param sql
* 更新数据的sql语句
* @return count 更新数据的个数
* @throws Exception
*/
public int update(String sql) throws Exception {
conn = getConnection(); // 连接到数据库
try {
// 创建用于执行静态sql语句的Statement对象,
statement = (Statement) conn.createStatement();
int count = statement.executeUpdate(sql);// 执行更新操作的sql语句,
conn.close(); // 关闭数据库连接
return count; // 返回更新数据的个数
} catch (SQLException e) {
e.printStackTrace();
throw new Exception("更新数据失败");
}
} /**
* 查询数据库,返回符合要求的记录的数据
*
* @param sql 查询数据的sql语句
* @throws Exception
* @return list
*/
public List<Object> query(String sql) throws Exception { conn = getConnection(); // 连接到数据库
try {
statement = (Statement) conn.createStatement(); // 创建用于执行静态sql语句的Statement对象
ResultSet rs = statement.executeQuery(sql); // 执行sql查询语句,返回查询数据的结果集
List<Object> list=ResultSetToList(rs);
conn.close(); // 关闭数据库连接
return list; } catch (SQLException e) {
e.printStackTrace();
throw new Exception("查询数据失败");
}
}
/* 删除符合要求的记录,输出情况*/
/**
*
* @param sql 删除数据的sql语句
* @return count 返回删除数据的数量
* @throws Exception
*/
public int delete(String sql) throws Exception {
conn = getConnection(); //连接到数据库
try {
statement = (Statement) conn.createStatement(); //创建用于执行静态sql语句的Statement对象
int count = statement.executeUpdate(sql);// 执行sql删除语句
conn.close(); //关闭数据库连接
return count;//返回删除数据的数量
} catch (SQLException e) {
e.printStackTrace();
throw new Exception("删除数据失败");
} }
/**
* 分页查找
* @param sql 要查找的sql语句
* @param page 页数
* @param count 数据条数
* @return List<Object>
* @throws Exception
*/
public List<Object> findByPage(String sql,
int page,int count) throws Exception {
conn = getConnection(); //连接到数据库
PreparedStatement pre = conn.prepareStatement(sql);
pre.setMaxRows(count);
ResultSet rs = pre.executeQuery();
if(page<1){
rs.absolute(0);
}else{
page=page*count-1;
rs.absolute(page);
}
List<Object> list=ResultSetToList(rs);
return list;
}
/**
* ResultSet 转换成List
*/
public List<Object> ResultSetToList(ResultSet rs) throws SQLException{
if (rs == null)
return Collections.emptyList();
ResultSetMetaData md = rs.getMetaData(); // 得到结果集(rs)的结构信息
int columnCount = md.getColumnCount(); // 返回此 ResultSet 对象中的列数
List<Object> list = new ArrayList<Object>();
Map<Object, Object> rowData = new HashMap<Object, Object>();
while (rs.next()) {
rowData = new HashMap<Object, Object>(columnCount);
for (int i = 1; i <= columnCount; i++) {
rowData.put(md.getColumnName(i), rs.getObject(i));
}
list.add(rowData);
}
return list;
} }

java jdbc连接mysql的更多相关文章

  1. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  2. java jdbc 连接mysql 数据库

    JDBC连接MySQL 加载及注册JDBC驱动程序 Class.forName("com.mysql.jdbc.Driver"); Class.forName("com. ...

  3. 【Java】JDBC连接MySQL

    JDBC连接MySQL 虽然在项目中通常用ORM的框架实现持久化.但经常因测试某些技术的需要,要写一个完整的JDBC查询数据库.写一个在这儿备份. 首先引入驱动包: <dependencies& ...

  4. JAVA使用jdbc连接MYSQL简单示例

    以下展示的为JAVA使用jdbc连接MYSQL简单示例: import java.sql.DriverManager; import java.sql.ResultSet; import java.s ...

  5. java用JDBC连接MySQL数据库的详细知识点

    想实现java用JDBC连接MySQL数据库.需要有几个准备工作: 1.下载Connector/J的库文件,下载Connector/J的官网地址:http://www.mysql.com/downlo ...

  6. Java编程学习之JDBC连接MySQL

    JDBC连接MySQL 一.对JDBC连接数据库的步骤1.加载数据库驱动//加载驱动Class.forName(driverClass)-------------------------------- ...

  7. (Win10)Java,Maven,Tomcat8.0,Mysql8.0.15安装与环境配置,以及IDEA2019.3使用JDBC连接MySQL、创建JavaEE项目

    之前用windows+linux的双系统,最近不怎么舒服就把双系统给卸了,没想到除了问题,导致有linux残余,于是就一狠心重装了电脑,又把Java及其相关的一些东西重新装了回来,还好当初存了网盘链接 ...

  8. ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库

    1.MySQL存储过程   1.1.什么是存储过程 带有逻辑的sql语句:带有流程控制语句(if  while)等等 的sql语句   1.2.存储过程的特点 1)执行效率非常快,存储过程是数据库的服 ...

  9. JDBC连接MySQL数据库代码模板

    下面这个例子是最简单的JDBC连接MySQL数据库的例子. 一般步骤: 1.注册驱动: 2.建立连接: 3.创建语句: 4.处理结果: 5.释放资源. 注意: 1.软件开发环境:MyEclipse 8 ...

随机推荐

  1. 随笔2 PAT1001.A+B Format (20)

    1001.A+B Format(20) 题目链接 1001.A+B Format (20) C++ 代码 第一次使用markdown,还不是很习惯,现在努力的在适应它 首先这道题我们很容易就可以读懂题 ...

  2. CSU1612Destroy Tunnels(强连通)

    Destroy Tunnels 原来早忘记了离散里含有这么一个叫传递闭包的东西 矩阵A的闭包B = A U A^2 U A^3 U ... 所以这里直接如果A[i][j]!= 0,建边i->j跑 ...

  3. Win7 x64下进程保护与文件保护(ObRegisterCallbacks)

    进程保护部分参考 http://bbs.pediy.com/showthread.php?t=168023 进程保护,在任务管理器不能结束进程 #ifndef CXX_PROTECTPROCESSX6 ...

  4. 利用 Heritrix 构建特定站点爬虫

    http://www.ibm.com/developerworks/cn/opensource/os-cn-heritrix/

  5. ASP.NET MVC 修改视图的默认路径(MVC2,MVC3)

    ASP.NET MVC2 修改视图的默认路径 步骤:1.编写继承自WebFormViewEngine的类,重写视图路径 2.在Application_Start()中添加语句: ViewEngines ...

  6. js时间转换相关

    1.json时间格式转换 function ChangeDateFormat(jsondate) { if (!jsondate||jsondate.length < 1) {return &q ...

  7. Python 存储模型

    1.Python彻底分离了对象和引用,可以认为内存中的对象都是不可修改的,每次修改引用,相当于在堆上重新创建一个对象,引用指向新对象. 2.对于数值和字符串,修改意味着引用指向一个新对象. 3.集合中 ...

  8. 转换到 COFF 期间失败: 文件无效或损坏 解决方法

    转自csdn 终极解决方案:VS2010在经历一些更新后,建立Win32 Console Project时会出“error LNK1123” 错误,解决方案为将 项目|项目属性|配置属性|清单工具|输 ...

  9. [每日一题] OCP1z0-047 :2013-08-06 外表部――相关描述

    这道题目的知识点是要你熟悉外部表,怎么建外部表,外部表的数据是怎么存储的等等.请给出正确答案,并解释A B C D每项,最好用实验测试证明! 外部表的metadata(元数据)是存在数据库中,但它的数 ...

  10. C++ Code_ImageList

    主题 1.  创建图像列表 2.  使用图像列表绘图 3. 4. 5.     代码::创建图像列表 双击 Cproject03Dlg在     下面添加 1 句 ////////////////// ...