Format函数的用法总结如下:
函数声明
function Format(const Format: string; const Args: array of const): string; overload;
函数功能
事实上Format方法有两个种形式,另外一种是三个参数的,主要区别在于它是线程安全的, 但并不多用,所以这里只对第一个介绍。Format参数是一个格式字符串,用于格式化Args里面的值的。Args是一个变体数组,即它里面可以有多个参数,而且每个参数可以不同。 例如:
Format("my name is %6s","wind");
返回的是:my name is wind
函数参数
Format里面可以写普通的字符串,比如"my name is" ,但有些格式指令字符具有特殊意义,比如"%6s" 格式指令具有以下的形式: "%" [index ":"] ["-"] [width] ["." prec] type
它是以"%"开始,而以type结束,type表示一个具体的类型。中间是用来格式化type类型的指令字符,是可选的。各个参数的含义与用途如下;
[type]
type参数可选的类型有d,u,f,e,g,n,m,p,s,x.
1) d 十进制数,表示一个整型值,u 和d一样是整型值,但它是无符号的,而如果它对应的值是负的,则返回时是一个2的32次方减去这个负数的绝对值 。
例如:Format("this is %u",-2);
返回的是:this is 4294967294
2)f 对应浮点数
3)e科学表示法,对应整型数和浮点数
例如:Format("this is %e",-2.22);
返回的是:this is -2.220xx0E+000
4)g 这个只能对应浮点型,且它会将值中多余的数去掉
例如:Format("this is %g",02.200);
返回的是:this is 2.2
5)n 只能对应浮点型,将值转化为号码的形式,看一个例子就明白了
例如:Format("this is %n",4552.2176);
返回的是:this is 4,552.22
注意:一是,只表示到小数后两位
二是,即使小数没有被截断,它也不会也像整数部分一样有逗号来分开的
6)m 钱币类型,但关于货币类型有更好的格式化方法,这里只是简单的格式化,另外它只对应于浮点值 例如:Format("this is %m",9552.21);
返回的是:this is ¥9,552.21
7)p 对应于指针类型,返回的值是指针的地址,以十六进制的形式来表示
例如: Format("this is %p",p);
返回的是:this is 0012F548
8)s 对应字符串类型
9)x 必须是一个整形值,以十六进制的形式返回
例如:Format("this is %X",15);
返回的是:this is F
下面介绍格式化Type的指令:
[index ":"] :index指示Args中参数显示的顺序 。
例如:Format("this is %d %d",12,13);
其中第一个%d的索引是0,第二个%d是1,所以字符显示的时候,是这样:this is 12 13
若定义为:Format("this is %1:d %0:d",12,13);
那么返回的字符串就变成了:this is 13 12
若定义为:Format("%d %d %d %0:d %d", 1, 2, 3, 4) ;
那么将返回的是:1 2 3 1 2
若想返回的是1 2 3 1 4,必须这样定义:Format("%d %d %d %0:d %3:d", 1, 2, 3, 4) ;
注意:索引不能超出Args中的个数,不然会引起异常。
例如:Format("this is %2:d %0:d",12,13);
由于Args中只有12 13 两个数,所以Index只能是0或1,这里为2就错了 。
[width] :指定将被格式化的值占的宽度。
例如:Format("this is %4d",12);
返回的是:this is 12
如果Width的值小于参数的长度,则没有效果。
例如:Format("this is %1d",12);
返回的是:this is 12
["-"] :这个指定参数向左对齐,和[width]合在一起最可以看到效果。
例如:Format("this is %-4d,yes",12);
返回的是:this is 12 ,yes
["." prec] :指定精度,对于浮点数效果最佳。
例如:Format('this is %.2f,1.1234);
返回的是: this is 1.12
又如:Format('this is %.7f,1.1234);
返回的是: this is 1.1234000
而对于整型数,如果prec比如整型的位数小,则没有效果,反之比整形值的位数大,则会在整型值的前面以0补之。
例如:Format('this is %.7d,1234);
返回的是:this is 0001234
对于字符型,刚好和整型值相反,如果prec比字符串型的长度大,则没有效果,反之比字符串型的长度小,则会截断尾部的字符。
例如:Format('this is %.2s,1234);
返回的是:this is 12
之前说过的例子:Format("this is %e",-2.22);
返回的是:this is -2.220xx0E+000
若这样:Format('this is %.2e',[-2.22]); 就可以解决了!
第二篇:SQL中forXML语句用法总结
-------raw模式:raw模式将查询结果集中的每一行转换为带有通用标识符row或可能提供元素名称的xml元素。(将查询结果集中的每一行转换为row元素的属性或row元素的子无素) --------------------------------------------行集中非Null的每列值都将映射为row元素的一个属性--------------------------
select top 10 *
from mixtureMeasureMonitor
for xml raw
----------------------------------将elements指令添加到for xml子句,则行集中非null的每列值都将映射为row元素的一个子元素
-------------------------------------------------------------------------
select top 10 *
from mixtureMeasureMonitor
for xml raw,elements
-----------------------------------在指定elements指令的同时指定xsinil选项,则将行集中为null的每例值映射为具有属性xsi:nil="true"的一个元素
----------------------------------------------------------
select top 10 *
from mixtureMeasureMonitor
for xml raw,elements XSINIL
--------------------------------Auto模式根据查询确定返回的xml的形式---------------------------------------------
select pmm.id,pmm.ppId,pp.MixPropNo,pmm.criterion
from mixtureMeasureMonitor as pmm inner join
produceProportion as pp on pp.id=pmm.ppid and pp.cOrgID=pmm.cOrgID tOption as tp on tp.cValue=pmm.Criterion inner join
where tp.ckey='Criterion '
for xml auto
select
pmm.id,pp.MixPropNo,pmm.ppId,pmm.criterion,pmm.temperatureMark,pmm.remark
from mixtureMeasureMonitor as pmm inner join
produceProportion as pp on pp.id=pmm.ppid and pp.cOrgID=pmm.cOrgID tOption as tp on tp.cValue=pmm.Criterion inner join
where tp.ckey='Criterion '
for xml auto,elements xsinil
-----------------explicit模式:使用RAW和AUTO模式不能很好地控制从查询结果生成的XML的形状。但是,对于要从查询结果生成的XML,EXPLICIT模式会提供非常好的灵活性-------------------------------------------------------------------------------------
select
pp.MixPropNo,pmm.id,pmm.ppId,pmm.criterion,pmm.temperatureMark,pmm.remark
from mixtureMeasureMonitor as pmm inner join
produceProportion as pp on pp.id=pmm.ppid and pp.cOrgID=pmm.cOrgID tOption as tp on tp.cValue=pmm.Criterion inner join
where tp.ckey='Criterion '
for xml explicit
-------------------------OPENXML语句,对XML文件进行查询,然后返回指定的XML中的结果集数据---------------------------
/*openxml(idoc int [in],rowpattern nvarchar[in],[flags byte [in]])
[WITH(SchemaDeclaration|TableName)]
Idoc:XML文档的内部表示形式的文档句柄
RowPattern:XPath模式,用来标识要作为行处理的节点
Flags:指示应在XML数据和关系行集间使用映射,以及应如何填充溢出列
SchemaDeclaration:窗体的架构定义
TableName:如果具有所需架构的表已经存在且不要求列模式,则为给定的表名*/ DECLARE @idoc int
declare @doc varchar(20xx)
set @doc='
<ROOT>
<Customer CustomerID="LEO" ContactName="leo carol">
<Order CustomerID="LEO" EmployeeID="1" <OrderDetail OrderID="11111" ProductID="31" Quantity="1"/> <OrderDetail OrderID="11111" ProductID="32" Quantity="2"/> OrderDate="20xx-07-04T00:00:00"> </Order>
</Customer>
<Customer CustomerID="CAROL" ContactName="carol leo">
<Order CustomerID="CAROL" EmployeeID="2" <OrderDetail OrderID="22222" ProductID="33" Quantity="3"/> OrderDate="20xx-08-16T00:00:00"> </Order>
</Customer>
</ROOT>
'
EXEC sp_xml_preparedocument @idoc output,@doc
select *
from openxml(@idoc,'/ROOT/Customer',1)
with(CustomerID varchar(10),
ContactName varchar(20)) /*path()括号内的参数是控制节点名称的,不指定括号时控制节点默认是row。rooot选项来添加单个顶级元素*/
------------------path选项不带()时,默认控制节点是row,其他字段元素都是row元素
的子元素-----------------------------------------
select ID ,name
from MtrlBaseName
for xml path
--------------------------ID,name是product标签的子标签--------------- select ID ,name
from MtrlBaseName
for xml path('Product'),root('ProductExport')
------------------ID是Product标签的属性,name是Product标签的内容-----------------------------
select ID [@ID],name as [*]
from MtrlBaseName
for xml path('Product'),root('ProductExport')
------------------ID,name是Product标签的属性
-----------------------------------
select ID [@ID],name as [@name]
from MtrlBaseName
for xml path('Product'),root('ProductExport')