一,JDBC介绍

  • SUN公司为了简化、统一对数据库的操作,定义了一套Java操作数据库的规范(接口),称之为JDBC。这套接口由数据库厂商去实现,这样,开发人员只需要学习jdbc接口,并通过jdbc加载具体的驱动,就可以操作数据库
  • JDBC全称为:Java Data Base Connectivity(java数据库连接),它主要由接口组成
  • 组成JDBC的2个包: java.sql 和 javax.sql, 开发JDBC应用需要以上2个包的支持外,还需要导入相应JDBC的数据库实现(即数据库驱动)

二,下载jar包

推荐下载地址 : https://mvnrepository.com/artifact/mysql/mysql-connector-java



三,编写JDBC程序

1,在mysql中创建一个库,并创建user表和插入表的数据

  1. #创建jdbcStudy数据库
  2. 1 create database jdbcStudy character set utf8 collate utf8_general_ci;
  3. 2 use jdbcStudy; #使用jdbcStudy数据库
  4. #创建users用户表

  5. 3 create table users(

  6. 4 id int primary key, #将id设为主键

  7. 5 name varchar(40),

  8. 6 password varchar(40),

  9. 7 email varchar(60),

  10. 8 birthday date

  11. 9 );
  12. <span class="hljs-meta">#插入数据</span>
  13. 10 insert into users(id,name,password,email,birthday)

  14. values(1,'zhansan','123456','zs@sina.com','1980-12-04');

  15. 11 insert into users(id,name,password,email,birthday)

  16. values(2,'lisi','123456','lisi@sina.com','1981-12-04');

  17. 12 insert into users(id,name,password,email,birthday)

  18. values(3,'wangwu','123456','wangwu@sina.com','1979-12-04');

  19.  

2,新建一个Java工程,并导入数据驱动

3,编写程序从user表中读取数据,并打印在命令行窗口中

  1. public class JDBCDemo {
  2. public static void main(String[] args) throws Exception {
  3. //要连接的数据库URL
  4. String url = "jdbc:mysql://localhost:3306/jdbcstudy";
  5. //连接的数据库时使用的用户名
  6. String username = "root";
  7. //连接的数据库时使用的密码
  8. String password = "123456";
  9.        <span class="hljs-comment">//1.加载驱动</span>
  10.        Class.forName(<span class="hljs-string">"com.mysql.jdbc.Driver"</span>);
  11.        <span class="hljs-comment">//2.获取与数据库的链接</span>
  12.        Connection conn = DriverManager.getConnection(url, username, password);
  13.        <span class="hljs-comment">//3.获取用于向数据库发送sql语句的statement</span>
  14.        Statement st = conn.createStatement();
  15.        String sql = <span class="hljs-string">"select id,name,password,email,birthday from users"</span>;
  16.        <span class="hljs-comment">//4.向数据库发sql,并获取代表结果集的resultset</span>
  17.        ResultSet rs = st.executeQuery(sql);
  18.        <span class="hljs-comment">//5.取出结果集的数据</span>
  19.        <span class="hljs-keyword">while</span>(rs.next()){
  20.                System.<span class="hljs-keyword">out</span>.println(<span class="hljs-string">"id="</span> + rs.getObject(<span class="hljs-string">"id"</span>));
  21.                System.<span class="hljs-keyword">out</span>.println(<span class="hljs-string">"name="</span> + rs.getObject(<span class="hljs-string">"name"</span>));
  22.                System.<span class="hljs-keyword">out</span>.println(<span class="hljs-string">"password="</span> + rs.getObject(<span class="hljs-string">"password"</span>));
  23.                System.<span class="hljs-keyword">out</span>.println(<span class="hljs-string">"email="</span> + rs.getObject(<span class="hljs-string">"email"</span>));
  24.                System.<span class="hljs-keyword">out</span>.println(<span class="hljs-string">"birthday="</span> + rs.getObject(<span class="hljs-string">"birthday"</span>));
  25.            }
  26.        <span class="hljs-comment">//6.关闭链接,释放资源</span>
  27.        rs.close();
  28.        st.close();
  29.        conn.close();
  30. }
  31. }

  32.  

4,运行结果

四,DriverManager类讲解

Jdbc程序中的DriverManager用于加载驱动,并创建与数据库的链接,这个API的常用方法:

1:DriverManager.registerDriver(new Driver())

2:DriverManager.getConnection(url, user, password),

【注意:在实际开发中并不推荐采用registerDriver方法注册驱动】  

原因1:查看Driver的源代码可以看到,如果采用此种方式,会导致驱动程序注册两次,也就是在内存中会有两个Driver对象

原因2:程序依赖mysql的api,脱离mysql的jar包,程序将无法编译,将来程序切换底层数据库将会非常麻烦

【推荐方式:Class.forName("com.mysql.jdbc.Driver")】

采用此种方式不会导致驱动对象在内存中重复出现,并且采用此种方式,程序仅仅只需要一个字符串,不需要依赖具体的驱动,使程序的灵活性更高

五,Connection类讲解

Jdbc程序中的Connection,它用于代表数据库的链接,Collection是数据库编程中最重要的一个对象,客户端与数据库所有交互都是通过connection对象完成的

createStatement():创建向数据库发送sql的statement对象

prepareStatement(sql) :创建向数据库发送预编译sql的PrepareSatement对象

prepareCall(sql):创建执行存储过程的callableStatement对象

setAutoCommit(boolean autoCommit):设置事务是否自动提交

commit() :在链接上提交事务

rollback() :在此链接上回滚事务

六,Statement类讲解

Jdbc程序中的Statement对象用于向数据库发送SQL语句

executeQuery(String sql) :用于向数据发送查询语句

executeUpdate(String sql):用于向数据库发送insert、update或delete语句

execute(String sql):用于向数据库发送任意sql语句

addBatch(String sql) :把多条sql语句放到一个批处理中

executeBatch():向数据库发送一批sql语句执行

七,ResultSet类讲解

Jdbc程序中的ResultSet用于代表Sql语句的执行结果。Resultset封装执行结果时,采用的类似于表格的方式。ResultSet 对象维护了一个指向表格数据行的游标,初始的时候,游标在第一行之前,调用ResultSet.next() 方法,可以使游标指向具体的数据行,进行调用方法获取该行的数据

ResultSet既然用于封装执行结果的,所以该对象提供的都是用于获取数据的get方法:


获取任意类型的数据

    getObject(int index)

    getObject(string columnName)

获取指定类型的数据

    getString(int index)

    getString(String columnName)

ResultSet还提供了对结果集进行滚动的方法:

next():移动到下一行

Previous():移动到前一行

absolute(int row):移动到指定行

beforeFirst():移动resultSet的最前面。

afterLast() :移动到resultSet的最后面。

八,释放资源

Jdbc程序运行完后,切记要释放程序在运行过程中,创建的那些与数据库进行交互的对象,这些对象通常是ResultSet, Statement和Connection对象,特别是Connection对象,它是非常稀有的资源,用完后必须马上释放,如果Connection不能及时、正确的关闭,极易导致系统宕机。Connection的使用原则是尽量晚创建,尽量早的释放

为确保资源释放代码能运行,资源释放代码也一定要放在finally语句中

九,数据库URL讲解

URL用于标识数据库的位置,通过URL地址告诉JDBC程序连接哪个数据库,URL的写法为:



常用数据库URL地址的写法:

Oracle写法:jdbc:oracle:thin:@localhost:1521:sid

SqlServer写法:jdbc:microsoft:sqlserver://localhost:1433; DatabaseName=sid

MySql写法:jdbc:mysql://localhost:3306/sid

【如果连接的是本地的Mysql数据库,并且连接使用的端口是3306,那么的url地址可以简写为jdbc:mysql:///数据库】

JDBC(1):JDBC介绍的更多相关文章

  1. JDBC实例--JDBC连接池技术解密,连接池对我们不再陌生

    一.为什么我们要用连接池技术? 前面的数据库连接的建立及关闭资源的方法有些缺陷.统舱传统数据库访问方式:一次数据库访问对应一个物理连接,每次操作数据库都要打开.关闭该物理连接, 系统性能严重受损. 解 ...

  2. 线程池-连接池-JDBC实例-JDBC连接池技术

    线程池和连接池   线程池的原理:     来看一下线程池究竟是怎么一回事?其实线程池的原理很简单,类似于操作系统中的缓冲区的概念,它的流程如下:先启动若干数量的线程,并让这些线程都处于睡眠状态,当客 ...

  3. 深入浅出MyBatis:JDBC和MyBatis介绍

    JDBC相关概念 Java程序都是通过JDBC连接数据库的,通过SQL对数据库编程,JDBC是由SUN公司提出的一些列规范,只定义了接口规范,具体实现由各个数据库厂商去实现,它是一种典型的桥接模式. ...

  4. MyBatis源码分析(一):从JDBC到MyBatis 介绍MyBatis的背景,为什么要用MyBatis

    一.介绍JDBC JDBC全称Java Database Connectivity,是Java语言规范客户端访问数据库的应用程序接口,所面向的数据库类型为关系型数据库. JDBC的三层架构图: JDB ...

  5. Mysql——JDBC编程 理论介绍

    一.JDBC简介(来自俞琰--数据库老师) Java数据库编程主要使用JDBC技术.JDBC是一种用于执行SQL语句的Java API.它由一组用Java编写的类和接口组成.JDBC为开发人员提供了一 ...

  6. 【JDBC】jdbc原理总结

    1 什么是JDBC JDBC(Java DataBase Connectivity)就是Java数据库连接,说白了就是用Java语言来操作数据库.原来我们操作数据库是在控制台使用SQL语句来操作数据库 ...

  7. JDBC——使用JDBC连接MySQL数据库

    在JDBC--什么是JDBC一文中我们已经介绍了JDBC的基本原理. 这篇文章我们聊聊如何使用JDBC连接MySQL数据库. 一.基本操作 首先我们需要一个数据库和一张表: CREATE DATABA ...

  8. JDBC基础:JDBC快速入门,JDBC工具类,SQL注入攻击,JDBC管理事务

    JDBC基础 重难点梳理 一.JDBC快速入门 1.jdbc的概念 JDBC(Java DataBase Connectivity:java数据库连接)是一种用于执行SQL语句的Java API,可以 ...

  9. 初学JDBC,JDBC工具类的简单封装

    //工具类不需要被继承 public final class JdbcUtils{ //封装数据库连接参数,便于后期更改参数值 private static String url="jdbc ...

  10. JDBC初步 JDBC连接SQLServer 2008之心路历程

    转自:http://www.cnblogs.com/weilengdeyu/archive/2013/01/17/2864321.html JDBC简介 今天,研究了下JDBC连接SQL Server ...

随机推荐

  1. 如何系统学习C 语言(中)之 结构体篇

    1,结构体 在前面我们知道变量和数组都可以用来存储数据,变量用来存储单个数据,数组可以用来存储一组同类型的数据,但你有没有发现--它们都只适合单一属性的数据.那现实生活中,很多对象都是具有多属性的.例 ...

  2. 在同级路径下,SpringBoot两种类型的配置文件(.properties/.yml)同时存在时,配置优先级如何处理?

    两类配置文件如果同时存在,若 key 相同则 properties 优先级高,若key不同则合并加载:

  3. [第二章]c++学习笔记3(构造函数)

    成员函数的一种 (1)名字与类名相同,可以有参数,不能有返回值(void也不行) (2)作用是对对象初始化,如给成员变量赋初值 (3)如果定义类时没写构造函数,则编译器生成一个默认的无参数的构造函数( ...

  4. 4.ASCII码排序

    描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符. 输入 第一行输入一个数N,表示有N组测试数据.后面的N行输入多组数据,每组输入数据都是占一行,有三个字符组成,之 ...

  5. cgdb | 一起边看源码边调试gdb吧

    简介 cgdb是一款轻量级的基于gdb的命令行可视化工具,关系大致如下: 尽管gdb本身可以通过layout src的命令显示源码布局,但是其功能还是过于简陋. 使用cgdb并不需要你重新去学习过多额 ...

  6. 在Vs code中使用sftp插件以及连接windows远程sftp协议部署指导(解决vscode的sftp插件中文目录乱码问题)

    一.启动SFtp 二.上手vs code SFTP插件 2.1 初始配置 2.2解决乱码问题 三.SFTP配置 3.1常用配置 3.2示例配置 四.SFTP使用 五.扩展阅读 一.启动SFtp 话说小 ...

  7. Python基础(递归函数)

    def age(n): if n == 1: return 18 else: return age(n - 1) + 2 ret=age(100) print(ret)#216 def test(nu ...

  8. vue开发中的一些简单骚操作

    在开发过程中,我们可以定义很多参数,这时需要通过不同的操作来改变不同的参数,这就比较复杂了, 虽然不难,但是代码多了也不好看,这时我们就可以通过简单的操作就行简化: 1.对象使用方括号 let obj ...

  9. 美团饿了么领取外卖优惠券微信小程序的开发及上线_怎样点外卖省钱_外卖小程序的开发及上线

    都1202年了,估计没人不知道外卖了,那么就有两种人在思考两种问题: 普通人:怎么点外卖划算? 程序员:怎么通过外卖赚钱? 话不多说,为了让你们相信我有能力来讲这块内容,先给你们看一个很简单的小程序: ...

  10. [loj3501]图函数

    $f(i,G)_{x}$为$x$对$i$是否有贡献,即在枚举到$x$时,$i$与$x$是否强连通 事实上,$f(i,G)_{x}=1$即不经过$[1,x)$中的点且$i$与$x$强连通 首先,当存在这 ...