■ NULLABLE DATETIME 사용시 처리하는 방법을 보여준다.
Dapper에서 DateTime? 컬럼 값 조회시 타입 변환 에러가 발생하기 때문에
NullableDateTimeHandler.cs 소스코드를 추가하고, 프로그램 시작시 아래 코드를 실행하도록 한다.
SqlMapper.AddTypeHandler(NullableDateTimeHandler.Default);
▶ NullableDateTimeHandler.cs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
using System.Data; using Dapper; /// <summary> /// NULLABLE 날짜/시간 핸들러 /// </summary> public class NullableDateTimeHandler : SqlMapper.TypeHandler<DateTime?> { //////////////////////////////////////////////////////////////////////////////////////////////////// Field ////////////////////////////////////////////////////////////////////////////////////////// Static //////////////////////////////////////////////////////////////////////////////// Public #region Field /// <summary> /// 디폴트 /// </summary> public static readonly NullableDateTimeHandler Default = new NullableDateTimeHandler(); #endregion //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor ////////////////////////////////////////////////////////////////////////////////////////// Protected #region 생성자 - NullableDateTimeHandler() /// <summary> /// 생성자 /// </summary> protected NullableDateTimeHandler() { } #endregion //////////////////////////////////////////////////////////////////////////////////////////////////// Method ////////////////////////////////////////////////////////////////////////////////////////// Public #region 값 설정하기 - SetValue(parameter, value) /// <summary> /// 값 설정하기 /// </summary> /// <param name="parameter">매개 변수</param> /// <param name="value">값</param> public override void SetValue(IDbDataParameter parameter, DateTime? value) { if(value.HasValue) { parameter.Value = value.Value; } else { parameter.Value = DBNull.Value; } } #endregion #region 파싱하기 - Parse(value) /// <summary> /// 파싱하기 /// </summary> /// <param name="value">값</param> /// <returns>NULLABLE 날짜/시간 값</returns> public override DateTime? Parse(object value) { if(value == null) { return null; } if(value is DateTime) { return (DateTime)value; } return Convert.ToDateTime(value); } #endregion } |