关于mysql,需要掌握的基础(二):JDBC和DAO层
目录
2、加载注册驱动:为什么Class.forName(“com.mysql.jdbc.Driver”); 一行代码就可以完成加载、注册驱动操作?
7、语句对象PreparedStatement 和Statement 的比较:
9、掌握连接池(也叫数据源DataSource)-获取连接对象
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层的更多相关文章
- Java通过JDBC 进行Dao层的封装
前言 前面有一章节,我专门讲解了Java通过JDBC 进行MySQL数据库操作,这主要讲解了MySQL数据库的连接和简单的操作,但是在真正的Java项目中,我们要不断的和数据库打交道,为了提高数据库操 ...
- sping整合hibernate之二:dao层开发
在上一篇日志中将hibernate的会话工厂sessionFactory注入到了spring的容器中,但这样还不够,因为hibernate的增删改查是要使用事务机制的, 所以还要在spring中配置 ...
- jdbc基础 (二) 通过properties配置文件连接数据库
csdn博文地址:jdbc基础 (二) 通过properties配置文件连接数据库 上一篇描述了对mysql数据库的简单操作,下面来看一下开发中应该如何灵活应用. 因为jdbc对数据库的驱动加载.连接 ...
- 02 mysql 基础二 (进阶)
mysql 基础二 阶段一 表约束 1.not null 非空约束 例子: create table tb1( id int, name varchar(20) not null ); 注意 空字符不 ...
- 数据库及MYSQL基础(3)-JDBC
教学视频链接:https://edu.aliyun.com/course/1694?spm=5176.11400004.0.0.29254768sg2H5P 程序文件链接:https://pan.ba ...
- 写给自己看的Linux运维基础(二) - Apache/MySQL. 安全设置. 定时任务
本文使用环境为CentOS 6 Apache, PHP, MySQL等常用软件均可通过yum安装包获取 yum install httpd php mysql-server # mysql: 客户端; ...
- java基础(11) -JDBC
java基础(11) -JDBC jdbc 1.装载驱动 载入跟数据库建立连接的驱动 /* sql server: String className ="com.microsoft.sqls ...
- MySQL中索引的基础知识
本文是关于MySQL中索引的基础知识.主要讲了索引的意义与原理.创建与删除的操作.并未涉及到索引的数据结构.高性能策略等. 一.概述 1.索引的意义:用于提高数据库检索数据的效率,提高数据库性能. 数 ...
- Java数据库基础(JDBC)
JDBC(Java Data Base Connectivity):SUN公司为了简化统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC: 这样应用程序就不需要关注数据库底层的详细 ...
随机推荐
- 晴天小猪历险记之Hill(Dijkstra优先队列优化)
描述 这一天,他来到了一座深山的山脚下,因为只有这座深山中的一位隐者才知道这种药草的所在.但是上山的路错综复杂,由于小小猪的病情,晴天小猪想找一条需时最少的路到达山顶,但现在它一头雾水,所以向你求助. ...
- 1030 - Discovering Gold
1030 - Discovering Gold PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 M ...
- Reproducing Kernel Hilbert Space (RKHS)
目录 概 主要内容 RKHS-wiki 概 这里对RKHS做一个简单的整理, 之前的理解错得有点离谱了. 主要内容 首先要说明的是, RKHS也是指一种Hilbert空间, 只是其有特殊的性质. Hi ...
- Chapter 11 Why Model ?
目录 11.1 Data cannot speak for themselves 11.2 Parametric estimators of the conditional mean 11.3 Non ...
- A Tutorial on Energy-Based Learning
目录 概 主要内容 损失函数 Energy Loss Generalized Perceptron Loss Generalized Margin Loss Hinge Loss Log Loss L ...
- CS5266参数|Capstone CS5266|CS5266应用方案
随着目前手机.笔电和平板类产品都是用的Type-C接口,特别是苹果类的笔电和平板就只有一个Type-C接口,在很多工作.学习.娱乐中突显很多不方便的情况,别是需要一些其他的功能如:鼠标键盘接口USB2 ...
- 替代联阳IT6564方案|CS5262替代IT6564|设计DP转HDMI+VGA扩展坞方案
联阳IT6564:带嵌入式MCU的单芯片4通道DisplayPort1.2到HDMI2.0/VGA转换器 联阳IT6564是一种高性能的单芯片显示端口到HDMI和VGA转换器.IT6564FN结合Di ...
- vue源码中computed和watch的解读
computed 会基于其内部的 响应式依赖 进行缓存. 只在相关 响应式依赖发生改变 时 它们才会重新求值. 可以在将模板中使用的常量放在计算属性中. watch 监听数据变化,并在监听回调函数中返 ...
- Eclipse 常用快捷键大全
15 个 Eclipse 常用开发快捷键使用技巧 1.alt+? 或 alt+/:自动补全代码或者提示代码 2.ctrl+o:快速outline视图 3.ctrl+shift+r:打开资源列表 4.c ...
- VUE的学习_从入门到放弃(一)
一.vue的功能及作用 工作方式如下 1.不用操作DOM 2.单页面应用web项目 简称:SPA 3.当下各种新框架都采用的类似Vue或者类似React的语法去作为主语法,微信小程序/MpVue... ...