DBC

JDBC就是一套接口,真正执行的是jar包里得实现类,通过泛型对象来执行实现类里的方法。

步骤:

###1.导入驱动jar包到工程中
###2.编写代码注册驱动,我们要让程序知道用的是哪个驱动包
###3.获取数据库连接对象 :Connection,这个对象就是本地java代码和数据库直接的对象
###4.定义sql,将来通过一些方式把sql发送到数据库,从而达到操作sql的要求
###5.获取执行sql语句的对象:Statement
###6.执行sql,方法调用返回一个返回值,接受返回的结果
###7.处理结果
###8.释放资源

代码:

package cn.itcast.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
/*
* JDBC
* */
public class JdbcDemo1 {
public static void main(String[] args) throws Exception {
//1,导入驱动jar包
// 1)复制mysql-connector-java-8.0.18到项目的libs目录下(mysql-connector-java-8.0.18要与mysql版本匹配,这里我用的mysql也是8.0.18版本)
// 2)右键libs选择添加为库(add as library),这一步才是真正的把jar包加入
Class.forName("com.mysql.cj.jdbc.Driver");//这是mysql8.0的更改内容,之前的mysql版本使用的是"com.mysql.jdbc.Drivar"。
// 3)获取数据库连接对象Connection类的conn
Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/db3", "root", "123456");
// 4)定义sql语句
String sql = "update emp set salary = 8500 where id = 1001";
// 5)获取执行sql的对象Statement类的stmt
Statement stmt = conn.createStatement();
// 6)执行sql,executeUpdate是修改语句
int count = stmt.executeUpdate(sql);
// 7)处理结果,打印接受返回的count值
System.out.println(count);
// 8)释放资源
stmt.close();
conn.close();
}
}

效果:

运行前:

运行后:

详解JDBC各个对象

1.DriverManager:驱动管理对象

    *功能:

1.注册驱动——



写代码使用:Class.forName("com.mysql.cj.jdbc.Driver");

那么这两个有啥关系呢?

我们把com.mysql.cj.jdbc.Driver类文件加载进内存,但是我们没有调用这个类,意味着这个类里的代码会随着类的加载而自动执行,也就是存在静态代码块来存放这些自动执行的代码。

通过查看源码发现:在com.mysql.cj.jdbc.Driver类中存在静态代码块:



代码显示它在注册驱动,而且真正注册驱动的是DriverManager,我们通过com.mysql.cj.jdbc.Driver类执行了DriverManager,这样比较简单。

从sql5开始,Class.forName("com.mysql.cj.jdbc.Driver");//sql8.0的新写法 这句话其实不需要写,因为



在这里相当于已经写了com.mysql.cj.jdbc.Driver这句话。

2.获取数据库连接——



这是一个静态的方法,可以通过类名直接调用。

参数:

url——指定连接的路径,IP端口与数据库的名称jdbc:mysql://ip地址(域名):端口号/数据库名称

如果连接的本机的mysql服务器,默认端口是3306,那么url可以简写为jdbc:mysql://数据库名称

user——用户名

password——密码

2.Connection:数据库连接对象

    Statement stmt = conn.createStatement();这个Statement 类的stmt 可以用来执行方法,int count = stmt.executeUpdate(sql);
###1.功能:
###1.获取执行sql的对象 ![](https://img2018.cnblogs.com/blog/1772487/201910/1772487-20191023161131213-281658183.png)
![](https://img2018.cnblogs.com/blog/1772487/201910/1772487-20191023161214542-464087519.png)
###2.管理事务 开启事务:
![](https://img2018.cnblogs.com/blog/1772487/201910/1772487-20191023161400794-181892992.png)
调用该方法设置参数为false,即开启事务
提交事务:
![](https://img2018.cnblogs.com/blog/1772487/201910/1772487-20191023161547203-906933181.png)
回滚事务:
![](https://img2018.cnblogs.com/blog/1772487/201910/1772487-20191023161617501-1136743706.png)

3.执行sql的对象

1.执行sql

1.

可以执行任意的sql,了解下,用的不多。

2.

执行的是DML语句(DML是增删改表中数据的语句),DDL语句(create,alter,drop)语句。int类型的返回值是影响的行数。

3.

执行的是DQL语句(查询语句),返回的是一个ResultSet类的结果集对象

4.ResultSet:结果集对象——封装结果集的对象

1.

next()方法,游标向下一行

默认游标:不能取数据

游标向下一行:可以把每一列的内容取出

获取数据的方法,一次获取(游标指向的某行中)某一列的数据。



getxx(),xx代表数据类型

2.

5.PreparedStatment:执行sql的对象

Java之JDBC操作数据库的更多相关文章

  1. Java使用Jdbc操作MySql数据库(一)

    这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...

  2. Java笔记(第七篇 JDBC操作数据库)

    JDBC是连接数据库和java程序的桥梁,通过JDBC API可以方便地实现对各种主流数据库的操作.学习java语言,必须学习JDBC技术,因为JDBC技术实在java语言中被广泛使用的一种操作数据库 ...

  3. Java基础之原生JDBC操作数据库

    前言 日常开发中,我们都习惯了使用ORM框架来帮我们操作数据库,本文复习.记录Java如何使用原生JDBC操作数据库 代码编写 封装几个简单方法 find查询方法 findOne查询方法 update ...

  4. Java的JDBC操作

    Java的JDBC操作 [TOC] 1.JDBC入门 1.1.什么是JDBC JDBC从物理结构上来说就是java语言访问数据库的一套接口集合,本质上是java语言根数据库之间的协议.JDBC提供一组 ...

  5. 用于JDBC操作数据库的公共类

    /* * @(#)CommonSql.java 2011-9-5 * * Copyright 2011 Bianjing,All rights reserved. */ import java.sql ...

  6. JDBC操作数据库的学习(2)

    在上一篇博客<JDBC操作数据库的学习(1)>中通过对例1,我们已经学习了一个Java应用如何在程序中通过JDBC操作数据库的步骤流程,当然我们也说过这样的例子是无法在实际开发中使用的,本 ...

  7. JDBC操作数据库的学习(1)

    单单对数据库的操作,比如说MySQL,我们可以在命令行窗口中执行,但是一般是应用程序要操作数据库,因此我们应该在程序中的代码上体现对数据库的操作,那么使用程序应用如何操作数据库呢?那就要使用到数据库的 ...

  8. JDBC操作数据库的三种方式比较

    JDBC(java Database Connectivity)java数据库连接,是一种用于执行上sql语句的javaAPI,可以为多种关系型数据库提供统一访问接口.我们项目中经常用到的MySQL. ...

  9. Spark Streaming通过JDBC操作数据库

    本文记录了学习使用Spark Streaming通过JDBC操作数据库的过程,源数据从Kafka中读取. Kafka从0.10版本提供了一种新的消费者API,和0.8不同,因此Spark Stream ...

随机推荐

  1. MVC默认提供了一个异常过滤器 HandleErrorAttribte特性

    这一篇记录MVC默认提供了一个异常过滤器 HandleErrorAttribte,下一篇介绍自定义异常过滤特性. 参考引用:https://www.cnblogs.com/TomXu/archive/ ...

  2. 什么是SolrCloud

    1.1 什么是SolrCloud SolrCloud(solr 云)是Solr提供的分布式搜索方案,当你需要大规模,容错,分布式索引和检索能力时使用 SolrCloud.当一个系统的索引数据量少的时候 ...

  3. oracle 数据恢复

    闪回表删除之前 flashback table t1 to before drop; 如果彻底删除表此方法无效 若要彻底删除表,则使用语句:drop table <table_name> ...

  4. 关键字group by 、 Having的 用法

    概述 GROUP BY我们可以先从字面上来理解,GROUP表示分组,BY后面写字段名,就表示根据哪个字段进行分组,如果有用Excel比较多的话,GROUP BY比较类似Excel里面的透视表. GRO ...

  5. 【leedcode】950. Reveal Cards In Increasing Order

    题目如下: In a deck of cards, every card has a unique integer.  You can order the deck in any order you ...

  6. ps查看和调整优先级

    主题ps查看和调整优先级 一查看优先级 nice值越大优先级越低 [root@centos72 ~]# ps axo pid,cmd,ni | head PID CMD NI 1 /usr/lib/s ...

  7. [CSP-S模拟测试]:赤(red)(WQS二分+DP)

    题目传送门(内部题38) 输入格式 每个输入文件包含多组测试数据.选手应当处理到文件结束($EOF$) 每一组数据包括$3$行. 第$1$行包含三个正整数$n,a,b$,表示有$n$只猫,$gyz$有 ...

  8. 【从0到1,搭建Spring Boot+RESTful API+Shiro+Mybatis+SQLServer权限系统】06、Mybatis+SQLServer集成

    1.增加POM依赖 注意pagehelper插件,我重写过,可以到我的这篇文章了解https://www.cnblogs.com/LiveYourLife/p/9176934.html <dep ...

  9. Linux系统Centos查看IP地址,不显示IP地址或者显示127.0.0.1

    1.桌面界面 右上角有个电脑的图标,鼠标悬停会显示no network connect 点击一下图标,选择连接的网络则ok 2.命令行界面 在命令行界面输入 vi  /etc/sysconfig/ne ...

  10. Mysql安装和简单设置

    MySQL安装文件分为两种,一种是msi格式的,一种是zip格式的.如果是msi格式的可以直接点击安装,按照它给出的安装提示进行安装(相信大家的英文可以看懂英文提示),一般MySQL将会安装在C:\P ...