赞
踩
索引是在数据库表的字段上添加的,是为了提高查询效率存在的一种机制。
一张表的一个字段可以添加一个索引,当然也可以联合起来添加,索引就相当于一本书的目录,是为了缩小扫描范围而存在的一种机制。
如果没有添加索引的话,mysql会把所有字段都扫描一遍,这样效率比较低。
索引需要排序,只有排序后才有区间查找这一说(缩小扫描范围其实就是扫描某个区间),并且索引的排序和TreeSet数据给够相同。TreeSet底层是一个自平衡的二叉树,在MySQL中索引是一个B-Tree数据结构。
遵循左小右大的原则
在任何数据库中主键上都会自动添加索引,在MySQL中一个字段上有unique约束的话,也会自动创建索引
在任何数据库中,任何一张表的任何一条记录在硬盘存储上都有一个硬盘的物理编号。
mysql中,索引是一个单独对象,不同的存储引擎以不同的形式存在,在MySQL
数据量庞大
这个字段经常出现在where后面,以条件形式存在,该字段总是被扫描
该字段很少的DML操作,因为DML之后索引需要重新排序,
建议不要随意添加索引,因为索引也是需要维护的,太多的话反而会降低系统的性能。建议通过主键查询,通过unique约束查询,效率会高一些。
添加索引:
ceate index emp_ename_index on emp(ename);
删除索引:
drop index emp_ename_index on emp;
mysql> create index emp_ename_index on emp(ename); Query OK, 0 rows affected (0.01 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> drop index emp_ename_index on emp(ename); ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(ename)' at line 1 mysql> drop index emp_ename_index on emp; Query OK, 0 rows affected (0.01 sec) Records: 0 Duplicates: 0 Warnings: 0
explain select * from emp where ename = 'KING';
mysql> explain select * from emp where ename = 'KING'; +----+-------------+-------+------+---------------+------+---------+------+------+-------------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+-------+------+---------------+------+---------+------+------+-------------+ | 1 | SIMPLE | emp | ALL | NULL | NULL | NULL | NULL | 14 | Using where | +----+-------------+-------+------+---------------+------+---------+------+------+-------------+ 1 row in set (0.00 sec)
19.6.1 失效的第一种情况
select * from emp where ename like '%T';
模糊匹配中,使用“%”开头,所以不会走索引
19.6.2 失效的第二种情况
使用or的时候会失效,如果使用or那么要求or两遍字段都要有索引,才会走索引,如果一遍没有那么另一个也不能用,少用or
19.6.3失效的第三种情况
使用复合索引,没有使用左侧的列去查找,索引就会失效。
19.6.4 失效的第四种情况
在where条件中,索引列参加的运算,或者,索引列使用了函数,索引失效
概念:运行在服务端的小程序
Servlet就是一个接口,定义了Java类被浏览器访问到(tomcat识别)的规则
将来我们定义一个类,实现Servlet接口,复写方法
快速入门:
创建一个Javaee项目
定义一个类,实现Servlet接口
实现接口中的抽象方法
配置Servlet
在web.xml文件中配置Servlet
<!-- 配置Servlet--> <servlet> <servlet-name>demo1</servlet-name> <servlet-class>cn.itcast.web.servlet.ServletDemo1</servlet-class> </servlet> <servlet-mapping> <servlet-name>demo1</servlet-name> <url-pattern>/demo1</url-pattern> </servlet-mapping>
当服务器接收到客户端浏览器的请求后,会解析请求URL路径,获取访问Servlet的资源路径
放查找web.xml文件,是否有对应的<url-pattr>标签体内容。
如果有,则在找到对应的<servlet-class>全类名
Tomcat会将字节码文件加载进内存,并且创建其对象
调用方法
Servlet生命周期
被创建:执行init方法,只执行一次。
Servlet默认在第一次被访问的时候,Servlet被创建
可以配置指定Servlet的创建时间,使用<load-on-startup>标签
<load-on-startup>0或正整数</load-on-startup>
在第一次访问时被创建
<load-on-startup>负数</load-on-startup>
在服务器启动的时候被创建
Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的
多个用户同时访问时,可能存在线程安全问题
解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对值进行修改。
提供服务:执行Servlet方法,执行多次
每次访问都会执行一次,方法调用一次
被销毁:执行destroy方法,只能执行一次。
Servlet被销毁时执行,关闭服务器时,Servlet被销毁
只有服务器正常关闭时才能执行destroy方法
这个方法在Servlet被销毁之前执行,一般用于释放资源
idea会为每一个Tomcat不熟的项目单独建立一份配置文件
工作空间项目和Tomcat部署的web项目
Tomcat真正访问的是“Tomcat部署的web项目”,“Tomcat部署的web项目”对应着“工作空间项目”的web目录下的所有资源
web-inf下的资源不能被浏览器直接访问
GenericServlet:将Servlet接口中其他方法都做了默认空实现,只讲service方法作为抽象
HTTPServlet:对http协议的一种封装,简化操作
http是一种传输协议,定义了,客户端和服务器端通信时,发送数据的格式
特点:
基于tcp/ip的高级协议
默认端口号:80
基于请求/响应模型:一次请求对应一次响应
无状态的:每次请求之间都是相互独立,不能交互数据
请求消息的数据格式:
请求行
请求方式 请求url 请求协议/版本
GET /login.html HTTP/1.1
get :
请求参数在请求行中,url之后。
请求的url长度有限制
不太安全(相对的)
post:
请求参数在请求体中
请求的url长度没有限制
相对安全
请求头
请求头的名称:请求头的值
User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.131 Safari/537.36 SLBrowser/8.0.0.2242 SLBChan/30
Referer:地址
告诉服务器当前请求从哪里来
作用:
放盗链
统计工作
请求空行 空行(用于分隔post请求头和请求体)
请求体(正文)
封装post请求消息的请求参数
request和response对象是由服务器创建的。我们来使用他们
request对象用来获取请求消息,response对象用来设置响应消息
request对象继承体系结构
ServletRequest——接口
| 继承
HTTpServletRequest——接口
| 实现
获取请求消息数据
获取请求行数据
获取请求头数据
获取请求体数据
其他功能
获取请求行的数据
获取请求方式
String getMethod();
获取虚拟目录(重点掌握)
String getContextpath();
获取Servlet路径 String getServletPath();
获取get方式请求参数
String getQueryString();
获取请求url(重点掌握)
String getRequestURL();
StringBuffer getRequertURL();
获取协议及版本
String getProtocal();
获取客户机的IP地址
String getRemoteAddr();
获取请求头的数据
String getHeader(String name):通过请求头的名称获取请求头的值(很重要)
Enumeration<String> getHeaderNames():获取所有的请求头名称
获取请求体的数据
BufferedReader getReader();:获取字符输入留,只能操作字符数据。
ServletInputStream getInputStream();:获取字节流输入流,可以操作所有类型数据。
获取请求参数的通用方法
String getParameter(String name):根据参数名称获取参数值
Sting[] getParameterValues(String name):根据参数名称获取参数值的数组
Enumeration<String> getParameterNames():获取所有请求的参数名称
Map<String,String[]> getParameterMap():获取所有参数的map集合
请求转发
一种在服务器内部的资源跳转方式
步骤:
通过request对象获取请求转发器对象:RequestDispatcher getRequestDiapatcher(String path)
使用RequestDispatcher对象来进行转发:forward(ServletRequest request,ServletResponse response)
好处:
浏览器地址栏路径没有发生变化
只能访问当前服务器内部资源中
转发是一次请求
共享数据
域对象:一个有作用范围的对象,可以在范围内共享数据
request域:代表一次请求的范围,一般用于请求转发的多个资源中共享数据
用SetAttribute(String name,Object obj):存储数据
getAttritude(String name):通过建获取值
removeAtrribute(String name):通过键移除值
获取ServletContext
get方式:tomcat会将中文乱码问题解决
响应行,响应头,响应空行,响应体
请求体就是页面内容
响应行
协议版本 响应状态码 响应描述
响应状态码:服务器告诉客户端浏览器本次请求和响应的一个状态
状态码都是三位数
分类:
1**:服务器接受客户端消息,但是没有接受完成,等待一段时间后,发送1~~
2**:成功
3**:重定向。302(重定向),304(访问缓存)
4**:客户端错误。404(请求路径没有对应资源),405(请求方式没有对应的do方法)
5**:服务端错误。500(服务器内部出现异常)
响应头
格式:头名称:值
Context-Type:服务器告诉客户端本次响应数据格式以及编码格式
Content-disposition:服务器告诉客户端以什么格式打开响应体格式
设置响应头:setHeader(String sc)
设置响应体:
获取输出流
字符输出流:PrintWriter()
字节输出流:ServletOutputStream getOutputStream()
使用输出流,将数据输出到客户端的浏览器
重定向:
地址栏发生变化
重定向可以访问其他站点的资源
重定向是两次请求,不可以使用request对象来共享数据
转发:
转发地址栏不发生变化
转发只能访问当前服务器下的资源
转发是一次请求,可以使用request对象来共享数据
绝对路径:以/开头的路径
给客服端浏览器使用:需要加虚拟牡蛎
给服务器使用:不需要加虚拟目录
相对路径:通过相对路径不可以确定唯一资源
规则:找到当前资源和目标资源之间的相对位置关系
package selver; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; import java.io.PrintWriter; @WebServlet(name = "response3", value = "/response3") public class response3 extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doPost(request,response); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //在获取流对象前要先设置流的默认编码:ISO-8859-1为:GBK response.setCharacterEncoding("GBK"); //告诉浏览器,服务器发送的消息体数据的编码。建议浏览器使用改编码解码 response.setHeader("content-type","text/html;charset=utf-8");//不仅可以设置文件的编码,还可以设置浏览器的编码 //简单形式 response.setContentType("text/html;charset=utf-8"); //1.获取字符输出流 PrintWriter printWriter = response.getWriter(); //2.输出数据 printWriter.write("<h1 style = 'color:red;'>一个人的夜,我的心应该放在哪里</h1>"); } }
代表整个web应用,可以和程序的容器(服务器)来通信
获取MIME类型
MIME类型:在互联网那个通信过程中定义的一种文件数据类型
格式:大类型/小类型 text/html
域对象:共享数据
setAttribute(String name,String value)
getAttribute(String name)
removeAttribute(String name)
获取文件的真实(服务器)路径
方法:getRealPath();
request.getServletContext();
this.getServletConte();
一次回话中包含多次请求和响应
一次回话:浏览器第一次给服务器资源发送请求,回话建立,知道有一缸断开为止。
在一次回家的范围内的多次请求间,共享数据
方式:
客户端回话技术:Cookie
服务器端回话技术:Session
步骤:
创建cookie对象,绑定数据
new Cookie(String name , String value)
发送cookie对象
response.addCookie(Cookie cookie)
获取cookie,拿到数据
Cookie[] request. getCookies()
一次可不可以发送多个Cookie
可以一次创建多个cookie,用response调用多次
Cookie在浏览器中保存多长时间
默认情况下,当浏览器关闭之后,cookie被销毁
设置cookie的存储信息,持久化存储
setMaxAge(int second)
正数:将cookie数据写到硬盘文件中,持久化存储。cookie存活间
负数:默认值
0:代表删除cookie信息
cookie能不能存储中文
在Tomcat 8之前,不能存储中文,在Tomcat 8之后能访问
cookie获取范围多大
在一个Tomcat服务器中,部署了多个web项目,默认情况下,在这些web项目中cookie不能共享。
cookie的存储数据在客户端浏览器
浏览器对于当cookie的大小有限制(4kb)以及对用一个域名下的总cookie数量也有显示(20个)
作用
cookie一般用于存储少量的不太敏感的数据
在不登录的情况下,完成服务器对客户端的身份识别
服务器端回话技术,在一次回话的多次请求间共享数据,将数据保存在服务器端的对象中。HTTPSession
Object getAttribute(String name)
void setAttirbute(String name,Object value)
void removeAttirbute(String name)
获取session对象
使用session对象
在两个demo中,获取了两个session,这两个session是同一个session,第一次获取session的时候没有cookie,会在内存中创建一个新的session
session是依赖cookie的
当客户端关闭后,服务器不关闭,两次获取的session是不是同一个
默认情况下不是
如何两次获取同一个session,可以创建一个cookie
Cookie c = new Cookie("JSESSION",session.getId())
客服端不关闭,服务器关闭之后,两次获取的session不是同一个
不是同一个,但是如果要保证数据不丢失
session的钝化:
在服务器正常关闭前,将session对象系列化到硬盘上
session的活化:
在服务器启动后,将session文件转化为内存中的session对象即可
session什么时候被销毁
服务器关闭
session对象调用invalidate()
session默认失效时间是30分钟
session可以用于存储一次回话的多次请求的数据,存在服务器端
session可以存储任意类型,任意大小的数据
session存储数据在服务器端,cookie在客户端
session没有数据大小限制,cookie有
session数据安全,cookie相对于不安全
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。