• 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. JSX语法简介

    React的核心机制之一就是可以在内存中创建虚拟的DOM元素.React利用虚拟DOM来减少对实际DOM的操作从而提升性能. JSX简介 JSX就是Javascript和XML结合的一种格式.Reac ...

  2. [CareerCup] 18.1 Add Two Numbers 两数相加

    18.1 Write a function that adds two numbers. You should not use + or any arithmetic operators. 这道题让我 ...

  3. AppBox升级进行时 - 拥抱Entity Framework的Code First开发模式

    AppBox 是基于 FineUI 的通用权限管理框架,包括用户管理.职称管理.部门管理.角色管理.角色权限管理等模块. 从Subsonic到Entity Framework Subsonic最早发布 ...

  4. JS组件系列——开源免费图表组件:Chart.js

    前言:最近被开源免费得有点上火了,各种组件首先想到的就是是开源否.是否免费.是否和bootstrap风格一致.想着以后做报表肯定要用到图表组件的,于是在Bootstrap中文网上面找到了Chart.j ...

  5. epub电子书--目录结构介绍

    epub电子书简介 epub全称为Electronic Publication的缩写,意为:电子出版, epub于2007年9月成为国际数位出版论坛(IDPF)的正式标准,以取代旧的开放Open eB ...

  6. Python 从零学起(纯基础) 笔记 之 深浅拷贝

    深浅拷贝 1. import  copy#浅拷贝copy.copy()#深拷贝copy.deepcopy()#赋值 = 2.   对于数字和字符串而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个 ...

  7. BZOJ 4569 萌萌哒

    题目传送门 4569: [Scoi2016]萌萌哒 Time Limit: 10 Sec Memory Limit: 256 MB Submit: 483 Solved: 221 [Submit][S ...

  8. rsync数据同步备份

    一.rsync简介 (1)rsync是什么? rsync是一款开源的.快速的.多功能的.可实现全量及增量的本地或远程数据同步备份的优秀工具. (2)rsync作用比较 远程拷贝:有点类似ssh的scp ...

  9. The RAII Programming Idiom

    https://www.hackcraft.net/raii/ https://en.wikipedia.org/wiki/Resource_Acquisition_Is_Initialization

  10. 收藏一些好用的fifo

    1.Nordic库中的 E:\nRF52_SDK_0.9.2_dbc28c9\components\libraries\fifo app_fifo.c /* Copyright (c) 2013 No ...