目录

关于mysql,需要掌握的基础(二):JDBC和DAO层

1、了解jdbc是什么?

2、加载注册驱动:为什么Class.forName(“com.mysql.jdbc.Driver”); 一行代码就可以完成加载、注册驱动操作?

3、原始方式-获取连接对象:

4、JDBC 操作数据库的步骤:【贾琏欲执事】

5、了解DAO层是什么?

6、DAO诞生的背景:

■ 以前我们是把数据库的操作代码编写到客户端里:

■ DAO封装了数据的增删改操作,数据访问接口。

7、语句对象PreparedStatement 和Statement 的比较:

8、开发中获取自动生成主键:

9、掌握连接池(也叫数据源DataSource)-获取连接对象

✿ 从jdbc—》dao层—》myBatis:

jdbc封装的dao层的模板类jdbcTemplate来操作数据库:


关于mysql,需要掌握的基础(二):JDBC和DAO层

1、了解jdbc是什么?

■ java DataBase Connectivity,java连接数据库,通过java代码操作数据库,可以进行CRUD

执行SQL语句的java API,JDBC 本身是java连接数据库的一个标准,【需要加载连接驱动程序-连接数据库的jar包】,jdbc是进行数据库连接的抽象层,由java编写的一组类和接口组成,接口的实现由各个数据库厂商来完成。

2、加载注册驱动:为什么Class.forName(“com.mysql.jdbc.Driver”); 一行代码就可以完成加载、注册驱动操作?

① Class.forName(); 会把com.mysql.jdbc.Driver 这份字节码

② 当一份字节码别加载进JVM时,就会执行该字节码中的静态代码块,在该静态代码块中有: java.sql.DriverManager.

3、原始方式-获取连接对象:

  1):加载注册驱动:

Class.forName(“com.mysql.jdbc.Driver”);

   2):获取连接:通过DriverManger类的getConnection方法来获取连接对象:

              Connection conn = DriverManger.getConnection(url,username, password);

4、JDBC 操作数据库的步骤:【贾琏欲执事】

1)贾:加载注册驱动

2)琏:获取连接对象

3)欲:创建语句对象

4)执:执行SQL语句

5)事:释放资源

5、了解DAO层是什么?

■ Data Access Object 数据访问对象,跟jdbc一样本身是一个接口,封装了数据的增删改查(CRUD)操作。

6、DAO诞生的背景:

■ 以前我们是把数据库的操作代码编写到客户端里:

跟业务代码混杂在一起;②而且每次操作数据库时都需要重复书写代码。

■ DAO封装了数据的增删改操作,数据访问接口。

7、语句对象PreparedStatement 和Statement 的比较:

■ 拼接sql方面和安全方面【注入问题】

8、开发中获取自动生成主键:

■ 获取主键的作用:

---注册时,一次性填写过多信息,不友好,分成两次填写呗【**获取主键,将其传递给第二个填写注册信息界面**】

原始方式-获取主键:

Statement st = null;
st.executeUpdate(sql.toString(), Statement.RETURN_GENERATED_KEYS);
//去获取自动生成的主键
ResultSet keyRs = st.getGeneratedKeys();
if(keyRs.next()) {
Long id = keyRs.getLong(1);//获取第一列
System.out.println(id);
return id;
}

9、掌握连接池(也叫数据源DataSource)-获取连接对象

常用的连接池中的druid(德鲁伊):阿里巴巴提供的,号称世界最好的连接池

 

✿ 从jdbc—》dao层—》myBatis:

jdbc封装的dao层的模板类jdbcTemplate来操作数据库:

//增删改操作模板: public static update(String sql, Object...params)
//查询操作模板:public static <T> T query(String sql, IResultSetHandler rsh,Object...params)
//----------------------------------------------------------------------------- //还封装了BeanHandler、BeanListHandler
BeanHandler 处理结果类[结果集只有一行数据,把一行结果集数据封装成一个对象]
BeanListHandler 处理结果类[结果集有多行数据,把每一行结果集数据封装成一个对象,存储到List集合中]

● 使用BeanHandler和BeanListHandler要注意,对象的属性名和表中的列名需要相同,不同报错。

jdbc--->jdbc模板(通用结果集处理器[需要保证类的属性名和表名相同])----》ORM框架(MyBatis框架)

关于mysql,需要掌握的基础(二):JDBC和DAO层的更多相关文章

  1. Java通过JDBC 进行Dao层的封装

    前言 前面有一章节,我专门讲解了Java通过JDBC 进行MySQL数据库操作,这主要讲解了MySQL数据库的连接和简单的操作,但是在真正的Java项目中,我们要不断的和数据库打交道,为了提高数据库操 ...

  2. sping整合hibernate之二:dao层开发

     在上一篇日志中将hibernate的会话工厂sessionFactory注入到了spring的容器中,但这样还不够,因为hibernate的增删改查是要使用事务机制的, 所以还要在spring中配置 ...

  3. jdbc基础 (二) 通过properties配置文件连接数据库

    csdn博文地址:jdbc基础 (二) 通过properties配置文件连接数据库 上一篇描述了对mysql数据库的简单操作,下面来看一下开发中应该如何灵活应用. 因为jdbc对数据库的驱动加载.连接 ...

  4. 02 mysql 基础二 (进阶)

    mysql 基础二 阶段一 表约束 1.not null 非空约束 例子: create table tb1( id int, name varchar(20) not null ); 注意 空字符不 ...

  5. 数据库及MYSQL基础(3)-JDBC

    教学视频链接:https://edu.aliyun.com/course/1694?spm=5176.11400004.0.0.29254768sg2H5P 程序文件链接:https://pan.ba ...

  6. 写给自己看的Linux运维基础(二) - Apache/MySQL. 安全设置. 定时任务

    本文使用环境为CentOS 6 Apache, PHP, MySQL等常用软件均可通过yum安装包获取 yum install httpd php mysql-server # mysql: 客户端; ...

  7. java基础(11) -JDBC

    java基础(11) -JDBC jdbc 1.装载驱动 载入跟数据库建立连接的驱动 /* sql server: String className ="com.microsoft.sqls ...

  8. MySQL中索引的基础知识

    本文是关于MySQL中索引的基础知识.主要讲了索引的意义与原理.创建与删除的操作.并未涉及到索引的数据结构.高性能策略等. 一.概述 1.索引的意义:用于提高数据库检索数据的效率,提高数据库性能. 数 ...

  9. Java数据库基础(JDBC)

    JDBC(Java Data Base Connectivity):SUN公司为了简化统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC: 这样应用程序就不需要关注数据库底层的详细 ...

随机推荐

  1. 1021 - Painful Bases

    1021 - Painful Bases   PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 MB As ...

  2. <数据结构>XDOJ314.完全二叉树的子树

    问题与解答 问题描述 对一棵完全二叉树,采用自上而下.自左往右的方式从1开始编号,我们已知这个二叉树的最后一个结点是n,现在的问题是结点m所在的子树一共包括多少个结点? 输入格式 输入数据包括多行,每 ...

  3. 基于Spring MVC + Spring + MyBatis的【银行卡系统】

    资源下载:https://download.csdn.net/download/weixin_44893902/45604256 练习点设计: 删除.新增 一.语言和环境 实现语言:JAVA语言. 环 ...

  4. JDK、JVM和JRE三者间的关系,及JDK安装路径下的文件夹说明

    JDK的全称是Java SE Development Kit, 即Java标准开发包,是Sun公司提供的一套用于开发Java应用程序的开发包, 它提供了编译.运行Java查询所需的各种工具和资源,包括 ...

  5. ActiveMQ基础教程(三):C#连接使用ActiveMQ消息队列

    接上一篇:ActiveMQ基础教程(二):安装与配置(单机与集群) 安装部署好集群环境:192.168.209.133:61616,192.168.209.134:61616,192.168.209. ...

  6. 『无为则无心』Python函数 — 31、命名空间(namespace)

    目录 1.什么是命名空间 2.三种命名空间 3.命名空间查找顺序 4.命名空间的生命周期 5.如何获取当前的命名空间 1.什么是命名空间 命名空间指的是变量存储的位置,每一个变量都需要存储到指定的命名 ...

  7. 利用js 引用的方式 鼠标经过弹出效果

    js引用的是此网站代码: https://www.cnblogs.com/jq-growup/p/15609469.html <!DOCTYPE html> <html lang=& ...

  8. Linux的六种查找命令

    http://www.ruanyifeng.com/blog/2009/10/5_ways_to_search_for_files_using_the_terminal.html 1. find fi ...

  9. gitlab修改(重置)root用户密码

    gitlab修改(重置)root用户密码 1.使用root权限登录到服务器. 2.使用以下命令启动控制台:  gitlab-rails console production 该命令有时候启动比较慢,需 ...

  10. 面试题68 - II. 二叉树的最近公共祖先

    <搜索树结点> <获取路径> 题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q ...