DefaultCustom.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace SqlSugar.DbConvert
  8. {
  9. public class EnumToStringConvert: ISugarDataConverter
  10. {
  11. public SugarParameter ParameterConverter<T>(object columnValue, int columnIndex)
  12. {
  13. var name = "@MyEnum" + columnIndex;
  14. Type undertype = SqlSugar.UtilMethods.GetUnderType(typeof(T));//获取没有nullable的枚举类型
  15. if (columnValue == null)
  16. {
  17. return new SugarParameter(name, null);
  18. }
  19. else
  20. {
  21. var enumObjString = Enum.Parse(undertype, columnValue + "").ToString();
  22. return new SugarParameter(name, enumObjString);
  23. }
  24. }
  25. public T QueryConverter<T>(IDataRecord dr, int i)
  26. {
  27. var str = dr.GetString(i);
  28. Type undertype = SqlSugar.UtilMethods.GetUnderType(typeof(T));//获取没有nullable的枚举类型
  29. return (T)Enum.Parse(undertype, str);
  30. }
  31. }
  32. public class NoParameterCommonPropertyConvert : ISugarDataConverter
  33. {
  34. public SugarParameter ParameterConverter<T>(object columnValue, int columnIndex)
  35. {
  36. if (columnValue == null)
  37. {
  38. new SugarParameter("null", null, null);
  39. }
  40. return new SugarParameter(columnValue+"", null, null);
  41. }
  42. public T QueryConverter<T>(IDataRecord dr, int i)
  43. {
  44. var value = dr.GetValue(i);
  45. return (T)UtilMethods.ChangeType2(value, typeof(T));
  46. }
  47. }
  48. public class CommonPropertyConvert : ISugarDataConverter
  49. {
  50. public SugarParameter ParameterConverter<T>(object columnValue, int columnIndex)
  51. {
  52. var name = "@Common" + columnIndex;
  53. Type undertype = SqlSugar.UtilMethods.GetUnderType(typeof(T));//获取没有nullable的枚举类型
  54. return new SugarParameter(name, columnValue, undertype);
  55. }
  56. public T QueryConverter<T>(IDataRecord dr, int i)
  57. {
  58. var value = dr.GetValue(i);
  59. if (value is byte[] && typeof(T) != UtilConstants.ByteArrayType)
  60. {
  61. value = Encoding.UTF8.GetString((byte[])value);
  62. }
  63. return (T)UtilMethods.ChangeType2(value, typeof(T));
  64. }
  65. }
  66. public class Nvarchar2PropertyConvert : ISugarDataConverter
  67. {
  68. public SugarParameter ParameterConverter<T>(object columnValue, int columnIndex)
  69. {
  70. var name = "@Common" + columnIndex;
  71. Type undertype = SqlSugar.UtilMethods.GetUnderType(typeof(T));//获取没有nullable的枚举类型
  72. return new SugarParameter(name, columnValue, undertype) { IsNvarchar2=true };
  73. }
  74. public T QueryConverter<T>(IDataRecord dr, int i)
  75. {
  76. var value = dr.GetString(i);
  77. return (T)(object)value;
  78. }
  79. }
  80. public class NClobPropertyConvert : ISugarDataConverter
  81. {
  82. public SugarParameter ParameterConverter<T>(object columnValue, int columnIndex)
  83. {
  84. var name = "@Common" + columnIndex;
  85. Type undertype = SqlSugar.UtilMethods.GetUnderType(typeof(T));//获取没有nullable的枚举类型
  86. return new SugarParameter(name, columnValue, undertype) { IsNClob = true };
  87. }
  88. public T QueryConverter<T>(IDataRecord dr, int i)
  89. {
  90. var value = dr.GetString(i);
  91. return (T)(object)value;
  92. }
  93. }
  94. }