zoukankan      html  css  js  c++  java
  • 19-08-19

    ※1※数据库的存储过程(Stored Procedure):

    参考链接:https://www.imooc.com/article/19811   

    ※什么是数据库的存储过程:

          是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。

    为什么要使用存储过程??(存储过程的好处/优点)

    ♩:实现了模块化编程。
    ♩:调用一次以后,相关信息就保存在内存中,下次调用时可以直接执行。
    ♩:存储过程可以接受输入参数并可以返回输出值。
    ♩:存储过程具有对数据库立即访问的功能。
    ♩:使用存储过程可以加快程序的运行速度。
    ♩:使用存储过程可以减少网络流量。
    ♩:使用存储过程可以提高数据库的安全性。
    ※存储过程的分类:

    ♩:数据库系统存储过程:数据库自带

    ♩:用户自定义数据库存储过程:由用户根据需要自定义

    ※2※谈谈你理解的事务:

    • 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
    • 事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。

    一个事务从开始到执行会经历以下三个阶段:

    • 开始事务。
    • 命令入队。
    • 执行事务

    参考链接:https://blog.csdn.net/JIESA/article/details/51317164

    ※事务的特性(ACID):对于一个事务必须遵守ISO/IEC所定制的ACID原则

    Atomicity(原子性)、Consistency(一致性)、Isolation(隔离性)、Durability(持久性)

    ※事务产生的原因:

    由事务的隔离特性,多事务同时并发执行对同一数据库的记录进行操作的时候,会产生如下问题:

    ♩:数据丢失:第一次提交的数据被第二次提交的数据覆盖,导致数据丢失

    ♩:不可重复读两个并发的事务,“事务A:singo消费”、“事务B:singo的老婆网上转账”,事务A事先读取了数据,事务B紧接了更新了数据,并提交了事务,而事务A再次读取该数据时,数据已经发生了改变。

    ♩:幻读:singo的老婆工作在银行部门,她时常通过银行内部系统查看singo的信用卡消费记录。有一天,她正在查询到singo当月信用卡的总消费金额 (select sum(amount) from transaction where month = 本月)为80元,而singo此时正好在外面胡吃海塞后在收银台买单,消费1000元,即新增了一条1000元的消费记录(insert transaction ... ),并提交了事务,随后singo的老婆将singo当月信用卡消费的明细打印到A4纸上,却发现消费总额为1080元,singo的老婆很诧异,以为出 现了幻觉,幻读就这样产生了。


    ♩:脏读:
    指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。

    ※事务隔离级别(由低到高):

    ※3※如何实现对未登录网页的数据统计:

    参考链接:https://blog.csdn.net/yongh701/article/details/43969143

    ※利用Application对象实现访问人数统计功能:

    问题:当服务器重启时,由于Application会被销毁,重新建立,则人数统计会清零

    解决:统计数据人数是添加数据库功能,这样无论服务器需要重启或者遭遇停机,不会造成访问人数的丢失

    ♫:统计一个页面的访问人数,而且这个访问人数,在服务器重启之后不会丢失

    基本准备:

    ♩:在数据库中添加字段用于记录访问人数,无主键,不自增,默认为零

    ♩:添加MySql依赖

    ♩:在web.xml中添加如下字段:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
        http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
        <context-param>
         <--. 启动一个WEB项目的时候,容器(如:Tomcat)会去读它的配置文件web.xml.读两个节点: <listener></listener> 和 <context-param></context-param>--> <param-name>url</param-name> <param-value>jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=utf8&amp;useOldAliasMetadataBehavior=true</param-value> </context-param> <context-param> <param-name>user</param-name> <param-value>root</param-value> </context-param> <context-param> <param-name>pwd</param-name> <param-value>root</param-value> </context-param> </web-app>

     这样url,user,root就是我们连接数据库的全局变量

    ♩:连接数据库

    ♩:注意:整个网站工程的所有页面,利用application.getInitParameter("")方法获取这些全局变量

    这里值得注意的是,原本的&号,必须写成转义字符&amp;否则web.xml会把&当作一个编译符号,整个网络工程无法在tomcat服务器中启动。

    ♩:编写JSP页面:

     1 <%@ page language="java" contentType="text/html; charset=utf-8"
     2     pageEncoding="utf-8"%>
     3 <%@ page import="java.sql.*"%>
     4 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
     5 <html>
     6 <head>
     7 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
     8 <title>index</title>
     9 </head>
    10 <body>
    11 <%
    12 //取出web.xml中的全局变量
    13 String url=application.getInitParameter("url");
    14 String user=application.getInitParameter("user");
    15 String pwd=application.getInitParameter("pwd");
    16 //连接数据库,把访问人数+1
    17 String sql = null;
    18 Class.forName("com.mysql.jdbc.Driver");
    19 Connection con=DriverManager.getConnection(url,user,pwd);
    20 sql = "update visitcount set visitCount=visitCount+1";
    21 con.createStatement().execute(sql);
    22 sql = "select visitCount from visitcount";
    23 ResultSet rs=con.prepareStatement(sql).executeQuery();
    24 //这里由于整个数据库表只有一行,所以无需用到while循环来取
    25 //只需要把指向第0行的游标向下移一个位置就可以了
    26 rs.next();
    27 //把这个变量写到application
    28 application.setAttribute("counter",String.valueOf(rs.getInt("visitCount")));
    29 //再把这个变量取出来,让访问网站的所有人看到
    30 out.print("你是第"+application.getAttribute("counter")+"个访问本站的人!"); 
    31 %>
    32 </body>
    33 </html>

    ※4※JSP的内置对象有哪些:

    参考链接:https://blog.csdn.net/bighuan/article/details/68925746

     1 内置对象名              类型                            四大域对象              域作用范围
     2 request           HttpServletRequest           request域
     3 response          HttpServletResponse
     4 config              ServletConfig
     5 application       ServletContext                  context域              同一个web应用中使用
     6 session            HttpSession                       session域             只能在同一个会话使用
     7 exception        Throwable
     8 page               Object(this)
     9 out                 JspWriter
    10 pageContext    PageContext                       page域                只能在当前jsp页面使用  

    ※5※Filter的生效时机:

    过滤器(Filter)、拦截器(Interceptor)、监听器(Listenter)

    参考链接:https://www.cnblogs.com/CloverSH/p/4531492.html

    ※web 应用程序启动时,web 服务器将创建Filter 的实例对象,并调用其init方法,读取web.xml配置,完成对象的初始化功能,从而为后续的用户请求作好拦截的准备工作(filter对象只会创建一次,init方法也只会执行一次)

    ※6※<context-param>与<init-param>的区别与作用

    参考链接:https://www.cnblogs.com/hzj-/articles/1689836.html

    ※在启动一个WEB项目的时候,

    ♩:容器(如:Tomcat)会去读取它的配置文件web.xml中的两个节点:<listener></listener>和<context-param></context-param>

    ♩:容器创建一个ServletContext(上下文),这个WEB项目所有的部分都将共享这个上下文

    ♩:容器将<context-param></context-param>转化为键值对,并交给ServletContext

    ♩:容器创建<listener></listener>中的类实例,即创建监听

    ♩:在监听中会有contextInitalized(ServletContextEvent   args)初始化方法,在这个方法中获得ServletContext = ServletContextEvent.getServletContext();

    context-param的值 = ServletContext.getInitParameter("context-param的键");

    ♩:得到这个context-param的值后,你就可以做一些操作,注意这个时候你的WEB项目还没有完全启动,这个动作会比所有的Servlet都要早。

    ♫:在启动项目之前就对数据库进行连接

    在<context-param>中设置数据库的连接方式,在监听类中初始化数据库的连接。

    这个监听是自己写的一个类,除了初始化方法,还有销毁方法,用于关闭应用前释放资源,比如对数据库的关闭

     1 <!-- 加载spring的配置文件 -->
     2 <context-param>
     3     <param-name>contextConfigLocation</param-name>
     4     <param-value>/WEB-INF/applicationContext.xml,/WEB-INF/action-servlet.xml,/WEB-
     5 INF/jason-servlet.xml</param-value>
     6 </context-param>
     7 <listener>
     8     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
     9 </listener>
    10 <--又如: --->自定义context-param,且自定义listener来获取这些信息-->
    11 <context-param>
    12     <param-name>urlrewrite</param-name>
    13     <param-value>false</param-value>
    14 </context-param>
    15 <context-param>
    16     <param-name>cluster</param-name>
    17     <param-value>false</param-value>
    18 </context-param>
    19 <context-param>
    20     <param-name>servletmapping</param-name>
    21     <param-value>*.bbscs</param-value>
    22 </context-param>
    23 <context-param>
    24     <param-name>poststoragemode</param-name>
    25     <param-value>1</param-value>
    26 </context-param>
    27 <listener>
    28     <listener-class>com.laoer.bbscs.web.servlet.SysListener</listener-class>
    29 </listener>
    30 public class SysListener extends HttpServlet implements ServletContextListener {
    31 private static final Log logger = LogFactory.getLog(SysListener.class);
    32 public void contextDestroyed(ServletContextEvent sce) {
    33    //用于在容器关闭时,操作
    34 }
    35 //用于在容器开启时,操作
    36 public void contextInitialized(ServletContextEvent sce) {
    37    String rootpath = sce.getServletContext().getRealPath("/");
    38    System.out.println("-------------rootPath:"+rootpath);
    39    if (rootpath != null) {
    40     rootpath = rootpath.replaceAll("\\", "/");
    41    } else {
    42     rootpath = "/";
    43    }
    44    if (!rootpath.endsWith("/")) {
    45     rootpath = rootpath + "/";
    46    }
    47    Constant.ROOTPATH = rootpath;
    48    logger.info("Application Run Path:" + rootpath);
    49    String urlrewrtie = sce.getServletContext().getInitParameter("urlrewrite");
    50    boolean burlrewrtie = false;
    51    if (urlrewrtie != null) {
    52     burlrewrtie = Boolean.parseBoolean(urlrewrtie);
    53    }
    54    Constant.USE_URL_REWRITE = burlrewrtie;
    55    logger.info("Use Urlrewrite:" + burlrewrtie);
    56    其它略之....
    57    }
    58 }
    59    /*最终输出
    60    -------------rootPath:D:	omcat_bbswebappsBBSCS_8_0_3
    61    2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    62 Application Run Path:D:/tomcat_bbs/webapps/BBSCS_8_0_3/
    63    2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    64 Use Urlrewrite:true
    65    2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    66 Use Cluster:false
    67    2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    68 SERVLET MAPPING:*.bbscs
    69    2009-06-09 21:51:46,573 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    70 Post Storage Mode:1
    71    */

    ※WEB.xml里面可以定义两种参数:

    ♩:application范围的参数,存放在servletContext中,在web.xml中配置如下:

    1 <context-param>
    2            <param-name>context/param</param-name>
    3            <param-value>avalible during application</param-value>
    4 </context-param>

    ♩:servlet范围内的参数,只能在servlet的init()方法中取得,在web.xml中配置如下:

    1 <servlet>
    2     <servlet-name>MainServlet</servlet-name>
    3     <servlet-class>com.wes.controller.MainServlet</servlet-class>
    4     <init-param>
    5        <param-name>param1</param-name>
    6        <param-value>avalible in servlet init()</param-value>
    7     </init-param>
    8     <load-on-startup>0</load-on-startup>
    9 </servlet>

    在servlet中可以通过代码分别取用:

     1 package com.wes.controller;
     2 import javax.servlet.ServletException;
     3 import javax.servlet.http.HttpServlet;
     4 public class MainServlet extends HttpServlet ...{
     5     public MainServlet() ...{
     6         super();
     7      }
     8     public void init() throws ServletException ...{
     9          System.out.println("下面的两个参数param1是在servlet中存放的");
    10          System.out.println(this.getInitParameter("param1"));
    11          System.out.println("下面的参数是存放在servletcontext中的");
    12         System.out.println(getServletContext().getInitParameter("context/param"));
    13       }
    14 }

    第一种参数在servlet里面可以通过getServletContext().getInitParameter("context/param")得到

    第二种参数只能在servlet的init()方法中通过this.getInitParameter("param1")取得

  • 相关阅读:
    设计模式7—装饰者模式【结构型】
    设计模式6—命令模式【行为型】
    vue工程类型—vue 多模块、vue多项目集成工程
    设计模式5—迭代器模式【行为型】
    设计模式4—代理模式【结构型】
    设计模式3—策略模式【行为型】
    用户权限管理系统(后台权限管理)
    https原理 及 证书
    设计模式2—单例模式【创建型】
    设计模式1—发布订阅者模式【行为型】
  • 原文地址:https://www.cnblogs.com/zhuo-zui/p/11379012.html
Copyright © 2011-2022 走看看