此前的笔记1
-----------------------------------------
当修改了/etc/profile文件,想让它立刻生效,而不用重新登录;这时就可以用source命令,用法: source /etc/profile
-----------------------------------------
OGNL表达式语言
由于ValueStack(值栈)是Struts 2中OGNL的根对象,如果用户需要访问值栈中的对象,则可以直接通过下面的代码访问ValueStack(值栈)中的属性:
${foo} //获得值栈中的foo属性
如果访问其他Context中的对象,由于不是根对象,在访问时,需要加#前缀。
application对象:用于访问ServletContext,例如#application.userName或者#application['userName'],相当于调用Servlet的getAttribute("username")。
session对象:用来访问HttpSession,例如#session.userName或者#session['userName'],相当于调用session.getAttribute("userName")。
request对象:用来访问HttpServletRequest属性(attribute)的Map,例如#request.userName或者#request['userName'],相当于调用request.getAttribute("userName")。
parameters对象:用于访问HTTP的请求参数,例如#parameters.userName或者#parameters['userName'],相当于调用request.getParameter("username")。
attr对象:用于按page->request->session->application顺序访问其属性
----------------------------------------------------------------
在用Hiberante时,
当一个model中使用联合主键,而联合主键中有其中一项还关联到另一张表,
这时用key-many-to-one,
但是,有时数据中,在做many-to-one时,找不到one的那一端,严格意义上讲,这种属于垃圾数据,
但是在实际应用中,又不可以删除。
在做many-to-one时,可以在配置文件中配置not-found="ignore",
但是key-many-to-one,不支持此属性,
于是,将key-many-to-one变通配置成了many-to-one,再重新配一遍该字段做联合主键,
-----------------------------------------------------
oracle中rank() over与row_number()的区别
PARTITION BY testid ORDER BY creat_time asc根据列testid分组,按照creat_time降序排列。
rank() OVER对有相同的值,标记相同的值。row_number() 则不会。
故如果要进行排重操作,使用row_number() 将不会有重复记录的产生。
eg:
-------rank() over-------------
select tmp.*
from (select s.YTNEWSID,s.TITLE,s.TITLE_IMG,s.CHANNEL_ID,
rank() over(partition by s.CHANNEL_ID order by release_date desc) px
from YT_NEWS s
where s.status=1
) tmp
where px <= 5
------row_number() over()-------
select *
from (select s.YTNEWSID,s.TITLE,s.TITLE_IMG,s.CHANNEL_ID,
(Row_number()
over(partition by channel_id order by release_date desc)) rn
from news s)
where rn <= 5;
-----------------------------------------------------------
保存退出文件 就是 :wq 不保存退出 :q 不保存强制退出 :q!
------------------------------------------------------------
oracle数据库对prodece,function,package等加密:(加密后记得保存好源代码,不然就再也找不回来了)
cmd,执行如下命令:
wrap iname=d:/test.sql oname=d:/text.pld
注:第二个参数oname可以不用,则默认输出到相同目录下面同名的yipld结尾的文件,然后@倒入数据库,ok。
---------------------------------------------------------------
org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'shopcode' in 'class java.lang.String'
使用mybatis拼接动态sql语句的时候产生的异常,异常原因是接口中提供的方法,参数不是封装的对象,而是基础类型,比如String ,int等,
在这种情况下为了避免错误,需要在实体映射文件中把对应的查询参数名改为value,demo如下:
List<YtPartershop> get4ProductsByShopcode(String shopcode);
<select id="getModel" resultMap="PartershopResultMap" parameterType="java.lang.String">
select s.*,c.shopcontent,t.templateurl from shop s
<if test="null != value and ''!= value"> -----把shopcode替换为value
where s.shopcode=#{value}-----把#{shopcode}替换为#{value}
</if>
</select>
另一种方法就是给实体对象中添加对应的属性名称。
---------------------------------------------------------------
HTTP消息报头包括普通报头、请求报头、响应报头、实体报头。
普通报头中的Cache-Control用于指定缓存指令,缓存指令是单向的(响应中出现的缓存指令在请求中未必会出现),且是独立的(一个消息的缓存指令不会影响另一个消息处理的缓存机制),HTTP1.0使用的类似的报头域为Pragma。
请求时的缓存指令包括:no-cache(用于指示请示或响应消息不能缓存)、no-store、max-age、max-stale、min-fresh、only-if-cached;
响应时的缓存指令包括:public、private、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age、s-maxage。
例:为了指示IE浏览器(客户端)不要缓存页面,服务器端的jsp程序可以编写如下:
response.setHeader(“Cache-Control”, “no-cache”);
//response.setHeader(“Pragma”, “no-cache”);作用相当于上行代码,通常两者合用
Expires实体报头域给出响应过期的日期和时间。为了让代理服务器或浏览器在一段时间以后更新缓存中(再次访问曾访问过的页面时,直接从缓存中加载,缩短响应时间和降低服务器负载)的页面,我们可以使用Expires实体报头域指定页面过期时间。例:Expires:Thu,15 Sep 2006 16:23:12 GMT
HTTP1.1的客户端和缓存必须将其他非法的日期格式(包括0)看作已经过期。如:为了让浏览器不要缓存页面,也可以利用Expires实体报关域,设置为0,jsp程序如下:
response.setDateHeader(“Expires”, “0”);
//JSP禁止缓存代码
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
response.flushBuffer();
另,网上各种禁客户端缓存总结如下:
HTM网页
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
<META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">
ASP网页
<%
Response.Expires = -1
Response.ExpiresAbsolute = Now() - 1
Response.cachecontrol = "no-cache"
%>
PHP网页
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Cache-Control: no-cache, must-revalidate");
header("Pragma: no-cache");
JSP
response.setHeader("Pragma","No-Cache");
response.setHeader("Cache-Control","No-Cache");
response.setDateHeader("Expires", 0);
C#中禁止cache的方法!
Response.Buffer=true;
Response.ExpiresAbsolute=System.DateTime.Now.AddSeconds(-1);
Response.Expires=0;
Response.CacheControl="no-cache";
在<%@ Page language="c#" Codebehind="A.aspx.cs" AutoEventWireup="false" Inherits="*.*" %>下面加上以下的代码:
<%@ OutPutCache Location="None"%> 能每次页面Load时都可以清空缓存
-----------------------------------------------------------
网站项目安全退出后,由于使用了springmvc中拦截器的配置,基本上不会出现在地址栏中输入链接直接跳转到页面的bug,
但是有一个页面例外,就是left.do,退出后第一次输入该地址仍然会跳转到页面,可再次刷新,就会跳转到登陆页,
为什么每次都会有这么一次缓存呢,查看对应的jsp页面,发现里面把菜单缓存到了session里面,但是action里面缓存已经清空了啊,怎么还会出现这种状况,难道没有清除掉,下断点,单步跟踪,没问题,session是空的,那问题出在哪了?该不会是客户端缓存了吧,于是在left.jsp页面加入如下三句话,
<meta http-equiv="Pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">//表示不缓存,立即过期
重复之前的操作,恩,效果不错,再也不会缓存一次了。over!
注意:
HTTP/1.0有一个功能比较弱的缓存控制机制:Pragma,使用HTTP/1.0的缓存将忽略Expires和Cache-Control头
Expires 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的
效果。但是如果同时存在,则被Cache-Control的max-age覆盖。
-----------------------------------------------------