易截截图软件、单文件、免安装、纯绿色、仅160KB

SQL 2005中用XML nodes()函数取代OPENXML

SQL Server 2005为XML提供本地支持;现在可以在OPENXML节点中使用一个带有nodes()函数的XML字段类型把一个XML文件转化为一个行集。让我们来看一个使用OPENXML的简单例子,并显示如何把它转化为在SQL Server 2005中使用XML字段类型和nodes()函数。
  为了使我们的例子简单化,我们将假设我们需要执行某种基于采购订单列表的过程,而这个采购订单将在一个XML文件中指定。该XML文件类似于这样:
   < polist>
  < po>< ponumber>100< /ponumber>< podate>2008-09-10< /podate>< /po>
  < po>< ponumber>101< /ponumber>< podate>2008-09-11< /podate>< /po>
  < /polist>
  我们可以通过下面的OPENXML把 XML转化为一个行集:
   DECLARE @DocHandle int
  DECLARE @XmlDocument nvarchar(1000)
  SET @XmlDocument = N''< polist>
  < po>< ponumber>100< /ponumber>< podate>2008-09-10< /podate>< /po>
  < po>< ponumber>101< /ponumber>< podate>2008-09-11< /podate>< /po>
  < /polist>''
  EXEC sp_xml_preparedocument @DocHandle OUTPUT, @XmlDocument
  SELECT * from OPENXML (@DocHandle, ''/polist/po'',2)
  WITH (ponumber nvarchar(10),
  podate datetime)
  EXEC sp_xml_removedocument @DocHandle
  下面是执行以上代码段得到的行集:
  
  图一
  这是从上面代码段得到的要点:
  使用OPENXML的第一步是通过访问该存储过程sp_xml_preparedocument来"准备"XML文件,该存储过程将返回一个确认准备好的XML的整数。
  OPENXML是一个行集提供者,这意味着如果它是一张表,那么你同样可以使用它。本质上它是一个带有参数的函数,这些参数将确定该从XML文件中提取什么。
  使用OPENXML的最后步骤是通过访问存储过程sp_xml_removedocument来"释放"准备好的XML文件。
上面的xml存储过程使用共同的MSXML解析组件。
  sp_xml_preparedocument存储过程把准备好的XML文件存储在SQL Server的内部高速缓存中。访问sp_xml_removedocument存储过程是很有必要的,这是为了把准备好的XML文件从高速缓存中消除。根据SQL Server 2005联机帮助,能够用于SQL Server的八分之一总内存可以用于MSX


相关文档:

SQL 行数的选择

Oracle数据库
SELECT
    *
from
(
    SELECT
        ROWNUM AS NO_ROW
        ,row_.*
    from
    (
        SELECT
 &nb ......

SQL行列的转换

/*
标题:普通行列转换(version 2.0)
作者:爱新觉罗.毓华
时间:2008-03-09
地点:广东深圳
说明:普通行列转换(version 1.0)仅针对sql server 2000提供静态和动态写法,version 2.0增加sql server 2005的有关写法。
问题:假设有张学生成绩表(tb)如下:
姓名 课程 分数
张三 语文 74
张三 数学 83
张三 物理 93 ......

SQL关于两表关联的update

关于两表关联的update,但语句怎么写都不正确,老是报错,于是心惊肉跳(就怕不能及时完成操作)去查了一下,NND,原来把SQL写成了在SQL Server下面的特有形式,这种语法在Oracle下面是行不通的,急忙改回来,及时完成了任务。顺便也把查到的SQL帖出来,哪天再忘记了,也好在这里找回来:
   update customers a ......

Load/Unload XML data in DB2

If XML data in the table is less than 32K for each record, then you can directly unload the data as char. If XML data exceeds 32K for some records, then you have to unload the common data and the XML data separately. First, create a template for unloading XML into a PDS: TEMPLATE LOBFRV DSN 'AAA. ......

SQL时间函数


Sql时间函数
一、sql server日期时间函数
Sql Server中的日期与时间函数 
1.  当前系统日期、时间 
    select getdate()  
2. dateadd  在向指定日期加上一段时间的基础上,返回新的 datetime 值
    ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号