• JDBC连接数据库 好文一定要让大家看见
  • •创建一个以JDBC连接数据库的程序,包含7个步骤:
  • 1、加载JDBC驱动程序:
  • 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),
  • 这通过java.lang.Class类的静态方法forName(String  className)实现。
  • 例如:
  • try{
  • //加载MySql的驱动类
  • Class.forName("com.mysql.jdbc.Driver") ;
  • }catch(ClassNotFoundException e){
  • System.out.println("找不到驱动程序类 ,加载驱动失败!");
  • e.printStackTrace() ;
  • }
  • 成功加载后,会将Driver类的实例注册到DriverManager类中。
  • 2、提供JDBC连接的URL
  • •连接URL定义了连接数据库时的协议、子协议、数据源标识。
  • •书写形式:协议:子协议:数据源标识
  • 协议:在JDBC中总是以jdbc开始
  • 子协议:是桥连接的驱动程序或是数据库管理系统名称。
  • 数据源标识:标记找到数据库来源的地址与连接端口。
  • 例如:(MySql的连接URL)
  • jdbc:mysql:
  • //localhost:3306/test?useUnicode=true&characterEncoding=gbk ;
  • useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为
  • gb2312或GBK,本参数必须设置为true 。characterEncoding=gbk:字符编码方式。
  • 3、创建数据库的连接
  • •要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,
  • 该对象就代表一个数据库的连接。
  • •使用DriverManager的getConnectin(String url , String username ,
  • String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和
  • 密码来获得。
  • 例如:
  • //连接MySql数据库,用户名和密码都是root
  • String url = "jdbc:mysql://localhost:3306/test" ;
  • String username = "root" ;
  • String password = "root" ;
  • try{
  • Connection con =
  • DriverManager.getConnection(url , username , password ) ;
  • }catch(SQLException se){
  • System.out.println("数据库连接失败!");
  • se.printStackTrace() ;
  • }
  • 4、创建一个Statement
  • •要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3
  • 种类型:
  • 1、执行静态SQL语句。通常通过Statement实例实现。
  • 2、执行动态SQL语句。通常通过PreparedStatement实例实现。
  • 3、执行数据库存储过程。通常通过CallableStatement实例实现。
  • 具体的实现方式:
  • Statement stmt = con.createStatement() ;
  • PreparedStatement pstmt = con.prepareStatement(sql) ;
  • CallableStatement cstmt =
  • con.prepareCall("{CALL demoSp(? , ?)}") ;
  • 5、执行SQL语句
  • Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate
  • 和execute
  • 1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句
  • ,返回一个结果集(ResultSet)对象。
  • 2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或
  • DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等
  • 3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的
  • 语句。
  • 具体实现的代码:
  • ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;
  • int rows = stmt.executeUpdate("INSERT INTO ...") ;
  • boolean flag = stmt.execute(String sql) ;
  • 6、处理结果
  • 两种情况:
  • 1、执行更新返回的是本次操作影响到的记录数。
  • 2、执行查询返回的结果是一个ResultSet对象。
  • • ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些
  • 行中数据的访问。
  • • 使用结果集(ResultSet)对象的访问方法获取数据:
  • while(rs.next()){
  • String name = rs.getString("name") ;
  • String pass = rs.getString(1) ; // 此方法比较高效
  • }
  • (列是从左到右编号的,并且从列1开始)
  • 7、关闭JDBC对象
  • 操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声
  • 明顺序相反:
  • 1、关闭记录集
  • 2、关闭声明
  • 3、关闭连接对象
  • if(rs != null){   // 关闭记录集
  • try{
  • rs.close() ;
  • }catch(SQLException e){
  • e.printStackTrace() ;
  • }
  • }
  • if(stmt != null){   // 关闭声明
  • try{
  • stmt.close() ;
  • }catch(SQLException e){
  • e.printStackTrace() ;
  • }
  • }
  • if(conn != null){  // 关闭连接对象
  • try{
  • conn.close() ;
  • }catch(SQLException e){
  • e.printStackTrace() ;
  • }
  • }

java开发JDBC连接数据库详解的更多相关文章

  1. Java的JDBC事务详解

    Java的JDBC事务详解         分类:             Hibernate              2010-06-02 10:04     12298人阅读     评论(9) ...

  2. Java开发JDBC连接数据库

    Java开发JDBC连接数据库 创建一个以JDBC连接数据库的程序,包含6个步骤: JDBC五部曲1.加载驱动2.获得链接3.获取statement对象 4.执行SQL语句5.产生resultset对 ...

  3. java开发JDBC连接数据库代码

    JDBC连接数据库,创建一个以JDBC连接数据库的程序,包含7个步骤: 1.加载JDBC驱动程序: 这通过java.lang.Class类的静态方法forName(String className)实 ...

  4. JDBC连接数据库详解

    JDBC连接数据库 •创建一个以JDBC连接数据库的程序,包含7个步骤: 1.加载JDBC驱动程序: 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),这通过java.la ...

  5. Java的JDBC事务详解(转)

    事务的特性: 1) 原子性(atomicity):事务是数据库的逻辑工作单位,而且是必须是原子工作单位,对于其数据修改,要么全部执行,要么全部不执行. 2) 一致性(consistency):事务在完 ...

  6. Java开发环境搭建详解

    一.jdk安装与配置 jdk7于3月份刚刚发布,目前eclipse的最新版本中还没有提供对jdk7的编译支持,所以我们只下载jdk6. 下载地址:http://download.java.net/jd ...

  7. 【转载】Java的JDBC事务详解

    转自:http://www.cnblogs.com/azhqiang/p/4044127.html 事务的特性: 1) 原子性(atomicity):事务是数据库的逻辑工作单位,而且是必须是原子工作单 ...

  8. java web.xml配置详解(转)

    源出处:java web.xml配置详解 1.常规配置:每一个站的WEB-INF下都有一个web.xml的设定文件,它提供了我们站台的配置设定. web.xml定义: .站台的名称和说明 .针对环境参 ...

  9. Java编程配置思路详解

    Java编程配置思路详解 SpringBoot虽然提供了很多优秀的starter帮助我们快速开发,可实际生产环境的特殊性,我们依然需要对默认整合配置做自定义操作,提高程序的可控性,虽然你配的不一定比官 ...

随机推荐

  1. Word2Vec 使用总结

    word2vec 是google 推出的做词嵌入(word embedding)的开源工具. 简单的说,它在给定的语料库上训练一个模型,然后会输出所有出现在语料库上的单词的向量表示,这个向量称为&qu ...

  2. 用上CommonMark.NET,.NET平台终于有了好用的markdown引擎

    缺少好用的markdown引擎之前一直是.NET平台上的一个痛点.因为这个痛点,我们被迫痛苦地使用了pandoc--不是pandoc做的不好,而是pandoc是由Haskell开发的,只能在Windo ...

  3. ConvertHelper 通用类

    public class ConvertHelper<T> where T : new() { private static Dictionary<Type, List<IPr ...

  4. inline-block元素间距

    做项目过程中发现元素设置为inline-block后,彼此之间会有间距,有时候不是我们想要的效果,这时候就需要将间距去除掉. 后来上网查了下,已有前人总结了不少好的方法.这里主要借鉴了张鑫旭博客中介绍 ...

  5. [转]在html中控制自动换行

    其实只要在表格控制中添加一句 <td style="word-break:break-all">就搞定了. 其中可能对英文换行可能会分开一个单词问题:解决如下: 语法: ...

  6. 网页游戏外挂辅助AMF模拟通讯必备

    class AMF_Post_Data { public List<byte> message; /// <summary> /// 初始化Message /// </s ...

  7. C#的访问级别

    可访问性级别有 public                       访问不受限制.  protected                 访问仅限于包含类或从包含类派生的类型.  interna ...

  8. eclipse安装和配置

    一.下载eclipse eclipse下载页 (选择"Eclipse IDE for Java EE Developers",适用于web和android开发) 我用的是luna的 ...

  9. 非对称加密算法——RSA

    RSA     这种算法1978年就出现了,它是第一个既能用于数据加密也能用于数字签名的算法.它易于理解和操作,也很流行.算法的名字以发明者的名字命名:Ron Rivest, AdiShamir 和L ...

  10. How to setup vsftpd FTP file Server on Redhat 7 Linux

    Forward from: https://linuxconfig.org/how-to-setup-vsftpd-ftp-file-server-on-redhat-7-linux How to s ...