JsonSqlFuncToParameters.cs 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. using Newtonsoft.Json.Linq;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Text.RegularExpressions;
  7. namespace SqlSugar
  8. {
  9. public partial class ContextMethods : IContextMethods
  10. {
  11. #region Root
  12. public List<object> GetParameter(JToken parameters)
  13. {
  14. List<object> result = new List<object>();
  15. if (IsString(parameters))
  16. {
  17. result.Add(GetStringParameters(parameters));
  18. }
  19. else if (IsArray(parameters))
  20. {
  21. result.AddRange(GetArrayParameters(parameters));
  22. }
  23. else if (IsObject(parameters))
  24. {
  25. result.Add(GetObjectParameters(parameters));
  26. }
  27. else
  28. {
  29. result.Add(GetObjectErrorParameters(parameters));
  30. }
  31. return result;
  32. }
  33. #endregion
  34. #region Level1
  35. private static List<object> GetObjectErrorParameters(JToken parameters)
  36. {
  37. Check.Exception(true, ErrorMessage.GetThrowMessage($" {parameters.ToString()} format is error ", $" {parameters.ToString()} 格式错误"));
  38. return null;
  39. }
  40. public List<object> GetArrayParameters(JToken parameters)
  41. {
  42. List<object> result = new List<object>();
  43. foreach (var item in parameters)
  44. {
  45. result.Add(GetParameter(item));
  46. }
  47. return result;
  48. }
  49. public object GetObjectParameters(JToken parameters)
  50. {
  51. return JsonToSqlFuncModels(parameters);
  52. }
  53. public object GetStringParameters(JToken parameters)
  54. {
  55. return parameters.ObjToString().ToCheckField();
  56. }
  57. #endregion
  58. }
  59. }