java企业级开发SSM

spring

  1. Bean的作用域:

    类别说明
    singleton在Spring容器中仅存在一个共享的Bean实例
    prototype每次从容器中都获取一个新的实例
    request每次HTTP请求都会创建一个新的Bean实例
    session同一个HTTP请求共享一个Bean实例
    global session同一个全局Session共享一个Bean实例
  2. Bean属性注入:

    1. 属性注入
    2. 构造注入
  3. AOP

    1. 增强(Advice)
    2. 切入点(Pointcut)
    3. 连接点(Joinpoint)
    4. 切面(Aspect)
    5. 代理(Proxy)
    6. 目标对象(Target)
    7. 织入(Weaving)
  4. 注解:

    1. @Component : 普通组件
    2. @Repository :用于标注DAO类
    3. @Service :用于标注业务类
    4. @Controller :用于标注控制器类
  5. 使用**@Autowired**注解实现Bean的自动装配,默认按类型匹配,可以使用@Qualifier指定Bean的名称

  6. 使用**@Scope**注解指定Bean的作用域

  7. @Resource默认按照ByName自动注入:

    1. 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常。
    2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常。
    3. 如果指定了type,则从上下文中找到类似匹配的唯一bean进行装配,找不到或是找到多个,都会抛出异常。
    4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配。

SpringMVC

  1. 处理请求流程

    image-20210509231551730

    1. 请求抵达web.xml
    2. Web.xml找到DispatcherServlet
    3. DispatcherServlet调用组件解析SpringMVC的配置文件
    4. 将配置文件的解析结果保存在HandlerMap当中(Controller,拦截器)
    5. 配请求,寻找对应的Handler,即交互层Controller,执行该Controller
    6. Controller调用Service获取业务数据模型Model
    7. Service返回的业务模型,由Controller完成组装,组装成ModelAndView。即,模型和视图。
    8. Controller将ModelAndView返回给DispatcherServlet,DispatcherServlet根据返回的视图信息,将对应的数据模型,渲染到视图上,将视图的渲染结果交还给客户端。

MyBatis

  1. 核心接口和类的结构

    image-20210509232913405

  2. SQL映射文件的几个顶级元素

    1. cache - 配置给定命名空间的缓存
    2. cache-ref – 从其他命名空间引用缓存配置
    3. resultMap –用来描述数据库结果集和对象的对应关系
    4. sql – 可以重用的SQL块,也可以被其他语句引用
    5. insert – 映射插入语句
    6. update – 映射更新语句
    7. delete – 映射删除语句
    8. select – 映射查询语句
  3. Select

    属性描述
    id在命名空间中唯一的标识符,可以被用来引用这条语句。
    parameterType将会传入这条语句的参数类的完全限定名或别名。
    resultType从这条语句中返回的期望类型的类的完全限定名或别名。注意集合情形,那应该是集合可以包含的类型,而不能是集合本身。使用resultType或resultMap,但不能同时使用。
    resultMap命名引用外部的resultMap
    flushCache将其设置为true,不论语句什么时候被调用,都会导致缓存被清空。默认值:false。
    useCache将其设置为true,将会导致本条语句的结果被缓存。默认值:true。
    timeout这个设置驱动程序等待数据库返回请求结果,并抛出异常时间的最大等待值。默认不设置(驱动自行处理)。
    fetchSize这是暗示驱动程序每次批量返回的结果行数。
    statementTypeSTATEMENT,PREPARED或CALLABLE的一种。让MyBatis选择使用Statement,PreparedStatement或CallableStatement。默认值:PREPARED。
    resultSetTypeFORWARD_ONLY|SCROLL_SENSITIVE|SCROLL_INSENSITIVE中的一种。默认是不设置(驱动自行处理)
  4. 动态SQL:if

    image-20210509233428792

  5. 动态SQL:choose、when、otherwise

    image-20210509233506053

  6. 动态SQL:trim、where、set

    image-20210509233602403

    image-20210509233632829

    image-20210509233707933

  7. 动态SQL:foreach

    image-20210509233726569

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

隐 风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值