#
JAVA 把字符串間的若干空格保留一個
String str="你 好, Fuck You";
System.out.println(str.replaceAll("\\s+"," "));
javascript和java里的回車換行符的處理
request.getParameter("modelTail").replaceAll("<br>",String.valueOf((char)13)).replaceAll("<bt>",String.valueOf((char)10))
content.replaceAll(String.valueOf((char)13),"<br>").replaceAll(String.valueOf((char)10),"<bt>")
document.all.txtContent.value = (varGet2.Content).replace("<br>",String.fromCharCode(13)).replace("<bt>",String.fromCharCode(10));
javascript里的String.fromCharCode 和 strObj.charCodeAt(index)
Tomcat默認可以使用的內(nèi)存為128MB,在較大型的應(yīng)用項目中,這點內(nèi)存是不夠的,輕微時,會使系統(tǒng)性能急劇下降,嚴重時,將導(dǎo)致系統(tǒng)無法運行,影響系統(tǒng)的穩(wěn)定性。當(dāng)內(nèi)存不夠用時,常見的問題就是報tomcat內(nèi)存益處錯誤,從兒導(dǎo)致客戶端包500錯誤的,如下:解決方法主要是加大TOMCAT可利用內(nèi)存,并在程序當(dāng)中加大內(nèi)存使用。因此根據(jù)應(yīng)用的需求,有必要調(diào)整JVM使用內(nèi)存的大小。現(xiàn)在將手工修改tomcat內(nèi)存的方法及注意事項列出,希望能對新人有所幫助。
tomcat提供了兩種安裝模式,即免安裝(*.zip)和安裝(*.exe)方式。針對不同的安裝方式下修改tomcat內(nèi)存大小的方法幾注意問題(windows環(huán)境):
方式1:當(dāng)選擇安裝方式時,可以在安裝tomcat的過程進行設(shè)置tomcat初始化內(nèi)存的大小。但是假如說在安裝時沒有選擇,或者應(yīng)用改變了,需要增加tomcat內(nèi)存時怎么半呢?此時,我們就要手工修改tomcat的一些文件了:
看了很多網(wǎng)上的資料,都是說修改<CATALINA_HOME>\bin\catalina.bat文件的內(nèi)容,即在里面增加一行代碼:
set JAVA_OPTS=-Xms512m -Xmx512m //表示初始化最小可用內(nèi)存和最大可用內(nèi)存都是512MB(修改相應(yīng)值即可)
如在catalina.bat的
rem ----- Execute The Requested Command
echo Using CATALINA_BASE: %CATALINA_BASE%
echo Using CATALINA_HOME: %CATALINA_HOME%
echo Using CATALINA_TMPDIR: %CATALINA_TMPDIR%
echo Using JAVA_HOME: %JAVA_HOME%
這一欄改為
rem ----- Execute The Requested Command
set JAVA_OPTS=-Xms512m -Xmx512m
echo Using CATALINA_BASE: %CATALINA_BASE%
echo Using CATALINA_HOME: %CATALINA_HOME%
echo Using CATALINA_TMPDIR: %CATALINA_TMPDIR%
echo Using JAVA_HOME: %JAVA_HOME%
就可以將JAVA虛擬機分配內(nèi)存 508.0625MB的!
但是很多人修改后,發(fā)現(xiàn)修改并沒有起作用,即通過windows的服務(wù)啟動tomcat時,實際的內(nèi)存還是默認的,修改的設(shè)置并沒有起作用;而通過<CATALINA_HOME>\bin\startup.bat 啟動卻是生效的。這是為什么呢?因為在安裝過程中,JVM的初始化參數(shù)已經(jīng)寫在注冊表中了,由于沒有修改注冊表中相關(guān)參數(shù),所以以windows服務(wù)方式啟動時,修改的并沒有生效。而通過<CATALINA_HOME>\bin\startup.bat 啟動直接是通過<CATALINA_HOME>\bin\catalina.bat文件中的配置的。你需要重新加載到系統(tǒng)服務(wù)中才生效,或者你手工在注冊表中查找修改啟動值,加載到服務(wù)中的時候參數(shù)已經(jīng)配置好了,自己修改artup.bat不會改變注冊表中的參數(shù)設(shè)置。
解決方法:修改注冊表中的參數(shù),加入JVM初始化內(nèi)存的參數(shù):
HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Tomcat Service Manager\Tomcat5\Parameters\JavaOptions
值為
-Dcatalina.home="C:\ApacheGroup\Tomcat 5.0"
-Djava.endorsed.dirs="C:\ApacheGroup\Tomcat 5.0\common\endorsed"
-Xrs
如加入 -Xms512m -Xmx800m
方式2:針對免安裝的用戶,也可以通過將tomcat注冊為windows的一個服務(wù)的方式來實現(xiàn):‘
我們可以對service.bat文件做一些其他修改,使tomcat更加能滿足我們各種不同需求時的要求
1. 如果讓tomcat編譯jsp文件,就在PR_CLASSPATH中加入J2SDK的tools.jar
修改前:
set PR_CLASSPATH=%CATALINA_HOME%\bin\bootstrap.jar
修改后:
set PR_CLASSPATH=%JAVA_HOME%\lib\tools.jar;%CATALINA_HOME%\bin\bootstrap.jar
2.要使用一個特定的JVM,就要修改jvm的參數(shù);要使注冊的windows服務(wù)的啟動方式為自動,增加--Startup Automatic,這個是比較常用的;要用定制的server.xml配置文件并且傳遞多個參數(shù)給StartClass,要修改StartParams的值,各個值之間用分號分隔:
修改前:
"%EXECUTABLE%" //IS//%SERVICE_NAME% --Jvm auto
--StartClass org.apache.catalina.startup.Bootstrap --StopClass org.apache.catalina.startup.Bootstrap
--StartParams start --StopParams stop
修改后:
"%EXECUTABLE%" //IS//%SERVICE_NAME% --Jvm "%JAVA_HOME%\jre\bin\server\jvm.dll"
--StartClass org.apache.catalina.startup.Bootstrap --StopClass org.apache.catalina.startup.Bootstrap
--StartParams "-config;%CUSTOM_SERVERXML_FILE%;-nonaming;start" --StopParams stop
--Startup Automatic
3. 指定最大和最小的內(nèi)存限制,要增加jvm的初始參數(shù)
修改前:
"%EXECUTABLE%" //US//%SERVICE_NAME% --JvmOptions
"-Dcatalina.base=%CATALINA_BASE%;-Dcatalina.home=%CATALINA_HOME%;-Djava.endorsed.dirs=%CATALINA_HOME%\common\endorsed"
--StartMode jvm --StopMode jvm
修改后:
"%EXECUTABLE%" //US//%SERVICE_NAME% --JvmOptions
"-Xms128M;-Xmx256M;-Dcatalina.base=%CATALINA_BASE%;-Dcatalina.home=%CATALINA_HOME%;-Djava.endorsed.dirs=%CATALINA_HOME%\common\endorsed"
--StartMode jvm --StopMode jvm
4.有時注冊windows服務(wù)成功后,但是啟動服務(wù)時顯示“發(fā)生服務(wù)特定錯誤: 0.”
就是因為jvm沒有指定,修改Jvm auto為Jvm "%JAVA_HOME%\jre\bin\server\jvm.dll"后重新注冊windows服務(wù)就可以啟動了。
具體記錄如下:
<s:set name="fieldType" value="'condition'"></s:set>
<s:set name="countryID" value="'CHN'"></s:set>
<s:set name="corpCenter" value="#session.opType.corpCenter"></s:set>
<s:set name="corpID" value="#session.opType.corpID"></s:set>
<s:set name="corpType" value="#session.opType.corpType"></s:set>
<s:set name="agentID" value=""></s:set>
<s:set name="city" value=""></s:set>
<s:set name="agentType" value='"A"'></s:set>
注意上面紅色部分的標識。當(dāng)定義的變量為單個字符是,必須外面是單引號,字符用雙引號引起。
<s:action name="ReportBeanListAction" id="reportBeanSkyechoAgentListAction">
<s:param name="agentID"><s:property value="agentID" /></s:param>
<s:param name="city"><s:property value="city" /></s:param>
<s:param name="corpID"><s:property value="corpID" /></s:param>
<s:param name="corpCenter"><s:property value="corpCenter" /></s:param>
<s:param name="agentType"><s:property value="agentType" /></s:param>
</s:action>
附:轉(zhuǎn)載OGNL表達式相關(guān)的知識點:
OGNL的全稱是Object Graph Navigation Language(對象圖導(dǎo)航語言),它是一種強大的表達式語言,讓你通過簡單一致的表達式語法來讀取和設(shè)置Java對象的屬性值,調(diào)用對象的方法,遍歷整個對象的結(jié)構(gòu)圖,實現(xiàn)字段類型轉(zhuǎn)換等功能。
為什么使用OGNL
相對于其它的表達式語言,OGNL的功能更為強大,它提供了很多高級而必需的特性,例如強大的類型轉(zhuǎn)換功能、靜態(tài)或?qū)嵗椒ǖ膱?zhí)行、跨集合投影,以及動態(tài)lambda表達式定義等。
OGNL基礎(chǔ)
OGNL表達式的計算都是圍繞OGNL上下文來進行的,OGNL上下文實際上就是一個Map對象,由ognl.OgnlContext類(實現(xiàn)了 java.util.Map接口)來表示。OGNL上下文可以包含一個或多個JavaBean對象,在這些對象中有一個是特殊的,這個對象就是上下文的根 (root)對象。如果在寫表達式的時候,沒有指定使用上下文中的哪一個對象,那么根對象將被假定為表達式所依據(jù)的對象。
在OGNL上下文中,只能有一個根對象,如果你訪問根對象,那么在寫表達式的時候,直接寫對象的屬性就可以了;否則,你需要使用“#key”前綴,例如表達式#namager.name。
OGNL表達式
OGNL表達式的基礎(chǔ)單元就是導(dǎo)航鏈,通常簡稱為鏈(chain)。最簡單的鏈由下列部分組成:
1、屬性名:如name和manager.name;
2、方法調(diào)用:如manager.hashCode(),返回manager對象的散列碼;
3、數(shù)組索引:如emals[0],返回當(dāng)前對象的郵件列表中的第一個郵件地址。
所有OGNL表達式的計算都是在當(dāng)前對象的上下文中,一個鏈簡單地使用鏈中先前鏈接的結(jié)果作為下一步計算的當(dāng)前對象。我們看如下所示的鏈:
name.toCharArray()[0].numericValue.toString()
這個表達式按照下列的步驟進行計算:
1、獲取根對象的name屬性;
2、在String結(jié)果上調(diào)用toCharArray()方法;
3、從char數(shù)組中提取第一個字符;
4、從提取的字符對象上行到numericValue屬性(這個字符被表示為Character對象,Character類有一個getNumericValue()方法);
5、在Integer對象結(jié)果上調(diào)用toString()方法。
這個表達式最終結(jié)果是最后返回的toString()方法調(diào)用返回的字符串。
常量
OGNL支持的所有常量類型:
1、字符串常量:
以單引號或雙引號括起來的字符串。如”hello”,’hello’。
不過要注意的是,如果是單個字符的字符串常量,必須使用雙引號。
2、字符常量:
以單引號括起來的字符。如’a'。
3、數(shù)值常量:
除了Java中的int、long、float和double外,OGNL還讓你使用“b”或“B”后綴指定BigDecimal常量,用“h”“H”后綴指定BigInteger常量。
4、布爾常量:
true和false。
5、null常量。
操作符
OGNL除了支持所有的Java操作符外,還支持以下幾種:
1、逗號,
與C語言中的逗號操作符類似。
2、花括號{}
用于創(chuàng)建列表,元素之間用逗號分隔。
3、in和not in
用于判斷一個值是否在集合中。
訪問JavaBean的屬性
假如有一個employee對象作為OGNL上下文的根對象,那對于下面的表達式:
1、name
對應(yīng)的java代碼是employee.getName();
2、address.country
對應(yīng)的java代碼是employee.getAddress().getCountry();
訪問靜態(tài)方法和靜態(tài)字段
@class@method(args) //調(diào)用靜態(tài)方法
@class@field //調(diào)用靜態(tài)字段
其中class必須給出完整的類名(包括包名),如果省略class,那么默認使用的類是java.util.Math,如:
@@min(5,3)
@@max(5,3)
@@PI
索引訪問
OGNL支持多種索引方式的訪問。
1、數(shù)組和列表索引
在OGNL中,數(shù)組和列表可以大致看成是一樣的。
如:array[0]、list[0]。表達式:{’zhangsan’,'lisi’,'wangwu’}[1]等。
2、JavaBean的索引屬性
要使用索引屬性,需要提供兩對setter和getter方法,一對用于數(shù)組,一對用于數(shù)組中的元素。
如:有一個索引屬性interest,它的getter和setter如下
public String[] interest;
public String[] getInterest(){ return interest;}
public void setInterest(String[] interest){ this.interest=interest;}
public String getInterest(int i){ return interest[i]}
public void setInterest(int i, String newInterest){ interest[i]=newInterest;}
對于表達式interest[2],OGNL可以正確解釋這個表達式,調(diào)用getInterest(2)方法。如果是設(shè)置的情況下,會調(diào)用setInterest(2,value)方法。
3、OGNL對象的索引屬性
JavaBean的索引屬性只能使用整型作為索引,OGNL擴展了索引屬性的概念,可以使用任意的對象來作為索引。
對集合進行操作
1、創(chuàng)建集合:
創(chuàng)建列表
使用花括號將元素包含起來,元素之間使用逗號分隔。如{’zhangsan’,'lisi’,'wangwu’}
創(chuàng)建數(shù)組
OGNL中創(chuàng)建數(shù)組與Java語言中創(chuàng)建數(shù)組類似。
創(chuàng)建Map
Map使用特殊的語法來創(chuàng)建 #{”key”:value, ……}
如果想指定創(chuàng)建的Map類型,可以在左花括號前指定Map實現(xiàn)類的類名。如:
#@java.util.LinkedHashMap@{”key”:”value”,….}
Map通過key來訪問,如map["key"]或map.key。
2、投影
OGNL提供了一種簡單的方式在一個集合中對每一個元素聞?wù){(diào)用相同的方法,或者抽取相同的屬性,并將結(jié)果保存為一個新的集合,稱之為投影。
假如employees是一個包含了employee對象的列表,那么
#employees.{name}將返回所有雇員的名字的列表。
在投影期間,使用#this變量來引用迭代中的當(dāng)前元素。
如:objects.{#this instanceof String? #this: #this.toString()}
3、選擇
OGNL提供了一種簡單的方式來使用表達式從集合中選擇某些元素,并將結(jié)果保存到新的集合中,稱為選擇。
如#employees.{?#this.salary>3000}
將返回薪水大于3000的所有雇員的列表。
#employees.{^#this.salary>3000}
將返回第一個薪水大于3000的雇員的列表。
#employees.{$#this.salary>3000}
將返回最后一個薪水大于3000的雇員的列表。
lambda表達式
lambda表達式的語法是: :[...]。OGNL中的lambda表達式只能使用一個參數(shù),這個參數(shù)通過#this引用。
如:
#fact= :[ #this<=1 ? 1 : #this* #fact ( #this-1) ], #fact(30)
#fib= :[#this==0 ? 0 : #this==1 ? 1 : #fib(#this-2)+#fib(#this-1)], #fib(11)
OGNL的全稱是Object Graph Navigation Language(對象圖導(dǎo)航語言),它是一種強大的表達式語言,讓你通過簡單一致的表達式語法來讀取和設(shè)置Java對象的屬性值,調(diào)用對象的方法,遍歷整個對象的結(jié)構(gòu)圖,實現(xiàn)字段類型轉(zhuǎn)換等功能。
為什么使用OGNL
相對于其它的表達式語言,OGNL的功能更為強大,它提供了很多高級而必需的特性,例如強大的類型轉(zhuǎn)換功能、靜態(tài)或?qū)嵗椒ǖ膱?zhí)行、跨集合投影,以及動態(tài)lambda表達式定義等。
OGNL基礎(chǔ)
OGNL表達式的計算都是圍繞OGNL上下文來進行的,OGNL上下文實際上就是一個Map對象,由ognl.OgnlContext類(實現(xiàn)了 java.util.Map接口)來表示。OGNL上下文可以包含一個或多個JavaBean對象,在這些對象中有一個是特殊的,這個對象就是上下文的根 (root)對象。如果在寫表達式的時候,沒有指定使用上下文中的哪一個對象,那么根對象將被假定為表達式所依據(jù)的對象。
在OGNL上下文中,只能有一個根對象,如果你訪問根對象,那么在寫表達式的時候,直接寫對象的屬性就可以了;否則,你需要使用“#key”前綴,例如表達式#namager.name。
OGNL表達式
OGNL表達式的基礎(chǔ)單元就是導(dǎo)航鏈,通常簡稱為鏈(chain)。最簡單的鏈由下列部分組成:
1、屬性名:如name和manager.name;
2、方法調(diào)用:如manager.hashCode(),返回manager對象的散列碼;
3、數(shù)組索引:如emals[0],返回當(dāng)前對象的郵件列表中的第一個郵件地址。
所有OGNL表達式的計算都是在當(dāng)前對象的上下文中,一個鏈簡單地使用鏈中先前鏈接的結(jié)果作為下一步計算的當(dāng)前對象。我們看如下所示的鏈:
name.toCharArray()[0].numericValue.toString()
這個表達式按照下列的步驟進行計算:
1、獲取根對象的name屬性;
2、在String結(jié)果上調(diào)用toCharArray()方法;
3、從char數(shù)組中提取第一個字符;
4、從提取的字符對象上行到numericValue屬性(這個字符被表示為Character對象,Character類有一個getNumericValue()方法);
5、在Integer對象結(jié)果上調(diào)用toString()方法。
這個表達式最終結(jié)果是最后返回的toString()方法調(diào)用返回的字符串。
常量
OGNL支持的所有常量類型:
1、字符串常量:
以單引號或雙引號括起來的字符串。如”hello”,’hello’。
不過要注意的是,如果是單個字符的字符串常量,必須使用雙引號。
2、字符常量:
以單引號括起來的字符。如’a'。
3、數(shù)值常量:
除了Java中的int、long、float和double外,OGNL還讓你使用“b”或“B”后綴指定BigDecimal常量,用“h”“H”后綴指定BigInteger常量。
4、布爾常量:
true和false。
5、null常量。
操作符
OGNL除了支持所有的Java操作符外,還支持以下幾種:
1、逗號,
與C語言中的逗號操作符類似。
2、花括號{}
用于創(chuàng)建列表,元素之間用逗號分隔。
3、in和not in
用于判斷一個值是否在集合中。
訪問JavaBean的屬性
假如有一個employee對象作為OGNL上下文的根對象,那對于下面的表達式:
1、name
對應(yīng)的java代碼是employee.getName();
2、address.country
對應(yīng)的java代碼是employee.getAddress().getCountry();
訪問靜態(tài)方法和靜態(tài)字段
@class@method(args) //調(diào)用靜態(tài)方法
@class@field //調(diào)用靜態(tài)字段
其中class必須給出完整的類名(包括包名),如果省略class,那么默認使用的類是java.util.Math,如:
@@min(5,3)
@@max(5,3)
@@PI
索引訪問
OGNL支持多種索引方式的訪問。
1、數(shù)組和列表索引
在OGNL中,數(shù)組和列表可以大致看成是一樣的。
如:array[0]、list[0]。表達式:{’zhangsan’,'lisi’,'wangwu’}[1]等。
2、JavaBean的索引屬性
要使用索引屬性,需要提供兩對setter和getter方法,一對用于數(shù)組,一對用于數(shù)組中的元素。
如:有一個索引屬性interest,它的getter和setter如下
public String[] interest;
public String[] getInterest(){ return interest;}
public void setInterest(String[] interest){ this.interest=interest;}
public String getInterest(int i){ return interest[i]}
public void setInterest(int i, String newInterest){ interest[i]=newInterest;}
對于表達式interest[2],OGNL可以正確解釋這個表達式,調(diào)用getInterest(2)方法。如果是設(shè)置的情況下,會調(diào)用setInterest(2,value)方法。
3、OGNL對象的索引屬性
JavaBean的索引屬性只能使用整型作為索引,OGNL擴展了索引屬性的概念,可以使用任意的對象來作為索引。
對集合進行操作
1、創(chuàng)建集合:
創(chuàng)建列表
使用花括號將元素包含起來,元素之間使用逗號分隔。如{’zhangsan’,'lisi’,'wangwu’}
創(chuàng)建數(shù)組
OGNL中創(chuàng)建數(shù)組與Java語言中創(chuàng)建數(shù)組類似。
創(chuàng)建Map
Map使用特殊的語法來創(chuàng)建 #{”key”:value, ……}
如果想指定創(chuàng)建的Map類型,可以在左花括號前指定Map實現(xiàn)類的類名。如:
#@java.util.LinkedHashMap@{”key”:”value”,….}
Map通過key來訪問,如map["key"]或map.key。
2、投影
OGNL提供了一種簡單的方式在一個集合中對每一個元素聞?wù){(diào)用相同的方法,或者抽取相同的屬性,并將結(jié)果保存為一個新的集合,稱之為投影。
假如employees是一個包含了employee對象的列表,那么
#employees.{name}將返回所有雇員的名字的列表。
在投影期間,使用#this變量來引用迭代中的當(dāng)前元素。
如:objects.{#this instanceof String? #this: #this.toString()}
3、選擇
OGNL提供了一種簡單的方式來使用表達式從集合中選擇某些元素,并將結(jié)果保存到新的集合中,稱為選擇。
如#employees.{?#this.salary>3000}
將返回薪水大于3000的所有雇員的列表。
#employees.{^#this.salary>3000}
將返回第一個薪水大于3000的雇員的列表。
#employees.{$#this.salary>3000}
將返回最后一個薪水大于3000的雇員的列表。
lambda表達式
lambda表達式的語法是: :[...]。OGNL中的lambda表達式只能使用一個參數(shù),這個參數(shù)通過#this引用。
如:
#fact= :[ #this<=1 ? 1 : #this* #fact ( #this-1) ], #fact(30)
#fib= :[#this==0 ? 0 : #this==1 ? 1 : #fib(#this-2)+#fib(#this-1)], #fib(11)
<s:set name="hello" value="'Hello Miky as Miky'"></s:set> ----定義源字符串
<s:property value="#hello.substring(#hello.indexOf('as')+2)"/> ---輸出字符串。結(jié)果為 Miky
Struts2的值是保存在ValueStack中的,假設(shè)有一個字符串str,我們一般是這么取值的:
<s:property value="str"/> 或者 ${str}
如果想在jsp中使用的話,可以這么取:
<%@ page import="com.opensymphony.xwork2.util.ValueStack" %>
……
<%= ((ValueStack)request.getAttribute("struts.valueStack")).findString("str") %>
也可以把ValueStack中的值先放到attribute中,然后直接取attribute的值:
<s:set name="str" value="%{str}" />
<%=request.getAttribute("str") %>
方法一:
<s:set name="str" value="'Hello World'"></s:set>
<s:property value="%{@com.common.Constant@func(#str)}"/>
func是類com.common.Constant里面的一個靜態(tài)方法
str是動態(tài)的參數(shù)
方法二:
<s:bean name="com.common.StrutsHelper" id="helper" />
<s:set name="str" value="'Hello World'"></s:set>
<s:property value="#helper.func(#str)" />
func是類com.common.StrutsHelper里面的一個普通方法
str是動態(tài)方法
s:bean其實是對類StrutsHelper的實例化,跟方法一有些區(qū)別,方法一里的函數(shù)必須是靜態(tài)的
表 a 字段,id,開始時間,結(jié)束時間,價格
1,2008-01-01,2008-09-10,220.0
2,2008-09-11,2008-09-30,280.0
3,2008-10-01,2008-10-10,320.0
3,2008-10-11,2008-12-31,350.0
輸入一個開始時間,一個結(jié)束時間,返回這段時間內(nèi)每天的價格,最好返回每天的日期和對應(yīng)的價格
例輸入開始時間2008-09-09,結(jié)束時間2008-09-13
返回
2008-09-09,220
2008-09-10,220
2008-09-11,280
2008-09-12,280
2008-09-13,280
方案一:采用存儲過程的方案!
create table T([id] int,[開始時間] datetime,[結(jié)束時間] datetime,[價格] numeric(4,1))
insert into T
select 1,'2008-01-01','2008-09-10',220.0 union all
select 2,'2008-09-11','2008-09-30',280.0 union all
select 3,'2008-10-01','2008-10-10',320.0 union all
select 3,'2008-10-13','2008-12-31',350.0

select * from T
go
--Code
create procedure GetTimePrice(@begintime datetime,@endtime datetime)
as
declare @tmptime datetime
declare @tmp table (dt datetime,price numeric(4,1))--結(jié)果表
begin
set @tmptime=@begintime
while @tmptime<=@endtime
begin

insert into @tmp
select @tmptime,價格 from t where @tmptime between 開始時間 and 結(jié)束時間
set @tmptime=DATEADD(dd,1,@tmptime)
end
select * from @tmp
end
go

exec GetTimePrice '2008-09-09','2008-09-14'--執(zhí)行
--Drop
drop table T
drop procedure GetTimePrice
方案二:采用Case方案
set nocount on
create table T([id] int,[開始時間] datetime,[結(jié)束時間] datetime,[價格] numeric(4,1))
insert into T
select 1,'2008-01-01','2008-09-10',220.0 union all
select 2,'2008-09-11','2008-09-30',280.0 union all
select 3,'2008-10-01','2008-10-10',320.0 union all
select 3,'2008-10-11','2008-12-31',350.0

declare @bgnTime datetime set @bgnTime = '2008-09-09'
declare @endTime datetime set @endTime = '2008-09-13'
select id
,case when [開始時間]<@bgnTime then @bgnTime else [開始時間] end as [開始時間] -- 讓輸出結(jié)果更貼近參數(shù)表現(xiàn)出來
,case when [結(jié)束時間]>@endTime then @endTime else [結(jié)束時間] end as [結(jié)束時間] -- 讓輸出結(jié)果更貼近參數(shù)表現(xiàn)出來
,[價格]
from T
where [開始時間]<@endTime
and [結(jié)束時間]>@bgnTime
-- id,開始時間,結(jié)束時間
-- 1,2008-09-09 00:00:00.000,2008-09-10 00:00:00.000
-- 2,2008-09-11 00:00:00.000,2008-09-13 00:00:00.000

drop table T

id 開始時間 結(jié)束時間 價格
----------- ------------------------------------------------------ ------------------------------------------------------ ------
1 2008-09-09 00:00:00.000 2008-09-10 00:00:00.000 220.0
2 2008-09-11 00:00:00.000 2008-09-13 00:00:00.000 280.0


摘要: 一、jQuery實現(xiàn)input文本框內(nèi)灰色提示文本效果
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<titl...
閱讀全文
摘要: 酒店間夜價格顯示實現(xiàn):
跨周:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC&...
閱讀全文
今天在用XmlBeans解析XML DOC時,遇到“xmlbeans dom level 3 not implemented”的解決辦法!
問題產(chǎn)生的原因:
1、由于在生成的XML結(jié)構(gòu)中插入了一些未在XSD中定義的節(jié)點,那么這些節(jié)點無法用XMLBeans所采用的對象的方法獲取,只能采用DOM的方式來處理,但在處理的過程中報“xmlbeans dom level 3 not implemented”
//實例化一個文檔構(gòu)建器工廠
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setNamespaceAware(true);
//通過文檔構(gòu)建器工廠獲取一個文檔構(gòu)建器
DocumentBuilder builder = factory.newDocumentBuilder();
//通過文檔通過文檔構(gòu)建器構(gòu)建一個文檔實例
AssertionDocument assertionDoc = AssertionDocument.Factory.parse(new File(”xml/assertion.xml”), loadOptions);
Document doc = builder.parse(new InputSource(new StringReader(assertionDoc.toString())));
doc.getDocumentElement().setIdAttribute(”AssertionID”, true);