ブール値コンストラクター関数 - true (XQuery)
適用対象: SQL Server
xs:boolean 値 True を返します。 これは、xs:boolean("1")
と同じです。
構文
fn:true() as xs:boolean
例
このトピックでは、AdventureWorks データベースのさまざまな xml 型の列に格納されている XML インスタンスに対する XQuery の例を示します。
A. XQuery 論理関数 true() の使用
次の例では、型指定されていない xml 変数を照会します。 value() メソッド内の式は、"aaa" が属性値の場合はブール値 true()を返します。 xml データ型の value() メソッドは、ブール値をビットに変換して返します。
DECLARE @x XML
SET @x= '<ROOT><elem attr="aaa">bbb</elem></ROOT>'
select @x.value(' if ( (/ROOT/elem/@attr)[1] eq "aaa" ) then fn:true() else fn:false() ', 'bit')
go
-- result = 1
次の例では、型指定された xml 列に対してクエリを指定します。 if
式は、<ROOT
>要素の型指定されたブール値をチェックし、それに応じて構築された XML を返します。 この例では、次の処理を実行します。
xs:boolean 型の <
ROOT
> 要素を定義する XML スキーマ コレクションを作成します。XML スキーマ コレクションを使用して、型指定された xml 列を持つテーブルを作成します。
XML インスタンスを列に保存し、クエリを実行します。
-- Drop table if exist
--DROP TABLE T
--go
DROP XML SCHEMA COLLECTION SC
go
CREATE XML SCHEMA COLLECTION SC AS '
<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="QNameXSD" >
<element name="ROOT" type="boolean" nillable="true"/>
</schema>'
go
CREATE TABLE T (xmlCol XML(SC))
go
-- following OK
insert into T values ('<ROOT xmlns="QNameXSD">true</ROOT>')
go
-- Retrieve the local name.
SELECT xmlCol.query('declare namespace a="QNameXSD";
if (/a:ROOT[1] eq true()) then
<result>Found boolean true</result>
else
<result>Found boolean false</result>')
FROM T
-- result = <result>Found boolean true</result>
-- Clean up
DROP TABLE T
go
DROP XML SCHEMA COLLECTION SC
go