SQL和JDBC

基本查询SQL的执行顺序
要学好查询SQL就必须掌握SQL的执行顺序。后执行的子句,可以使用前执行子句的计算结果、定义的别名等。

顺序为
1、执行FROM
2、WHERE条件过滤
3、GROUP BY分组
4、执行SELECT投影列
5、HAVING条件过滤
6、执行ORDER BY排序
7、执行limit语句,返回限定行

--------------------------JDBC------------------------------------------------------------

(1)什么是JDBC
JDBC全称是java DataBase Connectivity,是java连接数据库的一套API。

JDBC是java连接数据库的一套API,也是一套标准。该标准中定义了一系列的接口,
由数据库厂商根据自身数据库的特点分别实现,由开发者根据接口调用实现类的方法。
这样,无论连接什么样的数据库都是一套API,开发者开发时,可以屏蔽不同数据库的差异。

(2)驱动包
驱动包是数据库厂商针对JDBC规范所写的实现类

连接不同数据库时,应该使用不同数据库厂商提供的驱动包

(3)JDBC的开发流程:
建立连接
执行SQL语句
关闭连接

sql注入:
在执行SQL语句时,如果通过拼接字符串方式插入SQL语句的值,当值中有非法字符,或者SQL语句关键字时,
会导致SQL语句语法错误,或执行结果不正确的情况。这称为SQL注入

Statement和PrepareStatements的区别
Statement是PrepareStatements的父接口。在执行SQL语句时,
只能通过拼接字符串方式插入SQL语句的值,不但效率低,而且容易引起SQL注入。

PrepareStatements提供了占位符方式插入SQL语句的值,SQL语句只会编译一次,效率较高。
而且无论是什么值都当字符串处理,不会引起SQL注入。

-------------数据库----------------------------------------------------------------------------
数据库三要素范式;
范式一,行不重复,列不可再分。
范式二,非主依主。非主键列必须依赖于主键列。
范式三,非主独立。非主键列之间不能有依赖关系。

----------模式-----------------------------------------------------------------------------------
架构模式:
架构是指一个软件系统整体的组织结构
架构模式描述软件系统的组织结构的一些规则和指南
通过这些规则和指南,我们可以把预定的职责明确的子系统有效地组织起来

设计模式:
设计模式描述的是在软件系统的某一局部不断重现的核心解决方案。
这些解决发案以完善的设计结构出现,可以被应用到以后出现的类似的环境中。

三层架构模式
从低到高分为:表示层、业务逻辑层、数据访问层(持久层)

数据访问层:完成内存和数据库之间的数据交互。
业务逻辑层:完成内存数据的业务处理操作。
表示层:完成数据的展示,并提供界面供用户进行数据的录入。

数据持久层采用DAO模式(Data Access O Dbject)
建立实体类和数据库表进行映射,也就是哪个类对应哪个表,哪个属性对应哪个列(ORM)
数据持久层的目的,就是完成对象数据和关系数据的转换。

业务逻辑层采用事务脚本模式。
将一个业务中所有的操作封装成一个方法。(脚本)
保证一个业务方法中,所有的数据库更新操作作同时成功,或同时失败。
不允许出现部分成功,部分失败,这样引起数据混乱的操作。(事务)

表示层采用MVC模式。
M:模型。也就是实体类,负责数据的封装和数据的传输。

V:视图。也就是GUI窗体和GUI组件,负责提供界面和数据进行数据交互,以及数据的展示。

C:控制。也就是事件处理,负责业务流程的控制。

------------------------业务接口-------------------------------------------------------------------
业务接口设计原则:一个实体类一个接口,一次提交一个业务方法。方法的参数来自表示层

持久接口设计原则:一个实体类一个持久接口,一次数据库操作一个持久方法。

-----------接口---------------------------------------------------------------------------------------
接口隔离原则:使用专门的接口比用统一接口,便于项目的组织和分工。不要让开发者面对自己用不到的方法。

业务接口设计原则:一个实体类一个业务接口,一次提交一个业务方法,业务方法的参数来自表现层。

持久接口设计原则:一个实体类一个持久接口,一次数据库操作一个持久方法。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值