JAVA连接MySQL数据库(可转换成SQL Server、Oracle连接方式)(精华版)

本文主要是介绍JAVA连接MySQL数据库(可转换成SQL Server、Oracle连接方式)(精华版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先JAVA连接数据库的代码主要有三大步骤:
①加载驱动即jar包
②建立连接
③写SQL语句并执行或返回结果

可执行代码如下:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBC_Connection {//这里,我把连接myssql数据库的方法体写到构造器里只为方便大家测试运行。public JDBC_Connection() throws SQLException{Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;//1.加载驱动即jar包String Driver = "com.mysql.jdbc.Driver";try {Class.forName(Driver);} catch (ClassNotFoundException e) {System.err.println("未找到驱动包com.mysql.jdbc.Driver");}//2.建立连接String URL = "jdbc:mysql://localhost:3306/cet";//URL格式 - jdbc:subprotocol:subname 这里3306是mysql指定端口号,cet是我要连接的数据库名String username = "root";String password = "root";try {conn = DriverManager.getConnection(URL, username, password);} catch (SQLException e) {System.err.println("连接失败");}//3.写SQL语句并执行String  SQL = "select * from cet4_6 where 准考证号 = ?"; ps = conn.prepareStatement(SQL);//区别是若有增删改功能语句中的数据可用换位符“?”代替ps.setObject(1, "640012171200001");rs = ps.executeQuery();while(rs.next()){System.out.println(rs.getObject(1)+"--"+rs.getObject(2)+"--"+rs.getObject(3)+"--"+rs.getObject(4));}if(rs!=null){   //此处是倒序一一关闭rs.close();rs = null;}if(ps!=null){ps.close();ps = null;}if(conn!=null){conn.close();conn = null;}}public static void main(String[] args) throws SQLException {new JDBC_Connection();}
}

总结如下
1.加载驱动jar包的时候一定也要同步在IDE(eclipse)上加载上,很多初学者数据库连接失败就是这个原因,匹配的MySQL的jar包如下,可自行下载。
百度云盘链接:http://pan.baidu.com/s/1c2JCPaS 密码:mvkf
使用方法:项目右键->Build Path->Congigure Build Path->Add External JARs 选中此jar包加载即可。加载成功如图所示

JAR

2.URL格式注释中已经详细给出,不论是Oracle,MySQL还是SQL Sever等数据库,不同数据库连接代码大致相同,只需要修改加载的驱动,URL中的数据库类别以及相应的端口号,其余基本无需更改即可套用。
注:以上代码,如要配用请修改一下信息即可↓
用户名:root
密码:root
数据库名:cet
表名:cet4_6
端口号:3306
另给出三种常用数据库URL格式:
Mysql:jdbc:mysql://localhost:3306/数据库名
SQL Server:jdbc:sqlserver://localhost:1433;DatabaseName=数据库名 (SQL Server导入的Jar包为:sqljdbc4.jar)
Oracle:jdbc:oracle:thin:@localhost:1521:orc

3.执行SQL语句有三种方法及特点如下:
①静态:Statement语句。由createStatement方法创建,用于发送简单的SQL语句(写死的)且不带参数。以上代码如用此方法可换成如下代码:

Statement stmt = null;
stmt = conn.createStatement();
String  SQL = "select * from cet4_6";
rs = stmt.executeQuery(SQL);

②预编译:PreparedStatement语句。由prepareStatement方法创建,用于发送含有一个或多个输入参数的SQL语句。主要特点如下:
(1)高效性:预编译过程可对SQL进行预处理,可提高代码运行效率。
(2)安全性:防止在静态SQL语句下出现的SQL注入风险。
由于这两个特点,此方法一般为开发者常用方法。在使用中SQL语句中的数据可用换位符“?”代替,后可调用setObject(int num, String s);方法设置,num表示第几个换位符,从1开始递增,后面的字符串表示要置换的语句。
③CallableStatement语句:prePareCall方法创建,用于调用存储过程

另:常用的Statement方法有三种。
①execute(); 运行语句,返回是否有结果集。
②executeQuery(); 运行select语句,返回ResultSet结果集。
③executeUpdate(); 运行insert/update/delete操作,返回更新的行数。

4.最后三大功能类分别运行close()方法时,要倒序关闭。即后创建的,先关闭。

这篇关于JAVA连接MySQL数据库(可转换成SQL Server、Oracle连接方式)(精华版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/589571

相关文章

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

MySQL 多表连接操作方法(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL OUTER JOIN)

《MySQL多表连接操作方法(INNERJOIN、LEFTJOIN、RIGHTJOIN、FULLOUTERJOIN)》多表连接是一种将两个或多个表中的数据组合在一起的SQL操作,通过连接,... 目录一、 什么是多表连接?二、 mysql 支持的连接类型三、 多表连接的语法四、实战示例 数据准备五、连接的性

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St