分三层

第一章

1.三层架构

  界面层:和用户打交道,接收用户的请求参数明显是处理结果的(jsp,html,servlet)

  业务逻辑层:接收了界面层传递的数据,计算逻辑,调用数据库,获取数据

  数据访问层:就是访问数据库,执行对数据的查询,修改,删除等等的

  三层对应的包

  界面层:controller包(servlet)

  业务逻辑层:servlce包(XXXservlce类)

  数据访问层:dao包(XXXDao类)

  

  三层中类的的交互

    用户使用界面层-->业务逻辑层-->数据访问层(持久层)-->数据库(mysql)

  三层对应的处理框架

    界面层---servlet---springmvc(框架)

    业务逻辑层---service类---spring(框架) 1,2两个比较大 所以推荐先学习第三个

    数据访问层--dao类---mybatis(框架)

2,框架(Framework)

  框架是一个舞台,一个模板,

  模板:

    1.规定好了一些条款,内容。

·    2.加入自己的东西

  框架是一个模板

    1.框架中定义好了一些功能,这些功能是可用的

    2。可以加入项目中自己的功能,这些功能可以利用框架中写好的功能

  框架是一个软件,半成品的软件,定义好了一些基础功能,需要加入你的功能就是完整的,基础功能是可重复使用的,可升级的

  框架特点:

    1.框架一般不是全能的,不能做所有事情

    2. 框架是针对某一个领域有效,特长在一个方面,比如mybatis做数据库操作强,但是他不能做其他的

    3.框架是一个软件!

mabatis框架

  一个框架,早期叫做ibatis,代码在github

  mybatis是  MyBatis SQL Mapper Framework for Java(sql映射框架)

  1)sql mapper(sql映射)

    可以把数据库表中的一行数据  映射为一个java对象

    一行数据可以看作是一个java对象。操作这个对象,就相当于操作表中的数据

  2)Data Access Object(DAOs):数据访问,对数据库执行增删改查。

mybatis提供了哪些功能

  1.提供了创建Connection,Statement,Resultset的能力,不用开发人员创建这些对象

  2.它提供了执行sql语句的能力,不用你执行sql

  3.提供了循环sql,把sql的结果转为java对象,List集合的能力

    while(rs,next()){

      Student stu = new Student();

      stu.setId(rs.getInt('"id"));

      stu,setName(rs.getString(""name));

      stu.setAge(rs.getInt("age"));

      stuList.add(stu);

  }

  4.提供了关闭资源的能力,不用你关闭Connection,Statement,Resultset

  开发人员做的是,提供sql语句(站在巨人的肩膀上哈哈哈哈哈)

  最后是开发人员提供sql语句--->mybatis处理sql--->开发人员得到List计集合或java对象(表中数据)

总结:mybatis是一个sql映射框架,提供的数据库的操作能力。增强的JDBC

使用mybatis让开发人员集中精神写sql就可以了,而不必关心Connection,Statement,Resultset等的创建,销毁,sql的执行。

Mybatis初步认识的更多相关文章

  1. Mybatis初步详细配置

    1.Mybatis所需包 下载地址:https://github.com/mybatis/mybatis-3/releases,其中log4j是日志包,mysql是数据库所需包,需自行下载 2.项目结 ...

  2. mybatis 初步使用(IDEA的Maven项目, 超详细)

    目录 创建 Maven 项目 Maven配置 pom.xml 创建数据库 配置Mybatis 配置mybatis的XML文件 创建实体类和对应的Mapper.xml 测试 源码 @ 创建 Maven ...

  3. mybatis初步理解

    mybatis概念   mybatis 是一款轻量级的orm的数据持久框架,封装jdbc 对开发提供了便利,但是性能会比jdbc低,从开发的角度来说,现在是比较流行的 掌握上比较容易,也支持缓存,级联 ...

  4. Spring 14: Spring + MyBatis初步整合开发

    SM整合步骤 预期项目结构 新建数据库和数据表 springuser.sql脚本如下 create database ssm; use ssm; create table users( userid ...

  5. mybatis初步配置容易出现的问题

    The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. You ...

  6. mybatis 缓存的使用, 看这篇就够了

    目录 1 一级缓存 1.1 同一个 SqlSession 1.2 不同的 SqlSession 1.3 刷新缓存 1.4 总结 2 二级缓存 2.1 配置二级缓存 2.2 使用二级缓存 2.3 配置详 ...

  7. mybatis源码-解析配置文件(三)之配置文件Configuration解析

    目录 1. 简介 1.1 系列内容 1.2 适合对象 1.3 本文内容 2. 配置文件 2.1 mysql.properties 2.2 mybatis-config.xml 3. Configura ...

  8. mybatis源码-解析配置文件(二)之解析的流程

    目录 1. 简介 2. 配置文件解析流程分析 2.1 调用 2.2 解析的目的 2.3 XML 解析流程 2.3.1 build(parser) 2.3.2 new XMLConfigBuilder( ...

  9. mybatis源码-解析配置文件(一)之XML的DOM解析方式

    目录 简介 Java 中 XML 文件解析 解析方式 DOM 解析 XML 新建 XML 文件 DOM 操作相关类 Java 读取 XML 文件 一起学 mybatis @ 简介 在之前的文章< ...

随机推荐

  1. CentOS环境下搭建青岛大学OJ

    1.安装必要的依赖sudo yum updatesudo yum -y install epel-releasesudo yum -y install python-pipsudo yum clean ...

  2. LaTeX 环境安装&编译器配置

    推荐网站:https://www.latexstudio.net/articles/ (基本所有的latex疑惑都可以在这里得到解决) 入门视频:两小时短小精悍,让你轻松入门,https://www. ...

  3. Codeforces Round #647 (Div. 2) D. Johnny and Contribution(BFS)

    题目链接:https://codeforces.com/contest/1362/problem/D 题意 有一个 $n$ 点 $m$ 边的图,每个结点有一个从 $1 \sim n$ 的指定数字,每个 ...

  4. Codeforces Round #644 (Div. 3)

    比赛链接:https://codeforces.com/contest/1360 A - Minimal Square 题意 计算能包含两个 $a \times b$ 矩形的最小正方形的面积. 题解 ...

  5. Pokémon Army (easy version) CodeForces - 1420C1 dp

    题意: 给你一个长度为n个序列v,你需要从中找一个子序列.这个子序列的值等于:子序列中奇数下标的值-偶数下标的值 你需要使得这个值尽可能大,让你输出这个最大值 题解: dp[i][0]表示:在原序列从 ...

  6. 灯光照射,圆形探测类问题(解题报告)<分层差分><cmath取整>

    题目描述 一个n*n的网格图上有m个探测器,每个探测器有个探测半径r,问这n*n个点中有多少个点能被探测到. 输入输出格式 输入格式: (1<=r<n<=5000) (1<=m ...

  7. A. Little Elephant and Interval

    The Little Elephant very much loves sums on intervals. This time he has a pair of integers l and r ( ...

  8. A. Little Pony and Expected Maximum

    Twilight Sparkle was playing Ludo with her friends Rainbow Dash, Apple Jack and Flutter Shy. But she ...

  9. Codeforces Round #575 (Div. 3) F. K-th Path

    传送门 题意: 这道题把我看得懵懵的(不敢相信),其实就是给你n个点和m条边(无向图),你要找出来任意两点之间的的最短距离,然后再从其中找出来第k个最小值 题解: 正常思维就是floyd多源最短路算法 ...

  10. 大数据开发-从cogroup的实现来看join是宽依赖还是窄依赖

    前面一篇文章提到大数据开发-Spark Join原理详解,本文从源码角度来看cogroup 的join实现 1.分析下面的代码 import org.apache.spark.rdd.RDD impo ...