1

Asp.Net MVC 4 アプリケーションで Simple.Data for Oracle バージョン 0.18.3.1 を使用しています。スキーマ名を前に付けないテーブルでは問題なく動作しますが、スキーマ名を前に付ける必要があるテーブルからデータを取得しようとするとクラッシュします。私が受け取るエラーは

"No matching table found, or insufficient permissions."

実行する必要があるクエリは次のとおりです。

SELECT * FROM SchemaName.TableName

このクエリを Oracle Sql Developer で実行しようとすると、問題なく動作します。結果が出ます。ただし、C# で Simple.Data を使用すると上記のエラーが発生します。私は次の方法を試しました:

//BASE CLASS
public class BaseRepository
{
    protected dynamic DB { get; set; }
    public BaseRepository()
    {
        DB = Database.OpenNamedConnection("intranet_db");
    }
}

//Derived Class
public class EmployeeRepository : BaseRepository
{
    public List<Employee> GetEmployees()
    {                
        List<Employee> employees = DB.SchemaName.TableName.FindAllBy(JoinedOn:"2009-05-31");

        // I also have tried the following combinations as specified in documentations
        // DB.SchemaName["TableName"].FindAllBy(JoinedOn:"2009-05-31");
        // DB["SchemaName"].TableName.FindAllBy(JoinedOn:"2009-05-31");
        // DB["SchemaName"]["TableName"].FindAllBy(JoinedOn:"2009-05-31");

        return employees;
    }
}

しかし、それは上記のエラーをスローし続けます。

私は何を間違っていますか?

前もって感謝します。

編集

以下は、メインの例外とその InnerException のスタック トレースです。

スタックトレース

at System.RuntimeMethodHandle.InvokeMethod(Object target, Object[] arguments, Signature sig, Boolean constructor)
at System.Reflection.RuntimeMethodInfo.UnsafeInvokeInternal(Object obj, Object[] parameters, Object[] arguments)
at System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture)
at System.Reflection.MethodBase.Invoke(Object obj, Object[] parameters)
at Simple.Data.SimpleQuery.TryConvertToGenericCollection(ConvertBinder binder, Object& result, Type collectionType)
at Simple.Data.SimpleQuery.TryConvert(ConvertBinder binder, Object& result)
at CallSite.Target(Closure , CallSite , Object )
at MyProject.Repository.Repositories.EmployeeRepository.GetStoppedEmployees() in d:\Projects.Net\MyProject\MyProject.Repository\Repositories\EmployeeRepository.cs:line 11
at MyProject.Web.Controllers.HomeController.Index() in d:\Projects.Net\MyProject\MyProject.Web\Controllers\HomeController.cs:line 17
at lambda_method(Closure , ControllerBase , Object[] )
at System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters)
at System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary2 parameters)
at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary2 parameters)
at System.Web.Mvc.Async.AsyncControllerActionInvoker.<>c__DisplayClass42.b__41()
at System.Web.Mvc.Async.AsyncResultWrapper.<>c__DisplayClass81.<BeginSynchronous>b__7(IAsyncResult _)
at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncResult1.End()
at System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeActionMethod(IAsyncResult asyncResult)
at System.Web.Mvc.Async.AsyncControllerActionInvoker.<>c__DisplayClass37.<>c__DisplayClass39.b__33()
at System.Web.Mvc.Async.AsyncControllerActionInvoker.<>c__DisplayClass4f.b__49()

内部例外スタック トレース

at Simple.Data.Ado.Schema.TableCollection.Find(String tableName, String schemaName)
at Simple.Data.Ado.Schema.TableCollection.Find(ObjectName tableName)
at Simple.Data.Ado.Schema.DatabaseSchema.FindTable(ObjectName tableName)
at Simple.Data.Ado.QueryBuilderBase.SetQueryContext(SimpleQuery query)
at Simple.Data.Oracle.OracleQueryBuilder.Build(SimpleQuery query, IEnumerable1& unhandledClauses)
at Simple.Data.Oracle.OracleCustomQueryBuilder.Build(AdoAdapter adapter, Int32 bulkIndex, SimpleQuery query, IEnumerable1& unhandledClauses)
at Simple.Data.Ado.QueryBuilder.Build(SimpleQuery query, IEnumerable1& unhandledClauses)
at Simple.Data.Ado.AdoAdapterQueryRunner.GetQueryCommandBuilders(SimpleQuery& query, IEnumerable1& unhandledClauses)
at Simple.Data.Ado.AdoAdapterQueryRunner.RunQuery(SimpleQuery query, IEnumerable1& unhandledClauses)
at Simple.Data.Ado.AdoAdapter.RunQuery(SimpleQuery query, IEnumerable1& unhandledClauses)
at Simple.Data.DatabaseRunner.RunQuery(SimpleQuery query, IEnumerable`1& unhandledClauses)
at Simple.Data.SimpleQuery.Run()
at Simple.Data.SimpleQuery.CastT
4

0 に答える 0