SubLeftJoin.cs 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Linq.Expressions;
  5. using System.Text;
  6. using System.Text.RegularExpressions;
  7. using System.Threading.Tasks;
  8. namespace SqlSugar
  9. {
  10. public class SubLeftJoin : ISubOperation
  11. {
  12. public bool HasWhere
  13. {
  14. get; set;
  15. }
  16. public string Name
  17. {
  18. get { return "LeftJoin"; }
  19. }
  20. public Expression Expression
  21. {
  22. get; set;
  23. }
  24. public int Sort
  25. {
  26. get
  27. {
  28. return 302;
  29. }
  30. }
  31. public ExpressionContext Context
  32. {
  33. get; set;
  34. }
  35. public string GetValue(Expression expression)
  36. {
  37. var exp = expression as MethodCallExpression;
  38. var argExp = exp.Arguments[0];
  39. var name =this.Context.GetTranslationColumnName((argExp as LambdaExpression).Parameters[0].Name);
  40. var parameter = (argExp as LambdaExpression).Parameters.Last();
  41. foreach (var item in (argExp as LambdaExpression).Parameters)
  42. {
  43. Context.InitMappingInfo(item.Type);
  44. }
  45. this.Context.RefreshMapping();
  46. var tableName= Context.GetTranslationTableName(parameter.Type.Name, true);
  47. if (exp.Arguments.Count == 2 && exp.Arguments.Last().HasValue())
  48. {
  49. tableName=Context.GetTranslationTableName(ExpressionTool.DynamicInvoke(exp.Arguments.Last())+"");
  50. }
  51. var joinString =string.Format(" {2} LEFT JOIN {1} {0} ",
  52. this.Context.GetTranslationColumnName(parameter.Name),
  53. tableName,
  54. null);
  55. if (this.Context?.SugarContext?.Context?.CurrentConnectionConfig?.DbType == DbType.SqlServer && this.Context?.SugarContext?.Context?.CurrentConnectionConfig?.MoreSettings?.IsWithNoLockSubquery == true)
  56. {
  57. joinString = $"{joinString} {SqlWith.NoLock} ";
  58. }
  59. var result = joinString+ "ON " + SubTools.GetMethodValue(Context, argExp, ResolveExpressType.WhereMultiple);
  60. //var selfParameterName = Context.GetTranslationColumnName((argExp as LambdaExpression).Parameters.First().Name) + UtilConstants.Dot;
  61. this.Context.JoinIndex++;
  62. new SubSelect() { Context = this.Context }.SetShortName(exp, "+");
  63. //result = result.Replace(selfParameterName, SubTools.GetSubReplace(this.Context));
  64. return result;
  65. }
  66. }
  67. }