JDBC连接数据库

3 篇文章 0 订阅
1 篇文章 0 订阅

1.JDBC:
(1).Java Data Base Connectivity(Java数据库连接),官方解释它是Java编程语言和广泛的数据库之间独立于数据库的连接标准的Java API,根本上说JDBC是一种规范,它提供的接口,一套完整的,允许便捷式访问底层数据库。可以用JAVA来写不同类型的可执行文件:JAVA应用程序、JAVA Applets、Java Servlet、JSP等,不同的可执行文件都能通过JDBC访问数据库,又兼备存储的优势。简单说它就是JAVA与数据库的连接的桥梁或者插件,用JAVA代码就能操作数据库的增删改查、存储过程、事务等。
(2).工作原理图:JAVA具备天生跨平台的优势,它就提供了JDBC的接口API,具体的实现由不同的生产产商决定。这样,数据库生产产商都根据JAVA API去实现各自的应用驱动。
在这里插入图片描述
2.JAVA Eclipse 加载外部架包:
(1).在项目中右键选择Build Path -->Configure BuildPath…
在这里插入图片描述
(2). Libraries----->ADD External JARs…添加要引用的架包。
在这里插入图片描述
(3).第一步加载驱动,第二步获取数据库连接,获取数据库连接之前要连接字符串。
(4).连接字符串jdbc:mysql//代表mysql、localhost:3306/代表本地服务器名称及数据库的端口号,也可以用127.0.0.1代表本地服务器、demo_db_2021?代表数据库名称、characterEncoding=UTF-8&表示使用的字符编码、serverTimezone=Asia/Shanghai代表mysql8.0之后必须加的服务器时区,当前的是亚洲/上海、&useSSL=false代表是否加密,当前为不加密。
在这里插入图片描述
(5).连接数据库,而且连接完数据库一定要关闭数据库连接。
在这里插入图片描述
(6).创建Statement,不使用标志的方法创建,原因是该SQL是使用字符串拼接方式无法预防SQL输入在字符串拼接的时候本该拼接的是’userBame1’但是输出时候如果被OR拼接结果会导致所有数据库数据被查询出来导致不安全且加载速度慢。
在这里插入图片描述
在这里插入图片描述

(7).ResultSet(rs):它是一个迭代器,用于检索查询数据,JDBC索引从1开始没有从0开始的。
在这里插入图片描述

3.Mysql 驱动和连接字符串
版本 驱动 连接字符串
在这里插入图片描述

4.常用接口
(1).提供的接口包括:JAVA API:提供对JDBC的管理链接;JAVA Driver API:支持JDBC管理到驱动器连接。
(2).DriverManager:这个类管理数据库驱动程序的列表,查看加载的驱动是否符合JAVA Driver API的规范。
(3).Connection:与数据库中的所有的通信是通过唯一的连接对象。
(4).Statement/PreparedStatement:把创建的SQL对象,转而存储到数据库当中。
(5).ResultSet:它是一个迭代器,用于检索查询数据。
5.事务
(1).原子性(Atomicity):事务是应用中最小的执行单位,事务是应用中不可再分的最小逻辑执行体。
(2).一致性(Consistency):事务执行的结果,必须使数据库从一致性状态,变到另一个一致性状态,当数据库只包含事务成功提交的结果时,数据库处于一致性状态,要么一起成功要么就失败。
(3)隔离性(Isolation):各个事务的执行互不干扰,任意一个事务的内部操作对其他并发的事务都是隔离的。
(4).持续性(Durability):持续性也称为持久性(Persistence)指事务一旦提交,对数据所做的任何改变都要记录到永久存储器中,通常就是保存进物理数据库。
(5).事务第一步,开启事务,关闭JDBC的自动提交,默认为true。
在这里插入图片描述
(6).第一次执行修改,然后执行第二次修改,进行数据回滚,ID已经被添加然后被回收,所以数据库会跳过一条数据
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值