The Oracle TO_CHAR(datetime, fmt) function converts datetime values to a string in the format specified by the fmt option.
MySQL has the DATE_FORMAT function that allows datetime values converting to a string in the specified format.
SQLWays converts the Oracle TO_CHAR function to the MySQL DATE_FORMAT function and converts elements of format string from Oracle to corresponding specifier in MySQL as specified in the following table.
TABLE 56. Conversion of Oracle TO_CHAR(datetime) with format string to MySQL
Oracle
|
MySQL
|
---|---|
Ant的概念
可能有些讀者并不連接什么是Ant以及入可使用它,但只要使用通過Linux系統(tǒng)得讀者,應(yīng)該知道make這個(gè)命令。當(dāng)編譯Linux內(nèi)核及一些軟件的源程序時(shí),經(jīng)常要用這個(gè)命令。Make命令其實(shí)就是一個(gè)項(xiàng)目管理工具,而Ant所實(shí)現(xiàn)功能與此類似。像make,gnumake和nmake這些編譯工具都有一定的缺陷,但是Ant卻克服了這些工具的缺陷。最A(yù)nt開發(fā)者在開發(fā)跨平臺(tái)的應(yīng)用時(shí),用樣也是基于這些缺陷對(duì)Ant做了更好的設(shè)計(jì)。
Ant 與 makefile
Makefile有一些不足之處,比如很多人都會(huì)碰到的煩人的Tab問題。最初的Ant開發(fā)者多次強(qiáng)調(diào)”只是我在Tab前面加了一個(gè)空格,所以我的命令就不能執(zhí)行”。有一些工具在一定程度上解決了這個(gè)問題,但還是有很多其他的問題。Ant則與一般基于命令的工具有所不同,它是Java類的擴(kuò)展。Ant運(yùn)行需要的XML格式的文件不是Shell命令文件。它是由一個(gè)Project組成的,而一個(gè)Project又可分成可多target,target再細(xì)分又分成很多task,每一個(gè)task都是通過一個(gè)實(shí)現(xiàn)特定接口的java類來完成的。
Ant的優(yōu)點(diǎn)
Ant是Apache軟件基金會(huì)JAKARTA目錄中的一個(gè)子項(xiàng)目,它有以下的優(yōu)點(diǎn)。跨平臺(tái)性。Ant是存Java語言編寫的,所示具有很好的跨平臺(tái)性。操作簡(jiǎn)單。Ant是由一個(gè)內(nèi)置任務(wù)和可選任務(wù)組成的。Ant運(yùn)行時(shí)需要一個(gè)XML文件(構(gòu)建文件)。Ant通過調(diào)用target樹,就可以執(zhí)行各種task。每個(gè)task實(shí)現(xiàn)了特定接口對(duì)象。由于Ant構(gòu)建文件時(shí)XML格式的文件,所以和容易維護(hù)和書寫,而且結(jié)構(gòu)很清晰。Ant可以集成到開發(fā)環(huán)境中。由于Ant的跨平臺(tái)性和操作簡(jiǎn)單的特點(diǎn),它很容易集成到一些開發(fā)環(huán)境中去。
Ant 開發(fā)
Ant的構(gòu)建文件
當(dāng)開始一個(gè)新的項(xiàng)目時(shí),首先應(yīng)該編寫Ant構(gòu)建文件。構(gòu)建文件定義了構(gòu)建過程,并被團(tuán)隊(duì)開發(fā)中每個(gè)人使用。Ant構(gòu)建文件默認(rèn)命名為build.xml,也可以取其他的名字。只不過在運(yùn)行的時(shí)候把這個(gè)命名當(dāng)作參數(shù)傳給Ant。構(gòu)建文件可以放在任何的位置。一般做法是放在項(xiàng)目頂層目錄中,這樣可以保持項(xiàng)目的簡(jiǎn)潔和清晰。下面是一個(gè)典型的項(xiàng)目層次結(jié)構(gòu)。
(1)
(2)
(3)
(4)
Ant構(gòu)建文件是XML文件。每個(gè)構(gòu)建文件定義一個(gè)唯一的項(xiàng)目(Project元素)。每個(gè)項(xiàng)目下可以定義很多目標(biāo)(target元素),這些目標(biāo)之間可以有依賴關(guān)系。當(dāng)執(zhí)行這類目標(biāo)時(shí),需要執(zhí)行他們所依賴的目標(biāo)。每個(gè)目標(biāo)中可以定義多個(gè)任務(wù),目標(biāo)中還定義了所要執(zhí)行的任務(wù)序列。Ant在構(gòu)建目標(biāo)時(shí)必須調(diào)用所定義的任務(wù)。任務(wù)定義了Ant實(shí)際執(zhí)行的命令。Ant中的任務(wù)可以為3類。
(1) 核心任務(wù)。核心任務(wù)是Ant自帶的任務(wù)。
(2) 可選任務(wù)??蛇x任務(wù)實(shí)來自第三方的任務(wù),因此需要一個(gè)附加的JAR文件。
(3) 用戶自定義的任務(wù)。用戶自定義的任務(wù)實(shí)用戶自己開發(fā)的任務(wù)。
1.<project>標(biāo)簽
每個(gè)構(gòu)建文件對(duì)應(yīng)一個(gè)項(xiàng)目。<project>標(biāo)簽時(shí)構(gòu)建文件的根標(biāo)簽。它可以有多個(gè)內(nèi)在屬性,就如代碼中所示,其各個(gè)屬性的含義分別如下。
(1)
(2)
(3)
(4)
每個(gè)構(gòu)建文件都對(duì)應(yīng)于一個(gè)項(xiàng)目,但是大型項(xiàng)目經(jīng)常包含大量的子項(xiàng)目,每一個(gè)子項(xiàng)目都可以有
2.<target>標(biāo)簽
一個(gè)項(xiàng)目標(biāo)簽下可以有一個(gè)或多個(gè)target標(biāo)簽。一個(gè)target標(biāo)簽可以依賴其他的target標(biāo)簽。例如,有一個(gè)target用于編譯程序,另一個(gè)target用于聲稱可執(zhí)行文件。在生成可執(zhí)行文件之前必須先編譯該文件,因策可執(zhí)行文件的target依賴于編譯程序的target。Target的所有屬性如下。
(1) .name表示標(biāo)明,這個(gè)屬性是必須的。
(2) .depends表示依賴的目標(biāo)。
(3) if表示僅當(dāng)屬性設(shè)置時(shí)才執(zhí)行。
(4) unless表示當(dāng)屬性沒有設(shè)置時(shí)才執(zhí)行。
(5) description表示項(xiàng)目的描述。
Ant的depends屬性指定了target的執(zhí)行順序。Ant會(huì)依照depends屬性中target出現(xiàn)順序依次執(zhí)行每個(gè)target。在執(zhí)行之前,首先需要執(zhí)行它所依賴的target。程序中的名為run的target的depends屬性compile,而名為compile的target的depends屬性是prepare,所以這幾個(gè)target執(zhí)行的順序是prepare->compile->run。一個(gè)target只能被執(zhí)行一次,即使有多個(gè)target依賴于它。如果沒有if或unless屬性,target總會(huì)被執(zhí)行。
3.<mkdir>標(biāo)簽
該標(biāo)簽用于創(chuàng)建一個(gè)目錄,它有一個(gè)屬性dir用來指定所創(chuàng)建的目錄名,其代碼如下:
<mkdir dir=”${class.root}”/>
通過以上代碼就創(chuàng)建了一個(gè)目錄,這個(gè)目錄已經(jīng)被前面的property標(biāo)簽所指定。
4<jar>標(biāo)簽
該標(biāo)簽用來生成一個(gè)JAR文件,其屬性如下。
(1)
(2)
(3)
(4)
5.<javac標(biāo)簽>
該標(biāo)簽用于編譯一個(gè)或一組java文件,其屬性如下。
(1).srcdir表示源程序的目錄。
(2).destdir表示class文件的輸出目錄。
(3).include表示被編譯的文件的模式。
(4).excludes表示被排除的文件的模式。
(5).classpath表示所使用的類路徑。
(6).debug表示包含的調(diào)試信息。
(7).optimize表示是否使用優(yōu)化。
(8).verbose 表示提供詳細(xì)的輸出信息。
(9).fileonerror表示當(dāng)碰到錯(cuò)誤就自動(dòng)停止。
6.<java>標(biāo)簽
該標(biāo)簽用來執(zhí)行編譯生成的.class文件,其屬性如下。
(1).classname 表示將執(zhí)行的類名。
(2).jar表示包含該類的JAR文件名。
(3).classpath所表示用到的類路徑。
(4).fork表示在一個(gè)新的虛擬機(jī)中運(yùn)行該類。
(5).failonerror表示當(dāng)出現(xiàn)錯(cuò)誤時(shí)自動(dòng)停止。
(6).output 表示輸出文件。
(7).append表示追加或者覆蓋默認(rèn)文件。
7.<delete>標(biāo)簽
該標(biāo)簽用于刪除一個(gè)文件或一組文件,去屬性如下。
(1)/file表示要?jiǎng)h除的文件。
(2).dir表示要?jiǎng)h除的目錄。
(3).includeEmptyDirs 表示指定是否要?jiǎng)h除空目錄,默認(rèn)值是刪除。
(4).failonerror 表示指定當(dāng)碰到錯(cuò)誤是否停止,默認(rèn)值是自動(dòng)停止。
(5).verbose表示指定是否列出所刪除的文件,默認(rèn)值為不列出。
8.<copy>標(biāo)簽
該標(biāo)簽用于文件或文件集的拷貝,其屬性如下。
(1).file 表示源文件。
(2).tofile 表示目標(biāo)文件。
(3).todir 表示目標(biāo)目錄。
(4).overwrite 表示指定是否覆蓋目標(biāo)文件,默認(rèn)值是不覆蓋。
(5).includeEmptyDirs 表示制定是否拷貝空目錄,默認(rèn)值為拷貝。
(6).failonerror 表示指定如目標(biāo)沒有發(fā)現(xiàn)是否自動(dòng)停止,默認(rèn)值是停止。
(7).verbose 表示制定是否顯示詳細(xì)信息,默認(rèn)值不顯示。
Ant的數(shù)據(jù)類型
在構(gòu)建文件中為了標(biāo)識(shí)文件或文件組,經(jīng)常需要使用數(shù)據(jù)類型。數(shù)據(jù)類型包含在org.apache.tool.ant.types包中。下面鏡簡(jiǎn)單介紹構(gòu)建文件中一些常用的數(shù)據(jù)類型。
1.
由Ant構(gòu)建文件調(diào)用的程序,可以通過<arg>元素向其傳遞命令行參數(shù),如apply,exec和java任
(1).values 是一個(gè)命令參數(shù)。如果參數(shù)種有空格,但又想將它作為單獨(dú)一個(gè)值,則使用此屬性。
(2).file表示一個(gè)參數(shù)的文件名。在構(gòu)建文件中,此文件名相對(duì)于當(dāng)前的工作目錄。
(3).line表示用空格分隔的多個(gè)參數(shù)列表。
(4).path表示路徑。
2.ervironment 類型
由Ant構(gòu)建文件調(diào)用的外部命令或程序,<env>元素制定了哪些環(huán)境變量要傳遞給正在執(zhí)行的系統(tǒng)命令,<env>元素可以接受以下屬性。
(1).file表示環(huán)境變量值得文件名。此文件名要被轉(zhuǎn)換位一個(gè)絕對(duì)路徑。
(2).path表示環(huán)境變量的路徑。Ant會(huì)將它轉(zhuǎn)換為一個(gè)本地約定。
(3).value 表示環(huán)境變量的一個(gè)直接變量。
(4).key 表示環(huán)境變量名。
注意
3.filelist類型
Filelist 是一個(gè)支持命名的文件列表的數(shù)據(jù)類型,包含在一個(gè)filelist類型中的文件不一定是存在的文件。以下是其所有的屬性。
(1).dir是用于計(jì)算絕對(duì)文件名的目錄。
(2).files 是用逗號(hào)分隔的文件名列表。
(3).refid 是對(duì)某處定義的一個(gè)<filelist>的引用。
注意
4.fileset類型
Fileset 數(shù)據(jù)類型定義了一組文件,并通常表示為<fileset>元素。不過,許多ant任務(wù)構(gòu)建成了隱式的fileset,這說明他們支持所有的fileset屬性和嵌套元素。以下為fileset 的屬性列表。
(1).dir表示fileset 的基目錄。
(2).casesensitive的值如果為false,那么匹配文件名時(shí),fileset不是區(qū)分大小寫的,其默認(rèn)值為true.
(3).defaultexcludes 用來確定是否使用默認(rèn)的排除模式,默認(rèn)為true。
(4).excludes 是用逗號(hào)分隔的需要派出的文件模式列表。
(5).excludesfile 表示每行包含一個(gè)排除模式的文件的文件名。
(6).includes 是用逗號(hào)分隔的,需要包含的文件模式列表。
(7).includesfile 表示每行包括一個(gè)包含模式的文件名。
5.patternset 類型
Fileset 是對(duì)文件的分組,而patternset是對(duì)模式的分組,他們是緊密相關(guān)的概念。
<patternset>支持4個(gè)屬性:includes excludex includexfile 和 excludesfile,與fileset相同。Patternset 還允許以下嵌套元素:include,exclude,includefile 和 excludesfile.
6.filterset 類型
Filterset定義了一組過濾器,這些過濾器將在文件移動(dòng)或復(fù)制時(shí)完成文件的文本替換。
主要屬性如下:
(1).begintoken 表示嵌套過濾器所搜索的記號(hào),這是標(biāo)識(shí)其開始的字符串。
(2).endtoken表示嵌套過濾器所搜索的記號(hào)這是標(biāo)識(shí)其結(jié)束的字符串。
(3).id是過濾器的唯一標(biāo)志符。
(4).refid是對(duì)構(gòu)建文件中某處定義一個(gè)過濾器的引用。
7.Path類型
Path元素用來表示一個(gè)類路徑,不過它還可以用于表示其他的路徑。在用作揖個(gè)屬性時(shí),路經(jīng)中的各項(xiàng)用分號(hào)或冒號(hào)隔開。在構(gòu)建的時(shí)候,此分隔符將代替當(dāng)前平臺(tái)中所有的路徑分隔符,其擁有的屬性如下。
(1).location 表示一個(gè)文件或目錄。Ant在內(nèi)部將此擴(kuò)展為一個(gè)絕對(duì)路徑。
(2).refid 是對(duì)當(dāng)前構(gòu)建文件中某處定義的一個(gè)path的引用。
(3).path表示一個(gè)文件或路徑名列表。
8.mapper類型
Mapper類型定義了一組輸入文件和一組輸出文件間的關(guān)系,其屬性如下。
(1).classname 表示實(shí)現(xiàn)mapper類的類名。當(dāng)內(nèi)置mapper不滿足要求時(shí),用于創(chuàng)建定制mapper.
(2).classpath表示查找一個(gè)定制mapper時(shí)所用的類型路徑。
(3).classpathref是對(duì)某處定義的一個(gè)類路徑的引用。
(4).from屬性的含義取決于所用的mapper.
(5).to屬性的含義取決于所用的mapper.
(6).type屬性的取值為identity,flatten glob merge
Ant 的運(yùn)行
安裝好Ant并且配置好路徑之后,在命令行中切換到構(gòu)建文件的目錄,輸入Ant命令就可以運(yùn)行Ant.若沒有指定任何參數(shù),Ant會(huì)在當(dāng)前目錄下查詢build.xml文件。如果找到了就用該文件作為構(gòu)建文件。如果使用了 –find 選項(xiàng),Ant 就會(huì)在上級(jí)目錄中找構(gòu)建文件,直至到達(dá)文件系統(tǒng)得跟目錄。如果構(gòu)建文件的名字不是build.xml ,則Ant運(yùn)行的時(shí)候就可以使用 –buildfile file ,這里file 指定了要使用的構(gòu)建文件的名稱,示例如下:
Ant
如下說明了表示當(dāng)前目錄的構(gòu)建文件為build.xml 運(yùn)行 ant 執(zhí)行默認(rèn)的目標(biāo)。
Ant –buildfile
使用當(dāng)前目錄下的test.xml 文件運(yùn)行Ant ,執(zhí)行默認(rèn)的目標(biāo)
小寫
α |
β |
γ |
δ |
ε |
ζ |
Alpha |
Beta |
Gamma |
Delta |
Epsilon |
Zeta |
ν |
ξ |
ο |
π |
ρ |
σ |
Nu |
Xi |
Omicron |
Pi |
Rho |
Sigma |
η |
θ |
ι |
κ |
λ |
μ |
Eta |
Theta |
Iota |
Kappa |
Lambada |
Mu |
τ |
υ |
φ |
χ |
ψ |
ω |
Tau |
Upsilon |
Phi |
Chi |
Psi |
Omega |
大寫
α |
β |
γ |
δ |
ε |
ζ |
Alpha |
Beta |
Gamma |
Delta |
Epsilon |
Zeta |
ν |
ξ |
ο |
π |
ρ |
σ |
Nu |
Xi |
Omicron |
Pi |
Rho |
Sigma |
η |
θ |
ι |
κ |
λ |
μ |
Eta |
Theta |
Iota |
Kappa |
Lambada |
Mu |
τ |
υ |
φ |
χ |
ψ |
ω |
Tau |
Upsilon |
Phi |
Chi |
Psi |
Omega |
復(fù)習(xí)多線程,一個(gè)經(jīng)典的實(shí)例:生產(chǎn)者消費(fèi)者問題:
1.number表示產(chǎn)品編號(hào),flag表示現(xiàn)在應(yīng)該由誰來操作.
2.ProcuctData類中有兩個(gè)同步方法setNumber()和getNumber(),分別代表生產(chǎn)者生產(chǎn)產(chǎn)品和消費(fèi)者消費(fèi) 產(chǎn)品。
3.兩個(gè)線程類Producer和Consumer分別代表生產(chǎn)者與消費(fèi)者
一個(gè)JAR包,可用RAR等解壓文件解壓縮后查看代碼hfdp.jar
包括對(duì)bug的修復(fù)和在7.0M2和 6.6版本的加強(qiáng)。提供的支持包括:Eclipse 3.4.1/Ganymede、REST web服務(wù)、新的myeclipse操作板、spring工具集更新、集成Manven2、open JPA支持、高級(jí)javascript工具、專業(yè)的jsdt實(shí)現(xiàn)、報(bào)表工具加強(qiáng)、jsf和ICEfaces工具更。
The MyEclipse 7.0 production release includes enhancements and bug fixes for the MyEclipse environment over the previous 7.0 milestone and 6.6 production releases. Notably, this release includes support for the Eclipse 3.4.1/Ganymede platform, REST Web Services, a new MyEclipse dashboard, Spring tools update, integration with Maven 2 (m2e), Open JPA support, advances in JavaScript tooling, a professional implimentation of JSDT, enhancements to MyEclipse Reports tooling and updates to MyEclipse's extensive JSF and ICEfaces tooling.
windows集成版本下載地址: http://downloads.myeclipseide.com/downloads/products/eworkbench/7.0/myeclipse-7.0-win32.exe
1. JS代碼:
2.GridView代碼:
3.后臺(tái)獲取CheckBox狀態(tài)代碼
說明: 1.JS實(shí)現(xiàn)了對(duì)CHECKBOX的全選(取消全選)功能
2.實(shí)現(xiàn)了GRIDVIEW的第一列顯示為CHECKBOX
3.實(shí)現(xiàn)了對(duì)GRIDVIEW 中的gvChkBox控件的取值
這個(gè)做法沒什么新意,就是就用一個(gè)Hidden,不過里面有些問題有搞了半天,聽說細(xì)細(xì)說來。
還是先上代碼(代碼跟上一篇的差不多):
1.JS的代碼
2.Hidden
3.C#服務(wù)端
這個(gè)里面有一點(diǎn)我很搞不懂:網(wǎng)上很多同志都說在給Hidden賦值時(shí)要用下面這樣的語句(而且都說成功了)
一開始我也是這樣的,但我用了ASP.net的BUTTON來觸發(fā)的,死活取不到值。后來我用了HTML中的BUTTON進(jìn)了測(cè)試,發(fā)現(xiàn)報(bào)了一個(gè)空對(duì)象的錯(cuò)誤,我才發(fā)現(xiàn),這種方法根本無法取到Hidden控件的值,為什么,因?yàn)檫@個(gè)Hidden 控件是runat="Server"的,即為一個(gè)服務(wù)端的控件,我把runat="Server"鼓起去掉后,即:
就可以正常取到值。
后來想來想去,我用了
今天實(shí)現(xiàn)了兩個(gè)效果,一個(gè)是用JS來遍歷GRIDVIEW中的DROPDOWNLIST控件,一個(gè)是從C#服務(wù)端來讀取JS中的變量(當(dāng)然返回值的原理也一樣)。下面先介紹一下用JS來遍歷GRIDVIEW中控件的效果。
不說廢話,先上代碼:
1.
這個(gè)單元格中第一個(gè)dropdownlist控件(因?yàn)樵谇芭_(tái)用瀏覽器查看源代碼,我們發(fā)現(xiàn)Asp.net的dropdownlist就是HTML里的select),所以getElementsByTagName里應(yīng)該是“select”。
差不多就是這樣了,OK,結(jié)束,嘿嘿。
■“文本框”用於顯示單個(gè)實(shí)例資料。文本框可以放在報(bào)表上的任何位置,可以包含標(biāo)籤、欄位或計(jì)算資料。您可以使用運(yùn)算式來定義文字方塊中的資料。
■“表”是用於創(chuàng)建表格格式報(bào)表或向報(bào)表添加表結(jié)構(gòu)的資料區(qū)域。
■“矩陣”是將資料排列成在特定資料點(diǎn)相交的列和行的資料區(qū)域。矩陣的功能與交叉表和透視表類似。與包括一組靜態(tài)列的表不同的是,矩陣的列可以是動(dòng)態(tài)的。可以定義包含靜態(tài)列、靜態(tài)行、動(dòng)態(tài)列和動(dòng)態(tài)行的矩陣。
■“圖像”用於在報(bào)表中顯示二進(jìn)位圖像資料??梢允褂?.bmp、.jpeg、.gif 和 .png 格式的外部圖像、嵌入圖像或資料庫圖像。
■“子報(bào)表”用於將一個(gè)報(bào)表嵌入到另一個(gè)報(bào)表。子報(bào)表可以是獨(dú)立運(yùn)行的完整報(bào)表,也可以是嵌入到主報(bào)表中才表現(xiàn)最佳的報(bào)表。定義子報(bào)表時(shí),還可以定義用於篩選子報(bào)表資料的參數(shù)。
■“清單”是用於顯示單個(gè)欄位的重複行資料或包含其他報(bào)表項(xiàng)的資料區(qū)域。
■“矩形”用作圖形元素或作為其他報(bào)表項(xiàng)的容器。如果在矩形內(nèi)放入報(bào)表項(xiàng),則可以隨矩形一起移動(dòng)這些報(bào)表項(xiàng)。
■“線條”是可放在頁面上任何位置的圖形元素。線條沒有與其關(guān)聯(lián)的資料。
1、DateTime 數(shù)字型
System.DateTime currentTime=new System.DateTime();
1.1 取當(dāng)前年月日時(shí)分秒
currentTime=System.DateTime.Now;
1.2 取當(dāng)前年
int 年=currentTime.Year;
1.3 取當(dāng)前月
int 月=currentTime.Month;
1.4 取當(dāng)前日
int 日=currentTime.Day;
1.5 取當(dāng)前時(shí)
int 時(shí)=currentTime.Hour;
1.6 取當(dāng)前分
int 分=currentTime.Minute;
1.7 取當(dāng)前秒
int 秒=currentTime.Second;
1.8 取當(dāng)前毫秒
int 毫秒=currentTime.Millisecond;
(變量可用中文)
1.9 取中文日期顯示——年月日時(shí)分
string strY=currentTime.ToString("f"); //不顯示秒
1.10 取中文日期顯示_年月
string strYM=currentTime.ToString("y");
1.11 取中文日期顯示_月日
string strMD=currentTime.ToString("m");
1.12 取當(dāng)前年月日,格式為:
string strYMD=currentTime.ToString("d");
1.13 取當(dāng)前時(shí)分,格式為:14:24
string strT=currentTime.ToString("t");
更多介紹:
在使用Asp.net的過程中,我們經(jīng)常需要對(duì)時(shí)間日期進(jìn)行轉(zhuǎn)換,達(dá)到不同的顯示效果。默認(rèn)格式為:2006-6-6 14:33:34 ,如果要換成成200606,06-2006,2006-6-6或更多的格式該怎么辦呢?
這里將要用到:DateTime.ToString的方法(String, IFormatProvider)
示例:
using System;
using System.Globalization;
String format="D";
DateTime date=DataTime.Now;
Response.Write(date.ToString(format, DateTimeFormatInfo.InvariantInfo));
結(jié)果輸出
Thursday, June 16, 2006
在這里列出了參數(shù)format格式詳細(xì)用法
=======================
格式字符 關(guān)聯(lián)屬性/說明
d ShortDatePattern
D LongDatePattern
f 完整日期和時(shí)間(長(zhǎng)日期和短時(shí)間)
F FullDateTimePattern(長(zhǎng)日期和長(zhǎng)時(shí)間)
g 常規(guī)(短日期和短時(shí)間)
G 常規(guī)(短日期和長(zhǎng)時(shí)間)
m、M MonthDayPattern
r、R RFC1123Pattern
s 使用當(dāng)?shù)貢r(shí)間的 SortableDateTimePattern(基于 ISO 8601)
t ShortTimePattern
T LongTimePattern
u UniversalSortableDateTimePattern 用于顯示通用時(shí)間的格式
U 使用通用時(shí)間的完整日期和時(shí)間(長(zhǎng)日期和長(zhǎng)時(shí)間)
y、Y YearMonthPattern
下表列出了可被合并以構(gòu)造自定義模式的模式
========================================
這些模式是區(qū)分大小寫的;例如,識(shí)別“MM”,但不識(shí)別“mm”。如果自定義模式包含空白字符或用單引號(hào)括起來的字符,則輸出字符串頁也將包含這些字符。未定義為格式模式的一部分或未定義為格式字符的字符按其原義復(fù)制。
格式模式 說明 :
d 月中的某一天。一位數(shù)的日期沒有前導(dǎo)零。
dd 月中的某一天。一位數(shù)的日期有一個(gè)前導(dǎo)零。
ddd 周中某天的縮寫名稱,在 AbbreviatedDayNames 中定義。
dddd 周中某天的完整名稱,在 DayNames 中定義。
M 月份數(shù)字。一位數(shù)的月份沒有前導(dǎo)零。
MM 月份數(shù)字。一位數(shù)的月份有一個(gè)前導(dǎo)零。
MMM 月份的縮寫名稱,在 AbbreviatedMonthNames 中定義。
MMMM 月份的完整名稱,在 MonthNames 中定義。
y 不包含紀(jì)元的年份。如果不包含紀(jì)元的年份小于 10,則顯示不具有前導(dǎo)零的年份。
yy 不包含紀(jì)元的年份。如果不包含紀(jì)元的年份小于 10,則顯示具有前導(dǎo)零的年份。
yyyy 包括紀(jì)元的四位數(shù)的年份。
gg 時(shí)期或紀(jì)元。如果要設(shè)置格式的日期不具有關(guān)聯(lián)的時(shí)期或紀(jì)元字符串,則忽略該模式。
h 12 小時(shí)制的小時(shí)。一位數(shù)的小時(shí)數(shù)沒有前導(dǎo)零。
hh 12 小時(shí)制的小時(shí)。一位數(shù)的小時(shí)數(shù)有前導(dǎo)零。
H 24 小時(shí)制的小時(shí)。一位數(shù)的小時(shí)數(shù)沒有前導(dǎo)零。
HH 24 小時(shí)制的小時(shí)。一位數(shù)的小時(shí)數(shù)有前導(dǎo)零。
m 分鐘。一位數(shù)的分鐘數(shù)沒有前導(dǎo)零。
mm 分鐘。一位數(shù)的分鐘數(shù)有一個(gè)前導(dǎo)零。
s 秒。一位數(shù)的秒數(shù)沒有前導(dǎo)零。
ss 秒。一位數(shù)的秒數(shù)有一個(gè)前導(dǎo)零。
f 秒的小數(shù)精度為一位。其余數(shù)字被截?cái)唷?/p>
ff 秒的小數(shù)精度為兩位。其余數(shù)字被截?cái)唷?/p>
fff 秒的小數(shù)精度為三位。其余數(shù)字被截?cái)唷?/p>
ffff 秒的小數(shù)精度為四位。其余數(shù)字被截?cái)唷?/p>
fffff 秒的小數(shù)精度為五位。其余數(shù)字被截?cái)唷?/p>
ffffff 秒的小數(shù)精度為六位。其余數(shù)字被截?cái)唷?/p>
fffffff 秒的小數(shù)精度為七位。其余數(shù)字被截?cái)唷?/p>
t 在 AMDesignator 或 PMDesignator 中定義的 AM/PM 指示項(xiàng)的第一個(gè)字符(如果存在)。
tt 在 AMDesignator 或 PMDesignator 中定義的 AM/PM 指示項(xiàng)(如果存在)。
z 時(shí)區(qū)偏移量(“+”或“-”后面僅跟小時(shí))。一位數(shù)的小時(shí)數(shù)沒有前導(dǎo)零。例如,太平洋標(biāo)準(zhǔn)時(shí)間是“-8”。
zz 時(shí)區(qū)偏移量(“+”或“-”后面僅跟小時(shí))。一位數(shù)的小時(shí)數(shù)有前導(dǎo)零。例如,太平洋標(biāo)準(zhǔn)時(shí)間是“-08”。
zzz 完整時(shí)區(qū)偏移量(“+”或“-”后面跟有小時(shí)和分鐘)。一位數(shù)的小時(shí)數(shù)和分鐘數(shù)有前導(dǎo)零。例如,太平洋標(biāo)準(zhǔn)時(shí)間是“-08:00”。
: 在 TimeSeparator 中定義的默認(rèn)時(shí)間分隔符。
/ 在 DateSeparator 中定義的默認(rèn)日期分隔符。
% c 其中 c 是格式模式(如果單獨(dú)使用)。如果格式模式與原義字符或其他格式模式合并,則可以省略“%”字符。
\ c 其中 c 是任意字符。照原義顯示字符。若要顯示反斜杠字符,請(qǐng)使用“\\”。
只有上面第二個(gè)表中列出的格式模式才能用于創(chuàng)建自定義模式;在第一個(gè)表中列出的標(biāo)準(zhǔn)格式字符不能用于創(chuàng)建自定義模式。自定義模式的長(zhǎng)度至少為兩個(gè)字符;例如,
DateTime.ToString( "d") 返回 DateTime 值;“d”是標(biāo)準(zhǔn)短日期模式。
DateTime.ToString( "%d") 返回月中的某天;“%d”是自定義模式。
DateTime.ToString( "d ") 返回后面跟有一個(gè)空白字符的月中的某天;“d”是自定義模式。
比較方便的是,上面的參數(shù)可以隨意組合,并且不會(huì)出錯(cuò),多試試,肯定會(huì)找到你要的時(shí)間格式
如要得到2005年06月 這樣格式的時(shí)間
可以這樣寫:
date.ToString("yyyy年MM月", DateTimeFormatInfo.InvariantInfo)
如此類推.
下面列出一些Asp.net中具體的日期格式化用法:
============================================
1.綁定時(shí)格式化日期方法:
<ASP:BOUNDCOLUMN DATAFIELD= "JoinTime " DATAFORMATSTRING= "{0:yyyy-MM-dd} " >
<ITEMSTYLE WIDTH= "18% " > </ITEMSTYLE >
</ASP:BOUNDCOLUMN >
2.數(shù)據(jù)控件如DataGrid/DataList等的件格式化日期方法:
e.Item.Cell[0].Text = Convert.ToDateTime(e.Item.Cell[0].Text).ToShortDateString();
3.用String類轉(zhuǎn)換日期顯示格式:
String.Format( "yyyy-MM-dd ",yourDateTime);
4.用Convert方法轉(zhuǎn)換日期顯示格式:
Convert.ToDateTime("2005-8-23").ToString
("yyMMdd",System.Globalization.DateTimeFormatInfo.InvariantInfo); //支持繁體數(shù)據(jù)庫
5.直接用ToString方法轉(zhuǎn)換日期顯示格式:
DateTime.Now.ToString("yyyyMMddhhmmss");
DateTime.Now.ToString("yyyy/MM/dd hh:mm:ss")
6.只顯示年月
DataBinder.Eval(Container.DataItem,"starttime","{0:yyyy-M}")
7.顯示時(shí)間所有部分,包括:年月日時(shí)分秒
<asp:BoundColumn DataField="收款時(shí)間" HeaderText="收款時(shí)間"
DataFormatString="{0:yyyy-MM-dd HH24:mm:ss}">
</asp:BoundColumn>
[ASP.NET] 如何在GridView中使用DataFromatString
在我們從業(yè)務(wù)邏輯層獲得數(shù)據(jù)實(shí)體時(shí)候,接下來的事情就是要綁定到控件中。數(shù)據(jù)實(shí)體中的一些字段可以直接綁定到界面中,但是有一些字段需要重新格 式化格式。比如貨幣單位字段,需要顯示貨幣符號(hào)和每隔三位顯示分隔符;再比如日期字段,數(shù)據(jù)庫中存放的是日期和時(shí)間,但是在界面上需要按照XXXX年XX 月XX日的格式顯示。這時(shí)候我們就用到了DataFormatString屬性。
<asp:GridView ID="grvResult" runat="server" AutoGenerateColumns="False" Width="100%">
<Columns>
<asp:BoundField HeaderText="預(yù)定日期" DataField="OperationDate" DataFormatString="{0:yyyy-MM-dd}" HtmlEncode="False">
</asp:BoundField>
<asp:BoundField HeaderText="訂單總計(jì)" DataField="TotalRate" DataFormatString="{0:C}" HtmlEncode="False">
</asp:BoundField>
</Columns>
</asp:GridView>
例如上面的代碼展示了日期和貨幣兩種綁定方式。DataFormatString中的{0}是固定的格式,這和 String.Fromat(“{0}”, someString)中的{0}是一個(gè)用法,表示綁定上下文的參數(shù)索引編號(hào)。然后,在后面加入格式化字符串,具體的使用方法可以參考MSDN。
這里需要注意以下幾點(diǎn)
1. 在GridView中的asp:BoundField使用DataFormatString必須設(shè)置屬性HtmlEncode="False",否則不起作用。
2. 如果需要使用日期類型的格式化字符串,必須數(shù)據(jù)實(shí)體中對(duì)應(yīng)的字段也應(yīng)該日起類型的。
3. 格式化字符串C代表貨幣單位,需要綁定的數(shù)據(jù)類型應(yīng)該是數(shù)字類型的。如果是字符串類型的不起作用,需要手動(dòng)添加格式化字符串為DataFormatString="¥{0:C}"。