মানদণ্ড স্থানিক রেস্ট্রিকেশনস.ইসবিথিন দূরত্ব NHibernate.Spatial


95

কেউ কি এটি বাস্তবায়ন করেছেন, বা জানেন যে এটি বাস্তবায়ন করা কঠিন / কোন পয়েন্টার রয়েছে কিনা?

public static SpatialRelationCriterion IsWithinDistance(string propertyName, object anotherGeometry, double distance)
{
    // TODO: Implement
    throw new NotImplementedException();
}

NHibernate.Spatial.Criterion.SpatialRestrictions থেকে

আমি "যেখানে NHSP.Distance (PROPERTY,: point)" hql তে ব্যবহার করতে পারি। তবে এই ক্যোয়ারীটি আমার বিদ্যমান মানদণ্ডের প্রশ্নের সাথে একত্রিত করতে চাই।

এই মুহুর্তে আমি মোটামুটি বহুভুজ তৈরি করছি এবং ব্যবহার করছি

criteria.Add(SpatialRestrictions.Intersects("PROPERTY", myPolygon));

সম্পাদনা পেয়েছেন প্রোটোটাইপ SpatialRelationCriterion উপর কন্সট্রাকটর ওভারলোডিং দ্বারা কাজ, নতুন SpatialRelation.Distance যোগ

public static SpatialRelationCriterion IsWithinDistance(string propertyName, object anotherGeometry, double distance)
        {
            return new SpatialRelationCriterion(propertyName, SpatialRelation.Distance, anotherGeometry, distance);
        }

স্প্যাটিয়ালিলিয়েশনক্রিটায়নে একটি নতুন ক্ষেত্র যুক্ত হয়েছে

private readonly double? distance;

public SpatialRelationCriterion(string propertyName, SpatialRelation relation, object anotherGeometry, double distance)
            : this(propertyName, relation, anotherGeometry)
        {
            this.distance = distance;
        }

ToSQL স্ট্রিং সম্পাদিত

object secondGeometry = Parameter.Placeholder;
                if (!(this.anotherGeometry is IGeometry))
                {
                    secondGeometry = columns2[i];
                }

                if (distance.HasValue)
                {
                    builder.Add(spatialDialect.GetSpatialRelationString(columns1[i], this.relation, secondGeometry, distance.Value, true));
                }
                else
                {
                    builder.Add(spatialDialect.GetSpatialRelationString(columns1[i], this.relation, secondGeometry, true));
                }

অতিরিক্ত লোড ISpatialDialect.GetSpatialRelationString

এমএসএসএকএলসিএলএস 800 স্পেশিয়ালডায়ালেক্টে ওভারলোড প্রয়োগ করা হয়েছে

public SqlString GetSpatialRelationString(object geometry, SpatialRelation relation, object anotherGeometry, double distance, bool criterion)
        {
            var x = new SqlStringBuilder(8)
                           .AddObject(geometry)
                           .Add(".ST")
                           .Add(relation.ToString())
                           .Add("(")
                           .AddObject(anotherGeometry)
                           .Add(")");

            if (criterion)
            {
                x.Add(" < ");
                x.AddObject(distance.ToString());
            }

            return x.ToSqlString();
        }

অ্যাডপ্যারামিটার কেন ব্যবহার হচ্ছে না তা নিশ্চিত নন?


4
আমারও একই সমস্যা, এবং এখনও পর্যন্ত কোনও সম্পূর্ণ প্যাচ / ফিক্স / যা কিছু খুঁজে পেলাম না। আপনি কি এটি সমাধান করেছেন, না আপনি এইচকিউএল বৈকল্পিকের সাথে চলেছেন?
লিডম্যান

4
ভাবুন উপরোক্ত পদ্ধতির সাথে চলেছে, এবং কাজ করার জন্য dll পুনরুদ্ধার করেছিল তবে এখনও পরীক্ষামূলক কোড ছিল।
ইয়ান

4
@ আমরেশ আপনি ওপি প্রদত্ত প্রস্তাবিত সমাধান নিয়ে সন্তুষ্ট নন?
ইরানগা

এটি কাজ করার জন্য ডিএলএল পুনরায় সংকলন করুন।
কাউবয় 911

মাইক্রোসফ্টের রিচ ল্যান্ডারের মতে , আপনি এই সমস্যাটি এনএইচবারনেট ফোরামগুলিতে উত্থাপন করা আপনার পক্ষে আরও ভাল সুযোগ হতে পারে ।
অ্যানি

উত্তর:


1

আমরা এই সমস্যাটি গিটহাবের দিকে তাকাচ্ছি। দুর্দান্ত অন্তর্দৃষ্টি এবং একটি সম্ভাব্য সমাধান সরবরাহ করার জন্য ধন্যবাদ। এখানে ইস্যুটির একটি লিঙ্ক রয়েছে: https://github.com/nhibernate/NHibernate.Spatial/issues/61

এটি ঠিক হওয়ার সাথে সাথে আমি নতুন নিউগেট প্যাকেজ প্রকাশ করব।


এই এসও প্রশ্নটিও একটি একই সমাধান সম্পর্কে একটি ভিন্ন সমাধান স্ট্যাকওভারফ্লো
সূর্য প্রতাপ

0

হ্যাঁ আমি মনে করি যে ডিএলএল রিকম্পাইল করা আপাতত সেরা সমাধান।

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.