-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Custom type handlers for enums are ignored #259
Comments
I've just hit exactly the same problem. It seems like SqlMapper handles enums differently than every other type and tries to map them with Enum.Parse even if a custom type handler is specified. I'm just about to delve into the source and see if I can see an easy fix - I'll report back if I find anything useful. |
Urgh. I knew Dapper was optimised for performance but I didn't realise it literally emitted IL op codes to do value conversions. No chance I'm ever going to get to make enough sense of the source to offer up my own solution to this one so I'm hoping the devs will accept this as an enhancement. |
I don't thing you need to touch the IL sections. It's mostly a case of changing the order of the type checks to look for a custom handler first. At the moment it checks if it's an enum before it checks for custom type handlers and thus never discovers the custom type handler. My only concern is that I'm not sure what impact that will have on the rest of the system since similar type checks are in other places. Backwards compatibility shouldn't be a concern since it has never worked in the past I doubt anyone will have custom handlers for primitive types such as enums. |
Enums have quite a few nuances and special cases. I'm sympathetic to what On 10 April 2015 at 20:11, Chris Chilvers notifications@github.com wrote:
Regards, Marc |
I would like to be able the same for the generic System.Enum type to change the serialization behaviour of all Enums (I'm using attributes to specify the letter used to serialize an Enum) First check for a
then for a
(the default Dapper behaviour could be specified that way too) |
@mgravell I worked on this a bit yesterday, and came up with this: It works for everything I've tested, but I haven't written any unit tests for it. I was testing it with this Type Handler:
This doesn't support @vdaron's use case, however. |
@vdaron, thanks for the reference. Didn't make an effort to check that this issue was already logged, my bad. My use case is exactly the same as what @chilversc tried to achieve - single letter code in DB to represent an enum value. But it does not support @vdaron's "fall back" behavior request though. @mgravell, my commit in issue #286 included relevant test code and "all green" tests. |
+1 |
I've run into this as well. :( |
What is the status of this issue? |
We submitted a pull request to fix this two years ago, but it was never accepted. Still it's not fixed, and no feedback why the pull request was rejected :-( |
:+1 |
+1 |
Ultimately, my reservation here is that it was not intended or designed I think the elegance and convenience of a 1-line change is all well and Have I been lax and tardy on bottoming out what that impact is? yes. that On 28 September 2016 at 20:08, wmate notifications@github.com wrote:
Regards, Marc |
Wouldn't integration tests take away some those fears? |
@kbilsted my main concern would be the external 3rd-party code that could get an unexpected change in behaviour, i.e. a type handler that was previously doing nothing and had been forgotten about could start running. As such this change would have to be a major release under semantic versioning. There were further comments on the pull request #458 (which probably also needs the breaking change label). At the moment, the simplest way is to wrap the enum in a simple struct with implicit conversions, then you can add a type handler on the wrapping struct. |
@chilversc I don't think bumping the major version is an argument for not implementing the support. More importantly, I did not realize there was a simple solution that did not require code changes in dapper. Would you kindly document the suggested approach in the |
It would be nice to be able to opt-into support for the behavior requested by this issue instead of having to wait for v2.0. |
Could hide it behind a feature flag, or add a new interface such as |
Is there any chance this will be changed? If not then, unfortunately, I will have to look for an alternative because at the moment I have not found it possible to handle PostgreSQL Enum Types using Dapper in any form or workaround? More importanly, I should add that I very much do appreciate the hard work that has gone into this library and am a bit disappointed I cannot use it, so this is not a criticism, just need to know if its on the timeline at all as its a very old issue. |
I'd like to see this fixed. It's a frustrating and baffling limitation. Let me use my own handler please. |
Good job, team! |
6 years and no fix :/ |
Why hasn't this been fixed yet? I've spend hours trying to figure out why this is not working only to find out that this has been an issue for over six years now. |
Still no progress on this issue? That's just to bad... |
It's frustrating that such a common issue with such a trivial fix is not being considered...surely by now we have had enough time to rationalize the implications of this |
@mgravell Any update since your last message? As others have said, this fix is trivial, there have been multiple PRs with unit tests provided. In your last update you mentioned that you didn't think type handlers shouldn't subvert the "expected behaviour of primitives" however given than System.Text.Json allows Enums to serialize as ints or strings I think we need to take a look at those expectations. Those of us working with legacy databases would hugely appreciate some feedback here as to whether Dapper is ever going to be suitable for our needs, or whether we need to look for other solutions. |
@mgravell this is now 7 years old. Can the Dapper team either close the 453454 issues as 'wont fix' or make a decision on fixing this? |
@phillip-haydon Our decision on fixing this has been very consistent: we'd like to change this, if safe, in a breaking release. At the very least, it's a behavior change. At the most it could cause collateral damage to things and/or need an option (v3 has a plan for Options, but again: time). Overall a breaking major version is a very high bar and has a lot of work to do - and it's not just the work but follow-up on any issues, that's far worst than a known state. A change good for some can harm others. We're trying to button up The world has shifted here in that Dapper emitting IL to do deserialization isn't the path we'd ideally take at this point. It's not friendly to some restricted and many high performance scenarios (e.g. AOT). A vNext, when we can find the time, is a huge undertaking - until then we're holding off on breaking changes. This is open source, if you want to branch and change the behavior for your scenario and any deal with any behavioral differences or unexpected things that arise: go for it! |
Is there still no solution for this? It's 2022, 7 yeays since the issue opened, unbelievable. |
Hello from 2023 eve. Yet another frustrating enum issue opened for 8 years now. Just can't believe I've bumped into such an issue with such hyped ORM 😡 |
Just ran into this problem when trying to map enums to PostgreSQL enums using npgsql. As a long-time dapper user, I really hope this gets addressed in v3.0 |
+1 for fixing this. |
Please, fix the issue! |
It's 2 am, and after scratching my head for several hours on why my type handler wasn't working with Enums, I find that it's been an open issue for the past 7 years. yay. |
We ended up switching all our dapper code with linq2db as it supports custom handling for nearly everything. As a side bonus things become more typesafe, but it's a slightly different way to query. |
I'm slowly beginning to be convinced that Dapper is a dead project. Which is a shame cos I really love dapper. |
The reports of my death have been greatly exaggerated Hesitance to look at a specific feature doesn't mean we're not here; it means there might be more to it than you think, and it might not be as simple as one-fix-suits-all. |
@mgravell Dude, it's 2024, how many more years will this take? I get that you hesitate, that you are wary, cautious and all of that good stuff but at some point it becomes something else. |
I, too, have just spent hours trying to make this work and come to find it's been an issue for near 9 years. Any movement on this? |
I use ugly but generic workaround here as follows, just make sure you bind DB model into "MessageType" (property): Data model class:
sample enum:
|
Yearly update: Project still appears dead. Issue is now 9 years old with no resolution in sight. |
Maybe this helps. I combined what I found online into something that works https://gist.github.com/djimmo/b54a1643f15bd4e54303992ddce4a968 |
My workaround for this is to create a proxy struct. public readonly struct MyEnumProxy(MyEnum value)
{
public MyEnum Value { get; } = value;
public static implicit operator MyEnum(MyEnumProxy wrapper) => wrapper.Value;
public static implicit operator MyEnumProxy(MyEnum value) => new(value);
}
public enum MyEnum
{
Value1,
Value2,
Value3,
}
public sealed class MyEnumProxyTypeHandler : SqlMapper.TypeHandler<MyEnumProxy>
{
public override void SetValue(IDbDataParameter parameter, MyEnumProxy value) =>
{
// todo
}
public override MyEnumProxy Parse(object value) =>
value switch
{
"someValue1" => MyEnum.Value1,
"someValue2" => MyEnum.Value2,
"someValue3" => MyEnum.Value3,
_ => throw new ArgumentOutOfRangeException(nameof(value), value, null),
};
} |
I have an enum that is serialized to the DB using a single letter code.
I tried adding a custom type handler for the enum to handle the conversion but dapper seems to ignore the custom type handler.
Given the example code I expected to see the values;
ID = 10, Type = B
ID = 1, Type = Foo
What I actually got was:
ID = 1, Type = 2
DataException, Error parsing column 1 (Type=F - String)
The text was updated successfully, but these errors were encountered: