<?xml version="1.0" encoding="UTF-8" ?>

<sqlMap namespace="Order">

	<alias>
		<typeAlias alias="Order" type="IBatisNet.DataMapper.Test.Domain.Order, IBatisNet.DataMapper.Test" />
	</alias>

		<!-- If the type is not specified, ADO.NET infers the 
			  data provider Type of the Parameter from the Value property 
			  of the Parameter object. -->

	
	<resultMap id="credit-card-result" class="string">
		<result property="value" column="Order_CardNumber"/>
	</resultMap>
	<!--  -->
	<resultMap id="order-with-lines-result" class="Order" 
							extends="lite-order-result-by-name" >
		<result property="LineItemsList" lazyLoad="true" type="TList" column="Order_Id" select="GetLineItemsForOrder" />
	</resultMap>

	<resultMap id="order-with-lines-result-no-lazy-load" class="Order" 
							extends="lite-order-result-by-name" >
		<result property="LineItemsList" type="TList" column="Order_Id" select="GetLineItemsForOrder" />
	</resultMap>

	<resultMap id="order-with-lines-result-statement-namespaces" class="Order" 
							extends="lite-order-result-by-name" >
		<result property="LineItemsList" lazyLoad="true" type="TList" column="Order_Id" select="LineItem.GetLineItemsForOrder" />
	</resultMap>
			
	<resultMap id="order-with-lines-collection" class="Order"
							extends="lite-order-result-by-name" >
		<result property="LineItems" column="Order_Id" lazyLoad="true" 
			select="GetLineItemsForOrderWithListClass" />
	</resultMap>

	<resultMap id="order-with-lines-collection-no-lazy-load" class="Order"
							extends="lite-order-result-by-name" >
		<result property="LineItems" column="Order_Id" 
			select="GetLineItemsForOrderWithListClass" />
	</resultMap>

	<resultMap id="order-with-lines-array" class="Order"
							extends="lite-order-result-by-name">
		<result property="LineItemsArray" column="Order_Id" select="GetLineItemsForOrder"/>
	</resultMap>

	<resultMap id="lite-order-map-result" class="array">
		<result property="Id"         type="Int" column="Order_Id"/>
		<result property="Date"       type="date" column="Order_Date"/>
		<result property="CardExpiry" type="string" column="Order_CardExpiry"/>
		<result property="CardType"   type="string" column="Order_CardType"/>
		<result property="CardNumber" type="string" column="Order_CardNumber"/>
		<result property="Street"     type="string" column="Order_Street"/>
		<result property="City"       type="string" column="Order_City"/>
		<result property="Province"   type="string" column="Order_Province"/>
		<result property="PostalCode" type="string" column="Order_PostalCode"/>
	</resultMap>

	<resultMap id="lite-order-result-by-name" class="Order">
		<result property="Id"         column="Order_Id"/>
		<result property="Date"       type="date" column="Order_Date" nullValue="0001-01-01 00:00:00"/>
		<result property="CardExpiry" column="Order_CardExpiry"/>
		<result property="CardType"   column="Order_CardType"/>
		<result property="CardNumber" column="Order_CardNumber"/>
		<result property="Street"     column="Order_Street"/>
		<result property="City"       column="Order_City"/>
		<result property="Province"   column="Order_Province"/>
		<result property="PostalCode" column="Order_PostalCode"/>
	</resultMap>
	
	<resultMap id="order-hash" class="array">
		<result property="Date"       column="Order_Date" nullValue="0001-01-01 00:00:00"/>
	</resultMap>		
	
	<resultMap id="order-with-types-result" class="Order">
		<result property="Id"         column="Order_Id"			dbType="Int32"/>
		<result property="Date"       column="Order_Date"		type="date" dbType="DateTime "/>
		<result property="CardExpiry" column="Order_CardExpiry" dbType="VarChar"/>
		<result property="CardType"   column="Order_CardType"	dbType="VarChar"/>
		<result property="CardNumber" column="Order_CardNumber" dbType="VarChar"/>
		<result property="Street"     column="Order_Street"		dbType="VarChar"/>
		<result property="City"       column="Order_City"		dbType="VarChar"/>
		<result property="Province"   column="Order_Province"	dbType="VarChar"/>
		<result property="PostalCode" column="Order_PostalCode" dbType="VarChar"/>
	</resultMap>
	
	<resultMap id="lite-order-result-by-index" class="Order">
		<result property="Id"         column="Order_Id"			columnIndex="0"/>
		<result property="Date"       column="Order_Date"		type="date" columnIndex="1" />
		<result property="CardExpiry" column="Order_CardExpiry" columnIndex="2"/>
		<result property="CardType"   column="Order_CardType"	columnIndex="3" />
		<result property="CardNumber" column="Order_CardNumber" columnIndex="4" />
		<result property="Street"     column="Order_Street"		columnIndex="5" />
		<result property="City"       column="Order_City"		columnIndex="6" />
		<result property="Province"   column="Order_Province"	columnIndex="7"/>
		<result property="PostalCode" column="Order_PostalCode" columnIndex="8" />
	</resultMap>
	
	<resultMap id="order-with-account-result" class="Order">
		<result property="Id"         column="Order_Id"/>
		<result property="Date"       type="date" column="Order_Date"/>
		<result property="CardExpiry" column="Order_CardExpiry"/>
		<result property="CardType"   column="Order_CardType"/>
		<result property="CardNumber" column="Order_CardNumber"/>
		<result property="Street"     column="Order_Street"/>
		<result property="City"       column="Order_City"/>
		<result property="Province"   column="Order_Province"/>
		<result property="PostalCode" column="Order_PostalCode"/>
		<result property="Account"    column="Account_Id" select="GetAccountViaColumnName" />
	</resultMap>
	
	<resultMap id="order-with-collection-result" class="Order">
		<result property="Id"				column="Order_Id"/>
		<result property="Date"				type="date" column="Order_Date"/>
		<result property="CardExpiry"		column="Order_CardExpiry"/>
		<result property="CardType"			column="Order_CardType"/>
		<result property="CardNumber"		column="Order_CardNumber"/>
		<result property="Street"			column="Order_Street"/>
		<result property="City"				column="Order_City"/>
		<result property="Province"			column="Order_Province"/>
		<result property="PostalCode"		column="Order_PostalCode"/>
		<result property="LineItemsList"	column="Order_Id" select="GetLineItemsForOrder" />	
		<result property="LineItems"		column="Order_Id" select="GetLineItemsForOrder" lazyLoad="false" />
	</resultMap>
	
	<resultMap id="order-with-favourite-line-item" class="Order">
		<result property="Id"					column="Order_Id"/>
		<result property="Date"					column="Order_Date"/>
		<result property="CardExpiry"			column="Order_CardExpiry"/>
		<result property="CardType"				column="Order_CardType"/>
		<result property="CardNumber"			column="Order_CardNumber"/>
		<result property="Street"				column="Order_Street"/>
		<result property="City"					column="Order_City"/>
		<result property="Province"				column="Order_Province"/>
		<result property="PostalCode"			column="Order_PostalCode"/>
		<result property="FavouriteLineItem"	
				column="Order_ID=Order_Id,LineItem_ID=Order_FavouriteLineItem" 
				select="GetSpecificLineItem" />
	</resultMap>
	
	<resultMap id="order-with-dyn-favourite-line-item" class="Order">
		<result property="Id"					column="Order_Id"/>
		<result property="Date"					column="Order_Date"/>
		<result property="CardExpiry"			column="Order_CardExpiry"/>
		<result property="CardType"				column="Order_CardType"/>
		<result property="CardNumber"			column="Order_CardNumber"/>
		<result property="Street"				column="Order_Street"/>
		<result property="City"					column="Order_City"/>
		<result property="Province"				column="Order_Province"/>
		<result property="PostalCode"			column="Order_PostalCode"/>
		<result property="FavouriteLineItem"	
					column="Order_ID=Order_Id,LineItem_ID=Order_FavouriteLineItem" 
					select="GetDynSpecificLineItem" />
	</resultMap>
	
	<resultMap id="order-joined-favourite" class="Order">
		<result property="Id"					column="Order_Id"/>
		<result property="Date"					type="date" column="Order_Date"/>
		<result property="CardExpiry"			column="Order_CardExpiry"/>
		<result property="CardType"				column="Order_CardType"/>
		<result property="CardNumber"			column="Order_CardNumber"/>
		<result property="Street"				column="Order_Street"/>
		<result property="City"					column="Order_City"/>
		<result property="Province"				column="Order_Province"/>
		<result property="PostalCode"			column="Order_PostalCode"/>
		<result property="FavouriteLineItem"	resultMapping="LineItem" />
	</resultMap>
	
	<resultMap id="order-joined-favourite2" class="Order">
		<result property="Id"					column="Order_Id"/>
		<result property="Date"					type="date" column="Order_Date"/>
		<result property="CardExpiry"			column="Order_CardExpiry"/>
		<result property="CardType"				column="Order_CardType"/>
		<result property="CardNumber"			column="Order_CardNumber"/>
		<result property="Street"				column="Order_Street"/>
		<result property="City"					column="Order_City"/>
		<result property="Province"				column="Order_Province"/>
		<result property="PostalCode"			column="Order_PostalCode"/>
		<result property="FavouriteLineItem.Id" column="LineItem_Id"/>
		<result property="FavouriteLineItem.Code" column="LineItem_Code"/>
		<result property="FavouriteLineItem.Quantity" column="LineItem_Quantity"/>
		<result property="FavouriteLineItem.Price" column="LineItem_Price"/>			
	</resultMap>
			
	<resultMap id="order-joined-with-account" class="Order">
		<result property="Id"         column="Order_Id"/>
		<result property="Date"       type="date" column="Order_Date" nullValue="01/01/0001 00:00:00"/>
		<result property="CardExpiry" column="Order_CardExpiry"/>
		<result property="CardType"   column="Order_CardType"/>
		<result property="CardNumber" column="Order_CardNumber"/>
		<result property="Street"     column="Order_Street"/>
		<result property="City"       column="Order_City"/>
		<result property="Province"   column="Order_Province"/>
		<result property="PostalCode" column="Order_PostalCode"/>
		<result property="Account"	resultMapping="account-result-nullable-email" />
	</resultMap>		
	
	<statement id="GetOrderLiteByColumnName"
				parameterClass="integer"
				resultMap="lite-order-result-by-name" >
		select * from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderByHashTable"
				parameterClass="Int"
				resultMap="order-hash" >
		select Order_Date from Orders where Order_Id = #value#
	</statement>		
	
	<statement id="GetOrderLiteByColumnIndex"
				parameterClass="Int"
				resultMap="lite-order-result-by-index" >
		select
		Order_Id,
		Order_Date,
		Order_CardExpiry,
		Order_CardType,
		Order_CardNumber,
		Order_Street,
		Order_City,
		Order_Province,
		Order_PostalCode
		from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderWithTypes"
				parameterClass="Int"
				resultMap="order-with-types-result" >
		select * from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderWithLineItems"
				parameterClass="Integer"
				ListClass="TList"
				resultMap="order-with-lines-result" >
		select * from Orders where Order_Id = #value#
	</statement>


	<statement id="GetOrderWithLineItemsNoLazyLoad"
				parameterClass="Integer"
				resultMap="order-with-lines-result-no-lazy-load" >
		select * from Orders where Order_Id = #value#
	</statement>

	<statement id="GetOrderWithLineItemsUsingStatementNamespaces"
				parameterClass="Integer"
				resultMap="order-with-lines-result-statement-namespaces" >
		select * from Orders where Order_Id = #value#
	</statement>

	<statement id="GetAllOrderWithLineItems"
				resultMap="order-with-lines-result" >
		select * from Orders
	</statement>

	<statement id="GetOrderCardExpiryViaResultClass"
				parameterClass="int"
				resultClass="date">
		select
		Order_Date as 'datetime'
		from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderWithAccount"
				parameterClass="int"
				resultMap="order-with-account-result" >
		select * from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderWithLineItemsCollection"
				parameterClass="Integer"
				resultMap="order-with-collection-result" >
		select * from Orders where Order_Id = #value#
	</statement>
	
	 <statement id="GetOrderJoinedFavourite"
				parameterClass="Integer"
				resultMap="order-joined-favourite" >
		select 
		Orders.Order_Id as Order_Id,
		Orders.Account_Id as Account_Id,
		Orders.Order_Date as Order_Date,
		Orders.Order_CardType as Order_CardType,
		Orders.Order_CardNumber as Order_CardNumber,
		Orders.Order_CardExpiry as Order_CardExpiry,
		Orders.Order_Street as Order_Street,
		Orders.Order_City as Order_City,
		Orders.Order_Province as Order_Province,
		Orders.Order_PostalCode as Order_PostalCode,
		Orders.Order_FavouriteLineItem as Order_FavouriteLineItem,
		LineItems.LineItem_Id as LineItem_Id,
		LineItems.Order_Id as Order_Id,
		LineItems.LineItem_Code as LineItem_Code,
		LineItems.LineItem_Quantity as LineItem_Quantity,
		LineItems.LineItem_Price as LineItem_Price,
		LineItems.LineItem_Picture as LineItem_Picture
		
		from Orders, LineItems
		where Orders.Order_Id = LineItems.Order_Id
		and Order_FavouriteLineItem = LineItems.LineItem_ID
		and Orders.Order_Id = #value#
	</statement>

	<statement id="GetOrderJoinedFavourite2"
				parameterClass="Integer"
				resultMap="order-joined-favourite2" >
		select 
		
		Orders.Order_Id as Order_Id,
		Orders.Account_Id as Account_Id,
		Orders.Order_Date as Order_Date,
		Orders.Order_CardType as Order_CardType,
		Orders.Order_CardNumber as Order_CardNumber,
		Orders.Order_CardExpiry as Order_CardExpiry,
		Orders.Order_Street as Order_Street,
		Orders.Order_City as Order_City,
		Orders.Order_Province as Order_Province,
		Orders.Order_PostalCode as Order_PostalCode,
		Orders.Order_FavouriteLineItem as Order_FavouriteLineItem,
		LineItems.LineItem_Id as LineItem_Id,
		LineItems.Order_Id as Order_Id,
		LineItems.LineItem_Code as LineItem_Code,
		LineItems.LineItem_Quantity as LineItem_Quantity,
		LineItems.LineItem_Price as LineItem_Price,
		LineItems.LineItem_Picture as LineItem_Picture
		
		from Orders, LineItems
		where Orders.Order_Id = LineItems.Order_Id
		and Order_FavouriteLineItem = LineItems.LineItem_ID
		and Orders.Order_Id = #value#
	</statement>

	<statement id="GetOrderJoinedFavourite3"
				parameterClass="Integer"
				resultClass="Order" >
		select 
			Orders.Order_Id as Id,
			Order_Date as Date,
			Order_CardExpiry as CardExpiry,
			Order_CardType as CardType,
			Order_CardNumber as CardNumber,
			Order_Street as Street,
			Order_City as City,
			Order_Province as Province,
			Order_PostalCode as PostalCode,
			LineItem_ID as "FavouriteLineItem.Id",
			LineItem_Code as "FavouriteLineItem.Code",
			LineItem_Quantity as "FavouriteLineItem.Quantity",
			LineItem_Price as "FavouriteLineItem.Price"
		from Orders, LineItems
		where Orders.Order_Id = LineItems.Order_Id
		and Order_FavouriteLineItem = LineItems.LineItem_ID
		and Orders.Order_Id = #value#
	</statement>
			
	<statement id="GetOrderWithFavouriteLineItem"
				parameterClass="int"
				resultMap="order-with-favourite-line-item" >
		select * from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderWithLineItemCollection"
				parameterClass="int"
				resultMap="order-with-lines-collection" >
		select * from Orders where Order_Id = #value#
	</statement>

		<statement id="GetOrderWithLineItemCollectionNoLazy"
				parameterClass="int"
				resultMap="order-with-lines-collection-no-lazy-load" >
		select * from Orders where Order_Id = #value#
	</statement>

	<statement id="GetOrderAsHastable"
				parameterClass="Integer"
				resultMap="lite-order-map-result" >
		select * from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetOrderWithLineItemArray"
			parameterClass="int"
			resultMap="order-with-lines-array">
			select * from Orders where Order_Id = #value#
	</statement>
	
	<statement id="GetAllCreditCardNumbersFromOrders"
			resultMap="credit-card-result" >
		select distinct Order_CardNumber from Orders
		order by Order_CardNumber
	</statement>
	
	<statement id="InsertOrderViaParameterMap"
				parameterMap="order-insert-params-full" >
		insert into Orders  
			(Order_Id, Account_ID, Order_Date, Order_CardExpiry, Order_CardType, 
				Order_CardNumber, Order_Street, Order_City, Order_Province, Order_PostalCode ) 
		values 
			(?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
	</statement>		
	
	<statement id="InsertOrderViaExtendParameterMap"
				parameterMap="insert-extend" >
		insert into Orders  
			(Order_Id, Account_ID, Order_Date, Order_CardExpiry, Order_CardType, 
				Order_CardNumber, Order_Street, Order_City, Order_Province, Order_PostalCode ) 
		values 
			(?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
	</statement>	

	<statement id="InsertOrderViaPublicFields">
		insert into Orders  
			(Order_Id, Account_ID, Order_Date, Order_CardExpiry, Order_CardType, 
				Order_CardNumber, Order_Street, Order_City, Order_Province, Order_PostalCode ) 
		values 
			(#Id#, #Account.Id#, #Date#, #CardExpiry#, #CardType#, #CardNumber#, #Street#, #City#, #Province#, #PostalCode#)
	</statement>		
			
	<select id="GetOrderWithDynFavouriteLineItem"
			parameterClass="Integer"
			resultMap="order-with-dyn-favourite-line-item">
		select * from Orders where Order_Id = #value#
	</select>		
	
	<select id="SelectOrderByDate"
			parameterClass="array"
			resultMap="lite-order-result-by-name">
		select * from Orders where Order_Date = #Foo#
	</select>	
	
	<select id="SelectOrderByDateDynamic"
			parameterClass="array"
			resultMap="lite-order-result-by-name">
		select * from Orders
		where 1=1
		<isNotEmpty prepend="AND" property="Foo"> 
			(Order_Date = '$Foo$') 
		</isNotEmpty> 
	</select>				
	
	<select id="GetAccountJIRA45"
			parameterClass="int"
			resultMap="indexed-account-result">
		select
		Account_Id,
		Account_FirstName,
		Account_LastName,
		Account_Email
		from Accounts
		where Account_ID = #value#
	</select>

	<select id="GetOrderJoinWithAccount"
			parameterClass="Integer"
			resultMap="order-joined-with-account">
		select 
			Order_Id, 
			Order_Date, 
			Order_CardExpiry, 
			Order_CardType,
			Order_CardNumber, 
			Order_Street, 
			Order_City, 
			Order_Province, 
			Order_PostalCode,
			acc.Account_ID as Account_ID,
			acc.Account_FirstName as Account_FirstName,
			acc.Account_LastName as Account_LastName,
			acc.Account_Email as Account_Email 
		from Orders as ord
		LEFT OUTER JOIN Accounts as acc on acc.Account_ID = ord.Account_ID
		where Order_Id = #value#
	</select>					
	
	<parameterMap id="order-insert-params-full">
		<parameter property="Id" dbType="Int32"/>
		<parameter property="Account.Id"/>
		<parameter property="Date" nullValue="0001-01-01 00:00:00" />
		<parameter property="CardExpiry" />
		<parameter property="CardType" />			
		<parameter property="CardNumber" />
		<parameter property="Street" />
		<parameter property="City" />			
		<parameter property="Province" />
		<parameter property="PostalCode" />
	</parameterMap>
	
	<parameterMap id="params-parent"> <!-- 1043181 support request -->
		<parameter property="Id" dbType="Int32"/>	
		<parameter property="Account.Id"/>
		<parameter property="Date" nullValue="0001-01-01 00:00:00" />
		<parameter property="CardExpiry" />
		<parameter property="CardType" />			
		<parameter property="CardNumber" />
		<parameter property="Street" />
		<parameter property="City" />			
		<parameter property="Province" />
		<parameter property="PostalCode" />		
	</parameterMap>
	
	<parameterMap id="insert-extend" extends="params-parent">
	</parameterMap>

</sqlMap>