Building Database Applications With SQL Server Yukon - PowerPoint PPT Presentation

1 / 26
About This Presentation
Title:

Building Database Applications With SQL Server Yukon

Description:

Loosely structured and semi-structured data stored in native XML form ... Fully backward compatible with SS2K. FOR XML. New directive TYPE returns XML data type ... – PowerPoint PPT presentation

Number of Views:66
Avg rating:3.0/5.0
Slides: 27
Provided by: arpandesai8
Category:

less

Transcript and Presenter's Notes

Title: Building Database Applications With SQL Server Yukon


1
Building Database Applications With SQL Server
Yukon
Session Code DAT402
  • Istvan Cseri, Architect
  • Arpan Desai, Program Manager
  • Microsoft Corporation
  • istvanc_at_microsoft.com
  • arpande_at_microsoft.com

2
Tools
Client Application Model
Web Service Application Model
Data Systems Application Model
Mobile PC Devices Application Model
Command Line
Compact Framework
System.Console
Win FS
Yukon
Mobile PC Optimized
Avalon
Windows Forms
ASP.NET / Indigo
NT Service
System.Data.SqlServer
System.Windows
System.Windows.Forms
System.Windows
System.Windows.Forms
System.Web
System.Storage
System.ServiceProcess
Data
Communication
Presentation
System.Discovery
System.Search
System.Collaboration
System.Data
System.Messaging
System.Windows
SqlClient
DataSet
RealTimeEndpoint
UI Element
Explorer
Media
Annotations
System.DirectoryServices
ActiveDirectory
TransientDataSession
Mapping
SqlTypes
Animation
Controls
Documents
System.Remoting
Monitoring
SignalingSession
ObjectSpaces
SqlXML
Controls
Dialogs
Text Element
System.Runtime.Remoting
Logging
Uddi
Media
ObjectSpace
Control
SideBar
Shapes
OdbcClient
Relevance
Activities
Query
Panel
Notification
Shape
OleDbClient
Navigation
Schema
System.Web.Services
Design
Ink
OracleClient
System.MessageBus
Transport
Queue
Web.Service
System.Storage
Port
PubSub
System.Windows.Forms
System.Web.UI
Description
Item
Core
Channel
Router
Forms
Page
WebControls
Discovery
Relationship
Contact
Service
Policy
Control
Control
Adaptors
Protocols
Media
Location
Peer Group
Print Dialog
HtmlControls
Design
Audio
Message
Design
MobileControls
Video
Document
System.Net
System.Web
Images
Event
HttpWebRequest
NetworkInformation
System.Help
System.Speech
Personalization
System.Xml
FtpWebListener
Sockets
System.Drawing
Recognition
Synthesis
Caching
Schema
Xpath
SslClientStream
Cache
SessionState
System.NaturalLanguageServices
Query
Serialization
WebClient
Fundamentals
Security
Base Application Services
Configuration
Deployment/Management
System.Timers
System.Text
System.Windows.TrustManagement
System.Web.Configuration
System.Collections
System.Web
System.Security
System.Globalization
System.Design
System.MessageBus.Configuration
Generic
Administration
Authorization
Permissions
System.Web.Security
System.Serialization
System.IO
System.Configuration
Management
System.ComponentModel
AccessControl
Policy
System.Threading
Ports
System.Resources
System.CodeDom
System.Management
Principal
System.MessageBus.Security
Credentials
System.Runtime
System.Reflection
Token
Cryptography
System.Deployment
System.EnterpriseServices
InteropServices
Serialization
System.Diagnostics
System.Transactions
CompilerServices
3
Agenda
  • SS2K Recap
  • Scenarios
  • Yukon XML support
  • Native XML storage
  • XML schema support
  • XML query with insert, update, and delete
  • ADO.NET and Yukon
  • SQL Client support
  • XML Views
  • Summary

4
SQL Server 2000Technologies
  • Server support
  • FOR XML generate XML from tables
  • OpenXML generate relational rowset from XML
  • Mid-tier support (SQLXML)
  • XML views (annotated mapping schemas XSD)
  • Templates
  • UpdateGrams/BulkLoad
  • Access methods
  • HTTP SOAP (via mid-tier ISAPI)
  • ADO, OLE DB ADO.NET

5
XML ScenariosDocument management
Index, search XML data
Doc, E-Mail,
XSLT
6
XML ScenariosData Exchange
XML data
Point-of-Sales
Supplier
  • Platform independent transport format
  • Loosely-coupled system
  • B2B, B2C, A2A

7
XML ScenariosMid-Tier Collaborative Applications
8
Yukon XML SupportRelational and XML integration
  • Structured and semi-structured data
  • Structured data stored relationally
  • Bi-directional mapping between XML and relational
    data
  • Loosely structured and semi-structured data
    stored in native XML form
  • Index support with optimizer knowledge
  • Deep SQL Server integration for XML
  • Triggers, replication, bulk load, security

9
XML Support (Engine) Highlights
  • XML data type and XML index support
  • Unified XML and relational store
  • Both SQL and XQuery supported by same industrial
    strength infrastructure
  • Leverages existing SQL engine and optimizer
  • XQuery with data modification
  • XML schema enforcement
  • Client access using ADO.NET

10
FOR XML and OpenXML
  • Fully backward compatible with SS2K
  • FOR XML
  • New directive TYPE returns XML data type
  • Nested FOR XML
  • Assignment to XML data type
  • Support for new data types
  • OpenXML
  • XML overflow column
  • New types nvarchar(max), varbinary(max), UDT

11
Native XML StoreXML Data Type
  • Native SQL type
  • Use for column, variable or parameter
  • CREATE TABLE docs (id INT PRIMARY KEY,
    xDoc XML NOT NULL)
  • Store un-typed or typed XML instances
  • Well-formed and validation checks
  • Methods on XML data type
  • Query(), value(), exist(), XmlNodeRefs(),
    modify()
  • XML instances stored as LOB (2GB)
  • Efficient binary representation

12
Full-Text Indexing
  • XML filter
  • Index and query XML instances
  • Markup tags removed
  • Syntax same as for other columns
  • CREATE FULLTEXT INDEX ON docs (xDoc)
  • Use full-text search as filter, then XQuery
    search
  • Uses full-text index first
  • Uses XML index on tags, values, paths

13
Full-Text SearchQuery examples
  • SELECT R.Xquery ('//sec_at_num12')
  • FROM
  • (SELECT FROM docs
  • WHERE contains (xDoc, 'Wrd1 Wrd2')) R(X)
  • Supports xmllang attribute
  • Uses appropriate language word breaker
  • SELECT FROM docs
  • WHERE contains (xDoc, 'Visionen',
  • LANGUAGE 'German')

14
XQuery and XML Datatype
15
Native XML StoreXML Index
  • Create XML index on XML column
  • CREATE XML INDEX idx_1 ON docs (xDoc)
  • Creates indexes on tags, values, paths
  • Speeds up queries
  • Results can be served directly from index
  • Entire query is optimized
  • Same award winning cost based optimizer
  • Indexes are used as available

16
XML Query
  • XQuery query XML documents and data
  • Standards-based W3C working draft
  • In document 123, return section heading of
    section 3 and later
  • SELECT id, xDocquery('
  • for s in
  • /doc_at_id 123//sec_at_num gt 3
  • return lttopicgtdata(s/heading)lt/topicgt
  • ') FROM docs

17
XQuery Features
  • FLWR FOR / LET / WHERE / RETURN
  • Includes XPath 2.0 (/doc_at_id 123)
  • Element constructors (lttopicgt)
  • Order-preserving operators
  • Supports strong typing

18
XML Data Modification
  • Insert, update, and delete XQuery extensions
  • XML sub-tree modification
  • Add or delete XML sub-trees
  • Update values
  • Add a new section after section 1
  • UPDATE docs SET xDocmodify('insertltsection
    num''2''gt ltheadinggtBackground
    lt/headinggt lt/sectiongtafter
    /doc/section_at_num1')

19
XML Schema Support
  • XML Schema (W3C standard)
  • Rich mechanism for type definitions and
    validation constraints
  • Can be used to constrain XML documents
  • Benefits of typed data
  • Guarantees shape of data
  • Allows storage and query optimizations
  • XML type system
  • Store XML schemas in system meta-data

20
XML Type System
  • Associate XML namespace with XML type
  • Query and modify typed XML data
  • DECLARE _at_x XML('http//www.ms.com/xdb')
  • SET _at_x 'ltpdoc p"http//www.ms.com/xdb"gt '
  • SELECT _at_xquery( 'namespace p
    "http//www.ms.com/xdb" for s in /pdoc_at_pid
    123//psec return lttopicgtdata(s/headi
    ng)lt/topicgt') FROM docs

21
Strongly Typed XML Datatype
22
Support for Yukon Inside ADO.NET
  • Support within System.Data
  • SqlDataReader
  • SqlXmlReader GetSqlXmlReader(int i)
  • DataSet
  • New XPathDocument column type
  • Full databinding support
  • Support within System.Xml
  • XML Views and XQuery

23
XML Views3-Part Mapping
  • Schema-mapping separation
  • XML schema relational schema mapping
  • Optimizations resulting from having relational
    schema
  • Relational domain extensibility
  • Support for SPs and UDFs
  • Inline SQL
  • Tool Support

24
XML ViewsFeatures
  • XQuery support over the views
  • Optimized query translation into T-SQL queries
  • Leveraging MARS
  • Databinding over results
  • BulkLoad - Bulk insert of XML data shredded into
    tables with ID propagation
  • XmlAdapter - Instance based updates (XML
    equivalent of SqlDataAdapter)

25
Using XML Views
26
(No Transcript)
Write a Comment
User Comments (0)
About PowerShow.com