目录

关于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. 晴天小猪历险记之Hill(Dijkstra优先队列优化)

    描述 这一天,他来到了一座深山的山脚下,因为只有这座深山中的一位隐者才知道这种药草的所在.但是上山的路错综复杂,由于小小猪的病情,晴天小猪想找一条需时最少的路到达山顶,但现在它一头雾水,所以向你求助. ...

  2. 常见分布式唯一ID生成策略

    方法一: 用数据库的 auto_increment 来生成 优点: 此方法使用数据库原有的功能,所以相对简单 能够保证唯一性 能够保证递增性 id 之间的步长是固定且可自定义的 缺点: 可用性难以保证 ...

  3. Visualizing Data using t-SNE

    目录 概 主要内容 Stochastic Neighbor Embedding t-SNE Der Maaten L V, Hinton G E. Visualizing data using t-S ...

  4. Simplicial principal component analysis for density functions in Bayes spaces

    目录 问题 上的PCA Hron K, Menafoglio A, Templ M, et al. Simplicial principal component analysis for densit ...

  5. Winform中使用HttpClient与后端api服务进行交互

    前端js可以使用ajax.axios发出http请求 在c#中winform.控制台等可以通过WebRequest.WebClient.HttpClient 有关三个类的性能对比大家可以自己搜一下,这 ...

  6. <学习opencv>绘画和注释

    /*=========================================================================*/ // 绘画 和 注释 /*========= ...

  7. 如何通过Navicat远程访问宝塔面板安装的MySQL数据库

    运行环境描述 阿里云ECS 系统:CentOS Linux 7.4.1708 (Core)宝塔面板: 6.9.0数据库:MySQL 5.7.19 Navicat 远程连接 Navicat报错信息: 错 ...

  8. ANT之macrodef

    macrodef 的意思是宏定义, 可以理解为自定义函数. 对于大型部署,可以提高代码利用率. 为了方便理解,请看代码示例: <macrodef name="macro-send-fi ...

  9. 创客系列教程——认识LED灯

    认识LED灯 一.初识LED灯   LED灯是一种能够将电能转化为可见光的固态的半导体器件,它可以直接把电转化为光.LED灯逐步融入到生活中的方方面面:室内外的照明.电子指示牌.酷炫的舞台灯光.车辆的 ...

  10. python驱动SAP完成数据导出(二)

    在上一篇 python驱动SAP完成数据导出(一)中,我们提到了数据导出前,SAP布局的重要性,如何识别当前布局模式,以及如何切换到想要的布局.本篇小爬将着重讲讲数据导出的注意事项. 我们可以通过如下 ...