#region Apache Notice /***************************************************************************** * $Revision: 374175 $ * $LastChangedDate$ * $LastChangedBy$ * * iBATIS.NET Data Mapper * Copyright (C) 2008/2005 - The Apache Software Foundation * * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ********************************************************************************/ #endregion using System; using System.Collections; using System.Data; using Apache.Ibatis.DataMapper.Data; using Apache.Ibatis.DataMapper.Model.ResultMapping; using Apache.Ibatis.DataMapper.Scope; namespace Apache.Ibatis.DataMapper.MappedStatements.ArgumentStrategy { /// /// implementation when a 'select' attribute exists /// on an and the object property is /// different from an or an . /// public sealed class SelectObjectStrategy : IArgumentStrategy { #region IArgumentStrategy Members /// /// Gets the value of an argument constructor. /// /// The current . /// The with the argument infos. /// The current . /// The keys /// The paremeter value. public object GetValue(RequestScope request, ResultProperty mapping, ref IDataReader reader, object keys) { // Get the select statement IMappedStatement selectStatement = request.MappedStatement.ModelStore.GetMappedStatement(mapping.Select); reader = DataReaderTransformer.Transform(reader, request.Session.SessionFactory.DataSource.DbProvider); return selectStatement.ExecuteQueryForObject(request.Session, keys, null); } #endregion } }