diff --git a/Models/App.Config b/Models/App.Config index 679346b..994d613 100644 --- a/Models/App.Config +++ b/Models/App.Config @@ -1,9 +1,10 @@  - - + + + \ No newline at end of file diff --git a/Models/CHEMICAL_QUEUE.cs b/Models/CHEMICAL_QUEUE.cs new file mode 100644 index 0000000..04c9fd5 --- /dev/null +++ b/Models/CHEMICAL_QUEUE.cs @@ -0,0 +1,27 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class CHEMICAL_QUEUE + { + public string tmp_field { get; set; } + public string ID_NO { get; set; } + public Nullable STEP_NO { get; set; } + public string CREATE_DATE { get; set; } + public string CREATE_TIME { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public Nullable PRIORITY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/DYESTUFF_QUEUE.cs b/Models/DYESTUFF_QUEUE.cs new file mode 100644 index 0000000..f8f945a --- /dev/null +++ b/Models/DYESTUFF_QUEUE.cs @@ -0,0 +1,27 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class DYESTUFF_QUEUE + { + public string tmp_field { get; set; } + public string ID_NO { get; set; } + public Nullable STEP_NO { get; set; } + public string CREATE_DATE { get; set; } + public string CREATE_TIME { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public Nullable PRIORITY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/JOBTKT.cs b/Models/JOBTKT.cs new file mode 100644 index 0000000..2a1e468 --- /dev/null +++ b/Models/JOBTKT.cs @@ -0,0 +1,24 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class JOBTKT + { + public string tmp_field { get; set; } + public string IDNO { get; set; } + public Nullable FNDATE { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/Models.csproj b/Models/Models.csproj index fac70fe..aba91f9 100644 --- a/Models/Models.csproj +++ b/Models/Models.csproj @@ -74,6 +74,9 @@ SQL_BD.tt + + SQL_Ti.tt + SQL_BD.tt @@ -143,9 +146,15 @@ SQL_BD.tt + + SQL_Ti.tt + SQL_BD.tt + + SQL_Ti.tt + SQL_BD.tt @@ -188,6 +197,18 @@ SQL_BD.tt + + SQL_Ti.tt + + + SQL_Ti.tt + + + SQL_Ti.tt + + + SQL_Ti.tt + SQL_BD.tt @@ -207,6 +228,9 @@ SQL_BD.tt + + SQL_Ti.tt + SQL_BD.tt @@ -240,6 +264,21 @@ True SQL_BD.edmx + + True + True + SQL_Ti.Context.tt + + + True + True + SQL_Ti.tt + + + True + True + SQL_Ti.edmx + SQL_BD.tt @@ -252,6 +291,24 @@ SQL_BD.tt + + SQL_Ti.tt + + + SQL_Ti.tt + + + SQL_Ti.tt + + + SQL_Ti.tt + + + SQL_Ti.tt + + + SQL_Ti.tt + SQL_BD.tt @@ -274,6 +331,13 @@ SQL_BD.edmx + + EntityModelCodeGenerator + SQL_Ti.Designer.cs + + + SQL_Ti.edmx + @@ -286,6 +350,16 @@ SQL_BD.edmx SQL_BD.cs + + TextTemplatingFileGenerator + SQL_Ti.edmx + SQL_Ti.Context.cs + + + TextTemplatingFileGenerator + SQL_Ti.edmx + SQL_Ti.cs + diff --git a/Models/POWDER_QUEUE.cs b/Models/POWDER_QUEUE.cs new file mode 100644 index 0000000..4ae2986 --- /dev/null +++ b/Models/POWDER_QUEUE.cs @@ -0,0 +1,27 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class POWDER_QUEUE + { + public string tmp_field { get; set; } + public string ID_NO { get; set; } + public Nullable STEP_NO { get; set; } + public string CREATE_DATE { get; set; } + public string CREATE_TIME { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public Nullable PRIORITY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/Product.cs b/Models/Product.cs new file mode 100644 index 0000000..89c7c77 --- /dev/null +++ b/Models/Product.cs @@ -0,0 +1,78 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class Product + { + public string ProductCode { get; set; } + public string ProductName { get; set; } + public Nullable Price { get; set; } + public Nullable Deduct { get; set; } + public Nullable FullWeight { get; set; } + public Nullable LampPosition { get; set; } + public string TablePosition { get; set; } + public string AREA { get; set; } + public Nullable SafetyStock { get; set; } + public Nullable ProductUnit { get; set; } + public Nullable ProductType { get; set; } + public Nullable ProductClass { get; set; } + public Nullable CurrentStock { get; set; } + public string ProductLot { get; set; } + public Nullable RplDate { get; set; } + public Nullable UsedDate { get; set; } + public string CuMonth { get; set; } + public Nullable LaStock { get; set; } + public Nullable ThStock { get; set; } + public Nullable ThUsed { get; set; } + public Nullable Color { get; set; } + public Nullable LastTime { get; set; } + public Nullable CalTime { get; set; } + public Nullable BackflowTime { get; set; } + public Nullable Tol_G { get; set; } + public Nullable Tol_P { get; set; } + public Nullable Alarm { get; set; } + public Nullable Change_Bucket { get; set; } + public Nullable Small_Volume_by_manual { get; set; } + public Nullable Target_Weight { get; set; } + public Nullable Pre_Weight { get; set; } + public Nullable One_Sec { get; set; } + public Nullable GetscalTime { get; set; } + public Nullable DelayOpenValve { get; set; } + public string ValveMap { get; set; } + public string PumpMap { get; set; } + public Nullable Includepump { get; set; } + public Nullable Once_minimum_weight { get; set; } + public Nullable Once_minimum_max_weight { get; set; } + public Nullable Once_minimum_time { get; set; } + public string Res_S1 { get; set; } + public string Res_S2 { get; set; } + public string Res_S3 { get; set; } + public string Res_S4 { get; set; } + public Nullable Res_I1 { get; set; } + public Nullable Res_I2 { get; set; } + public Nullable Res_I3 { get; set; } + public Nullable Res_I4 { get; set; } + public Nullable Res_F1 { get; set; } + public Nullable Res_F2 { get; set; } + public Nullable Res_F3 { get; set; } + public Nullable Res_F4 { get; set; } + public string Batch_NO { get; set; } + public Nullable Concentration { get; set; } + public Nullable Pump { get; set; } + public Nullable PRODUCT_KIND { get; set; } + public string SUPPLIER { get; set; } + public Nullable PRODUCT_MODIFY_DATE { get; set; } + public double GRAVITY { get; set; } + public string UserAccount { get; set; } + } +} diff --git a/Models/ProductInventory.cs b/Models/ProductInventory.cs new file mode 100644 index 0000000..8f4895e --- /dev/null +++ b/Models/ProductInventory.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class ProductInventory + { + public string ProductCode { get; set; } + public Nullable Quantity { get; set; } + public Nullable Price { get; set; } + public Nullable CreateDate { get; set; } + } +} diff --git a/Models/ProductUsed.cs b/Models/ProductUsed.cs new file mode 100644 index 0000000..be0b313 --- /dev/null +++ b/Models/ProductUsed.cs @@ -0,0 +1,21 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class ProductUsed + { + public string ProductCode { get; set; } + public Nullable UsedQty { get; set; } + public Nullable CreateDate { get; set; } + } +} diff --git a/Models/REMOTETERMINAL.cs b/Models/REMOTETERMINAL.cs new file mode 100644 index 0000000..679bc6c --- /dev/null +++ b/Models/REMOTETERMINAL.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class REMOTETERMINAL + { + public string tmp_field { get; set; } + public string IDNO { get; set; } + public Nullable FNDATE { get; set; } + public string IDTYPE { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/SQL_Ti.Context.cs b/Models/SQL_Ti.Context.cs new file mode 100644 index 0000000..462ffb1 --- /dev/null +++ b/Models/SQL_Ti.Context.cs @@ -0,0 +1,43 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Data.Entity; + using System.Data.Entity.Infrastructure; + + public partial class TicketEntities : DbContext + { + public TicketEntities() + : base("name=TicketEntities") + { + } + + protected override void OnModelCreating(DbModelBuilder modelBuilder) + { + throw new UnintentionalCodeFirstException(); + } + + public virtual DbSet Product { get; set; } + public virtual DbSet ProductInventory { get; set; } + public virtual DbSet ProductUsed { get; set; } + public virtual DbSet CHEMICAL_QUEUE { get; set; } + public virtual DbSet DYESTUFF_QUEUE { get; set; } + public virtual DbSet JOBTKT { get; set; } + public virtual DbSet POWDER_QUEUE { get; set; } + public virtual DbSet REMOTETERMINAL { get; set; } + public virtual DbSet TEMPCHEMICALTKT { get; set; } + public virtual DbSet TEMPDYESTUFFTKT { get; set; } + public virtual DbSet TEMPPOWDER { get; set; } + public virtual DbSet TICKET_DETAIL { get; set; } + public virtual DbSet TicketSerial { get; set; } + public virtual DbSet UserAccount { get; set; } + } +} diff --git a/Models/SQL_Ti.Context.tt b/Models/SQL_Ti.Context.tt new file mode 100644 index 0000000..a0b5dfb --- /dev/null +++ b/Models/SQL_Ti.Context.tt @@ -0,0 +1,636 @@ +<#@ template language="C#" debug="false" hostspecific="true"#> +<#@ include file="EF6.Utility.CS.ttinclude"#><#@ + output extension=".cs"#><# + +const string inputFile = @"SQL_Ti.edmx"; +var textTransform = DynamicTextTransformation.Create(this); +var code = new CodeGenerationTools(this); +var ef = new MetadataTools(this); +var typeMapper = new TypeMapper(code, ef, textTransform.Errors); +var loader = new EdmMetadataLoader(textTransform.Host, textTransform.Errors); +var itemCollection = loader.CreateEdmItemCollection(inputFile); +var modelNamespace = loader.GetModelNamespace(inputFile); +var codeStringGenerator = new CodeStringGenerator(code, typeMapper, ef); + +var container = itemCollection.OfType().FirstOrDefault(); +if (container == null) +{ + return string.Empty; +} +#> +//------------------------------------------------------------------------------ +// +// <#=CodeGenerationTools.GetResourceString("Template_GeneratedCodeCommentLine1")#> +// +// <#=CodeGenerationTools.GetResourceString("Template_GeneratedCodeCommentLine2")#> +// <#=CodeGenerationTools.GetResourceString("Template_GeneratedCodeCommentLine3")#> +// +//------------------------------------------------------------------------------ + +<# + +var codeNamespace = code.VsNamespaceSuggestion(); +if (!String.IsNullOrEmpty(codeNamespace)) +{ +#> +namespace <#=code.EscapeNamespace(codeNamespace)#> +{ +<# + PushIndent(" "); +} + +#> +using System; +using System.Data.Entity; +using System.Data.Entity.Infrastructure; +<# +if (container.FunctionImports.Any()) +{ +#> +using System.Data.Entity.Core.Objects; +using System.Linq; +<# +} +#> + +<#=Accessibility.ForType(container)#> partial class <#=code.Escape(container)#> : DbContext +{ + public <#=code.Escape(container)#>() + : base("name=<#=container.Name#>") + { +<# +if (!loader.IsLazyLoadingEnabled(container)) +{ +#> + this.Configuration.LazyLoadingEnabled = false; +<# +} + +foreach (var entitySet in container.BaseEntitySets.OfType()) +{ + // Note: the DbSet members are defined below such that the getter and + // setter always have the same accessibility as the DbSet definition + if (Accessibility.ForReadOnlyProperty(entitySet) != "public") + { +#> + <#=codeStringGenerator.DbSetInitializer(entitySet)#> +<# + } +} +#> + } + + protected override void OnModelCreating(DbModelBuilder modelBuilder) + { + throw new UnintentionalCodeFirstException(); + } + +<# + foreach (var entitySet in container.BaseEntitySets.OfType()) + { +#> + <#=codeStringGenerator.DbSet(entitySet)#> +<# + } + + foreach (var edmFunction in container.FunctionImports) + { + WriteFunctionImport(typeMapper, codeStringGenerator, edmFunction, modelNamespace, includeMergeOption: false); + } +#> +} +<# + +if (!String.IsNullOrEmpty(codeNamespace)) +{ + PopIndent(); +#> +} +<# +} +#> +<#+ + +private void WriteFunctionImport(TypeMapper typeMapper, CodeStringGenerator codeStringGenerator, EdmFunction edmFunction, string modelNamespace, bool includeMergeOption) +{ + if (typeMapper.IsComposable(edmFunction)) + { +#> + + [DbFunction("<#=edmFunction.NamespaceName#>", "<#=edmFunction.Name#>")] + <#=codeStringGenerator.ComposableFunctionMethod(edmFunction, modelNamespace)#> + { +<#+ + codeStringGenerator.WriteFunctionParameters(edmFunction, WriteFunctionParameter); +#> + <#=codeStringGenerator.ComposableCreateQuery(edmFunction, modelNamespace)#> + } +<#+ + } + else + { +#> + + <#=codeStringGenerator.FunctionMethod(edmFunction, modelNamespace, includeMergeOption)#> + { +<#+ + codeStringGenerator.WriteFunctionParameters(edmFunction, WriteFunctionParameter); +#> + <#=codeStringGenerator.ExecuteFunction(edmFunction, modelNamespace, includeMergeOption)#> + } +<#+ + if (typeMapper.GenerateMergeOptionFunction(edmFunction, includeMergeOption)) + { + WriteFunctionImport(typeMapper, codeStringGenerator, edmFunction, modelNamespace, includeMergeOption: true); + } + } +} + +public void WriteFunctionParameter(string name, string isNotNull, string notNullInit, string nullInit) +{ +#> + var <#=name#> = <#=isNotNull#> ? + <#=notNullInit#> : + <#=nullInit#>; + +<#+ +} + +public const string TemplateId = "CSharp_DbContext_Context_EF6"; + +public class CodeStringGenerator +{ + private readonly CodeGenerationTools _code; + private readonly TypeMapper _typeMapper; + private readonly MetadataTools _ef; + + public CodeStringGenerator(CodeGenerationTools code, TypeMapper typeMapper, MetadataTools ef) + { + ArgumentNotNull(code, "code"); + ArgumentNotNull(typeMapper, "typeMapper"); + ArgumentNotNull(ef, "ef"); + + _code = code; + _typeMapper = typeMapper; + _ef = ef; + } + + public string Property(EdmProperty edmProperty) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1} {2} {{ {3}get; {4}set; }}", + Accessibility.ForProperty(edmProperty), + _typeMapper.GetTypeName(edmProperty.TypeUsage), + _code.Escape(edmProperty), + _code.SpaceAfter(Accessibility.ForGetter(edmProperty)), + _code.SpaceAfter(Accessibility.ForSetter(edmProperty))); + } + + public string NavigationProperty(NavigationProperty navProp) + { + var endType = _typeMapper.GetTypeName(navProp.ToEndMember.GetEntityType()); + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1} {2} {{ {3}get; {4}set; }}", + AccessibilityAndVirtual(Accessibility.ForNavigationProperty(navProp)), + navProp.ToEndMember.RelationshipMultiplicity == RelationshipMultiplicity.Many ? ("ICollection<" + endType + ">") : endType, + _code.Escape(navProp), + _code.SpaceAfter(Accessibility.ForGetter(navProp)), + _code.SpaceAfter(Accessibility.ForSetter(navProp))); + } + + public string AccessibilityAndVirtual(string accessibility) + { + return accessibility + (accessibility != "private" ? " virtual" : ""); + } + + public string EntityClassOpening(EntityType entity) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1}partial class {2}{3}", + Accessibility.ForType(entity), + _code.SpaceAfter(_code.AbstractOption(entity)), + _code.Escape(entity), + _code.StringBefore(" : ", _typeMapper.GetTypeName(entity.BaseType))); + } + + public string EnumOpening(SimpleType enumType) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} enum {1} : {2}", + Accessibility.ForType(enumType), + _code.Escape(enumType), + _code.Escape(_typeMapper.UnderlyingClrType(enumType))); + } + + public void WriteFunctionParameters(EdmFunction edmFunction, Action writeParameter) + { + var parameters = FunctionImportParameter.Create(edmFunction.Parameters, _code, _ef); + foreach (var parameter in parameters.Where(p => p.NeedsLocalVariable)) + { + var isNotNull = parameter.IsNullableOfT ? parameter.FunctionParameterName + ".HasValue" : parameter.FunctionParameterName + " != null"; + var notNullInit = "new ObjectParameter(\"" + parameter.EsqlParameterName + "\", " + parameter.FunctionParameterName + ")"; + var nullInit = "new ObjectParameter(\"" + parameter.EsqlParameterName + "\", typeof(" + TypeMapper.FixNamespaces(parameter.RawClrTypeName) + "))"; + writeParameter(parameter.LocalVariableName, isNotNull, notNullInit, nullInit); + } + } + + public string ComposableFunctionMethod(EdmFunction edmFunction, string modelNamespace) + { + var parameters = _typeMapper.GetParameters(edmFunction); + + return string.Format( + CultureInfo.InvariantCulture, + "{0} IQueryable<{1}> {2}({3})", + AccessibilityAndVirtual(Accessibility.ForMethod(edmFunction)), + _typeMapper.GetTypeName(_typeMapper.GetReturnType(edmFunction), modelNamespace), + _code.Escape(edmFunction), + string.Join(", ", parameters.Select(p => TypeMapper.FixNamespaces(p.FunctionParameterType) + " " + p.FunctionParameterName).ToArray())); + } + + public string ComposableCreateQuery(EdmFunction edmFunction, string modelNamespace) + { + var parameters = _typeMapper.GetParameters(edmFunction); + + return string.Format( + CultureInfo.InvariantCulture, + "return ((IObjectContextAdapter)this).ObjectContext.CreateQuery<{0}>(\"[{1}].[{2}]({3})\"{4});", + _typeMapper.GetTypeName(_typeMapper.GetReturnType(edmFunction), modelNamespace), + edmFunction.NamespaceName, + edmFunction.Name, + string.Join(", ", parameters.Select(p => "@" + p.EsqlParameterName).ToArray()), + _code.StringBefore(", ", string.Join(", ", parameters.Select(p => p.ExecuteParameterName).ToArray()))); + } + + public string FunctionMethod(EdmFunction edmFunction, string modelNamespace, bool includeMergeOption) + { + var parameters = _typeMapper.GetParameters(edmFunction); + var returnType = _typeMapper.GetReturnType(edmFunction); + + var paramList = String.Join(", ", parameters.Select(p => TypeMapper.FixNamespaces(p.FunctionParameterType) + " " + p.FunctionParameterName).ToArray()); + if (includeMergeOption) + { + paramList = _code.StringAfter(paramList, ", ") + "MergeOption mergeOption"; + } + + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1} {2}({3})", + AccessibilityAndVirtual(Accessibility.ForMethod(edmFunction)), + returnType == null ? "int" : "ObjectResult<" + _typeMapper.GetTypeName(returnType, modelNamespace) + ">", + _code.Escape(edmFunction), + paramList); + } + + public string ExecuteFunction(EdmFunction edmFunction, string modelNamespace, bool includeMergeOption) + { + var parameters = _typeMapper.GetParameters(edmFunction); + var returnType = _typeMapper.GetReturnType(edmFunction); + + var callParams = _code.StringBefore(", ", String.Join(", ", parameters.Select(p => p.ExecuteParameterName).ToArray())); + if (includeMergeOption) + { + callParams = ", mergeOption" + callParams; + } + + return string.Format( + CultureInfo.InvariantCulture, + "return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction{0}(\"{1}\"{2});", + returnType == null ? "" : "<" + _typeMapper.GetTypeName(returnType, modelNamespace) + ">", + edmFunction.Name, + callParams); + } + + public string DbSet(EntitySet entitySet) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} virtual DbSet<{1}> {2} {{ get; set; }}", + Accessibility.ForReadOnlyProperty(entitySet), + _typeMapper.GetTypeName(entitySet.ElementType), + _code.Escape(entitySet)); + } + + public string DbSetInitializer(EntitySet entitySet) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} = Set<{1}>();", + _code.Escape(entitySet), + _typeMapper.GetTypeName(entitySet.ElementType)); + } + + public string UsingDirectives(bool inHeader, bool includeCollections = true) + { + return inHeader == string.IsNullOrEmpty(_code.VsNamespaceSuggestion()) + ? string.Format( + CultureInfo.InvariantCulture, + "{0}using System;{1}" + + "{2}", + inHeader ? Environment.NewLine : "", + includeCollections ? (Environment.NewLine + "using System.Collections.Generic;") : "", + inHeader ? "" : Environment.NewLine) + : ""; + } +} + +public class TypeMapper +{ + private const string ExternalTypeNameAttributeName = @"http://schemas.microsoft.com/ado/2006/04/codegeneration:ExternalTypeName"; + + private readonly System.Collections.IList _errors; + private readonly CodeGenerationTools _code; + private readonly MetadataTools _ef; + + public static string FixNamespaces(string typeName) + { + return typeName.Replace("System.Data.Spatial.", "System.Data.Entity.Spatial."); + } + + public TypeMapper(CodeGenerationTools code, MetadataTools ef, System.Collections.IList errors) + { + ArgumentNotNull(code, "code"); + ArgumentNotNull(ef, "ef"); + ArgumentNotNull(errors, "errors"); + + _code = code; + _ef = ef; + _errors = errors; + } + + public string GetTypeName(TypeUsage typeUsage) + { + return typeUsage == null ? null : GetTypeName(typeUsage.EdmType, _ef.IsNullable(typeUsage), modelNamespace: null); + } + + public string GetTypeName(EdmType edmType) + { + return GetTypeName(edmType, isNullable: null, modelNamespace: null); + } + + public string GetTypeName(TypeUsage typeUsage, string modelNamespace) + { + return typeUsage == null ? null : GetTypeName(typeUsage.EdmType, _ef.IsNullable(typeUsage), modelNamespace); + } + + public string GetTypeName(EdmType edmType, string modelNamespace) + { + return GetTypeName(edmType, isNullable: null, modelNamespace: modelNamespace); + } + + public string GetTypeName(EdmType edmType, bool? isNullable, string modelNamespace) + { + if (edmType == null) + { + return null; + } + + var collectionType = edmType as CollectionType; + if (collectionType != null) + { + return String.Format(CultureInfo.InvariantCulture, "ICollection<{0}>", GetTypeName(collectionType.TypeUsage, modelNamespace)); + } + + var typeName = _code.Escape(edmType.MetadataProperties + .Where(p => p.Name == ExternalTypeNameAttributeName) + .Select(p => (string)p.Value) + .FirstOrDefault()) + ?? (modelNamespace != null && edmType.NamespaceName != modelNamespace ? + _code.CreateFullName(_code.EscapeNamespace(edmType.NamespaceName), _code.Escape(edmType)) : + _code.Escape(edmType)); + + if (edmType is StructuralType) + { + return typeName; + } + + if (edmType is SimpleType) + { + var clrType = UnderlyingClrType(edmType); + if (!IsEnumType(edmType)) + { + typeName = _code.Escape(clrType); + } + + typeName = FixNamespaces(typeName); + + return clrType.IsValueType && isNullable == true ? + String.Format(CultureInfo.InvariantCulture, "Nullable<{0}>", typeName) : + typeName; + } + + throw new ArgumentException("edmType"); + } + + public Type UnderlyingClrType(EdmType edmType) + { + ArgumentNotNull(edmType, "edmType"); + + var primitiveType = edmType as PrimitiveType; + if (primitiveType != null) + { + return primitiveType.ClrEquivalentType; + } + + if (IsEnumType(edmType)) + { + return GetEnumUnderlyingType(edmType).ClrEquivalentType; + } + + return typeof(object); + } + + public object GetEnumMemberValue(MetadataItem enumMember) + { + ArgumentNotNull(enumMember, "enumMember"); + + var valueProperty = enumMember.GetType().GetProperty("Value"); + return valueProperty == null ? null : valueProperty.GetValue(enumMember, null); + } + + public string GetEnumMemberName(MetadataItem enumMember) + { + ArgumentNotNull(enumMember, "enumMember"); + + var nameProperty = enumMember.GetType().GetProperty("Name"); + return nameProperty == null ? null : (string)nameProperty.GetValue(enumMember, null); + } + + public System.Collections.IEnumerable GetEnumMembers(EdmType enumType) + { + ArgumentNotNull(enumType, "enumType"); + + var membersProperty = enumType.GetType().GetProperty("Members"); + return membersProperty != null + ? (System.Collections.IEnumerable)membersProperty.GetValue(enumType, null) + : Enumerable.Empty(); + } + + public bool EnumIsFlags(EdmType enumType) + { + ArgumentNotNull(enumType, "enumType"); + + var isFlagsProperty = enumType.GetType().GetProperty("IsFlags"); + return isFlagsProperty != null && (bool)isFlagsProperty.GetValue(enumType, null); + } + + public bool IsEnumType(GlobalItem edmType) + { + ArgumentNotNull(edmType, "edmType"); + + return edmType.GetType().Name == "EnumType"; + } + + public PrimitiveType GetEnumUnderlyingType(EdmType enumType) + { + ArgumentNotNull(enumType, "enumType"); + + return (PrimitiveType)enumType.GetType().GetProperty("UnderlyingType").GetValue(enumType, null); + } + + public string CreateLiteral(object value) + { + if (value == null || value.GetType() != typeof(TimeSpan)) + { + return _code.CreateLiteral(value); + } + + return string.Format(CultureInfo.InvariantCulture, "new TimeSpan({0})", ((TimeSpan)value).Ticks); + } + + public bool VerifyCaseInsensitiveTypeUniqueness(IEnumerable types, string sourceFile) + { + ArgumentNotNull(types, "types"); + ArgumentNotNull(sourceFile, "sourceFile"); + + var hash = new HashSet(StringComparer.InvariantCultureIgnoreCase); + if (types.Any(item => !hash.Add(item))) + { + _errors.Add( + new CompilerError(sourceFile, -1, -1, "6023", + String.Format(CultureInfo.CurrentCulture, CodeGenerationTools.GetResourceString("Template_CaseInsensitiveTypeConflict")))); + return false; + } + return true; + } + + public IEnumerable GetEnumItemsToGenerate(IEnumerable itemCollection) + { + return GetItemsToGenerate(itemCollection) + .Where(e => IsEnumType(e)); + } + + public IEnumerable GetItemsToGenerate(IEnumerable itemCollection) where T: EdmType + { + return itemCollection + .OfType() + .Where(i => !i.MetadataProperties.Any(p => p.Name == ExternalTypeNameAttributeName)) + .OrderBy(i => i.Name); + } + + public IEnumerable GetAllGlobalItems(IEnumerable itemCollection) + { + return itemCollection + .Where(i => i is EntityType || i is ComplexType || i is EntityContainer || IsEnumType(i)) + .Select(g => GetGlobalItemName(g)); + } + + public string GetGlobalItemName(GlobalItem item) + { + if (item is EdmType) + { + return ((EdmType)item).Name; + } + else + { + return ((EntityContainer)item).Name; + } + } + + public IEnumerable GetSimpleProperties(EntityType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type); + } + + public IEnumerable GetSimpleProperties(ComplexType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type); + } + + public IEnumerable GetComplexProperties(EntityType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is ComplexType && p.DeclaringType == type); + } + + public IEnumerable GetComplexProperties(ComplexType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is ComplexType && p.DeclaringType == type); + } + + public IEnumerable GetPropertiesWithDefaultValues(EntityType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type && p.DefaultValue != null); + } + + public IEnumerable GetPropertiesWithDefaultValues(ComplexType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type && p.DefaultValue != null); + } + + public IEnumerable GetNavigationProperties(EntityType type) + { + return type.NavigationProperties.Where(np => np.DeclaringType == type); + } + + public IEnumerable GetCollectionNavigationProperties(EntityType type) + { + return type.NavigationProperties.Where(np => np.DeclaringType == type && np.ToEndMember.RelationshipMultiplicity == RelationshipMultiplicity.Many); + } + + public FunctionParameter GetReturnParameter(EdmFunction edmFunction) + { + ArgumentNotNull(edmFunction, "edmFunction"); + + var returnParamsProperty = edmFunction.GetType().GetProperty("ReturnParameters"); + return returnParamsProperty == null + ? edmFunction.ReturnParameter + : ((IEnumerable)returnParamsProperty.GetValue(edmFunction, null)).FirstOrDefault(); + } + + public bool IsComposable(EdmFunction edmFunction) + { + ArgumentNotNull(edmFunction, "edmFunction"); + + var isComposableProperty = edmFunction.GetType().GetProperty("IsComposableAttribute"); + return isComposableProperty != null && (bool)isComposableProperty.GetValue(edmFunction, null); + } + + public IEnumerable GetParameters(EdmFunction edmFunction) + { + return FunctionImportParameter.Create(edmFunction.Parameters, _code, _ef); + } + + public TypeUsage GetReturnType(EdmFunction edmFunction) + { + var returnParam = GetReturnParameter(edmFunction); + return returnParam == null ? null : _ef.GetElementType(returnParam.TypeUsage); + } + + public bool GenerateMergeOptionFunction(EdmFunction edmFunction, bool includeMergeOption) + { + var returnType = GetReturnType(edmFunction); + return !includeMergeOption && returnType != null && returnType.EdmType.BuiltInTypeKind == BuiltInTypeKind.EntityType; + } +} + +public static void ArgumentNotNull(T arg, string name) where T : class +{ + if (arg == null) + { + throw new ArgumentNullException(name); + } +} +#> \ No newline at end of file diff --git a/Models/SQL_Ti.Designer.cs b/Models/SQL_Ti.Designer.cs new file mode 100644 index 0000000..8c0b759 --- /dev/null +++ b/Models/SQL_Ti.Designer.cs @@ -0,0 +1,10 @@ +// 为模型“C:\Users\24018\source\repos\Audit_APP\Models\SQL_Ti.edmx”启用了 T4 代码生成。 +// 要启用旧代码生成功能,请将“代码生成策略”设计器属性的值 +// 更改为“旧的 ObjectContext”。当在设计器中打开该模型时,此属性会出现在 +// “属性”窗口中。 + +// 如果没有生成任何上下文和实体类,可能是因为您创建了空模型但是 +// 尚未选择要使用的实体框架版本。要为您的模型生成一个上下文类和实体 +// 类,请在设计器中打开该模型,右键单击设计器图面,然后 +// 选择“从数据库更新模型...”、“从模型生成数据库...”或“添加代码生成 +// 项...”。 \ No newline at end of file diff --git a/Models/SQL_Ti.cs b/Models/SQL_Ti.cs new file mode 100644 index 0000000..69c6b92 --- /dev/null +++ b/Models/SQL_Ti.cs @@ -0,0 +1,9 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + diff --git a/Models/SQL_Ti.edmx b/Models/SQL_Ti.edmx new file mode 100644 index 0000000..aac76cf --- /dev/null +++ b/Models/SQL_Ti.edmx @@ -0,0 +1,1103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + SELECT + [CHEMICAL_QUEUE].[tmp_field] AS [tmp_field], + [CHEMICAL_QUEUE].[ID_NO] AS [ID_NO], + [CHEMICAL_QUEUE].[STEP_NO] AS [STEP_NO], + [CHEMICAL_QUEUE].[CREATE_DATE] AS [CREATE_DATE], + [CHEMICAL_QUEUE].[CREATE_TIME] AS [CREATE_TIME], + [CHEMICAL_QUEUE].[FIRST_KEY] AS [FIRST_KEY], + [CHEMICAL_QUEUE].[SECOND_KEY] AS [SECOND_KEY], + [CHEMICAL_QUEUE].[PRIORITY] AS [PRIORITY], + [CHEMICAL_QUEUE].[ReDye] AS [ReDye] + FROM [dbo].[CHEMICAL_QUEUE] AS [CHEMICAL_QUEUE] + + + SELECT + [DYESTUFF_QUEUE].[tmp_field] AS [tmp_field], + [DYESTUFF_QUEUE].[ID_NO] AS [ID_NO], + [DYESTUFF_QUEUE].[STEP_NO] AS [STEP_NO], + [DYESTUFF_QUEUE].[CREATE_DATE] AS [CREATE_DATE], + [DYESTUFF_QUEUE].[CREATE_TIME] AS [CREATE_TIME], + [DYESTUFF_QUEUE].[FIRST_KEY] AS [FIRST_KEY], + [DYESTUFF_QUEUE].[SECOND_KEY] AS [SECOND_KEY], + [DYESTUFF_QUEUE].[PRIORITY] AS [PRIORITY], + [DYESTUFF_QUEUE].[ReDye] AS [ReDye] + FROM [dbo].[DYESTUFF_QUEUE] AS [DYESTUFF_QUEUE] + + + SELECT + [JOBTKT].[tmp_field] AS [tmp_field], + [JOBTKT].[IDNO] AS [IDNO], + [JOBTKT].[FNDATE] AS [FNDATE], + [JOBTKT].[FIRST_KEY] AS [FIRST_KEY], + [JOBTKT].[SECOND_KEY] AS [SECOND_KEY], + [JOBTKT].[ReDye] AS [ReDye] + FROM [dbo].[JOBTKT] AS [JOBTKT] + + + SELECT + [POWDER_QUEUE].[tmp_field] AS [tmp_field], + [POWDER_QUEUE].[ID_NO] AS [ID_NO], + [POWDER_QUEUE].[STEP_NO] AS [STEP_NO], + [POWDER_QUEUE].[CREATE_DATE] AS [CREATE_DATE], + [POWDER_QUEUE].[CREATE_TIME] AS [CREATE_TIME], + [POWDER_QUEUE].[FIRST_KEY] AS [FIRST_KEY], + [POWDER_QUEUE].[SECOND_KEY] AS [SECOND_KEY], + [POWDER_QUEUE].[PRIORITY] AS [PRIORITY], + [POWDER_QUEUE].[ReDye] AS [ReDye] + FROM [dbo].[POWDER_QUEUE] AS [POWDER_QUEUE] + + + SELECT + [REMOTETERMINAL].[tmp_field] AS [tmp_field], + [REMOTETERMINAL].[IDNO] AS [IDNO], + [REMOTETERMINAL].[FNDATE] AS [FNDATE], + [REMOTETERMINAL].[IDTYPE] AS [IDTYPE], + [REMOTETERMINAL].[FIRST_KEY] AS [FIRST_KEY], + [REMOTETERMINAL].[SECOND_KEY] AS [SECOND_KEY], + [REMOTETERMINAL].[ReDye] AS [ReDye] + FROM [dbo].[REMOTETERMINAL] AS [REMOTETERMINAL] + + + SELECT + [TEMPCHEMICALTKT].[tmp_field] AS [tmp_field], + [TEMPCHEMICALTKT].[IDNO] AS [IDNO], + [TEMPCHEMICALTKT].[FNDATE] AS [FNDATE], + [TEMPCHEMICALTKT].[IDTYPE] AS [IDTYPE], + [TEMPCHEMICALTKT].[FIRST_KEY] AS [FIRST_KEY], + [TEMPCHEMICALTKT].[SECOND_KEY] AS [SECOND_KEY], + [TEMPCHEMICALTKT].[ReDye] AS [ReDye] + FROM [dbo].[TEMPCHEMICALTKT] AS [TEMPCHEMICALTKT] + + + SELECT + [TEMPDYESTUFFTKT].[tmp_field] AS [tmp_field], + [TEMPDYESTUFFTKT].[IDNO] AS [IDNO], + [TEMPDYESTUFFTKT].[FNDATE] AS [FNDATE], + [TEMPDYESTUFFTKT].[IDTYPE] AS [IDTYPE], + [TEMPDYESTUFFTKT].[FIRST_KEY] AS [FIRST_KEY], + [TEMPDYESTUFFTKT].[SECOND_KEY] AS [SECOND_KEY], + [TEMPDYESTUFFTKT].[ReDye] AS [ReDye] + FROM [dbo].[TEMPDYESTUFFTKT] AS [TEMPDYESTUFFTKT] + + + SELECT + [TEMPPOWDER].[tmp_field] AS [tmp_field], + [TEMPPOWDER].[IDNO] AS [IDNO], + [TEMPPOWDER].[FNDATE] AS [FNDATE], + [TEMPPOWDER].[IDTYPE] AS [IDTYPE], + [TEMPPOWDER].[FIRST_KEY] AS [FIRST_KEY], + [TEMPPOWDER].[SECOND_KEY] AS [SECOND_KEY], + [TEMPPOWDER].[ReDye] AS [ReDye] + FROM [dbo].[TEMPPOWDER] AS [TEMPPOWDER] + + + SELECT + [TICKET_DETAIL].[ID_NO] AS [ID_NO], + [TICKET_DETAIL].[STEP_NO] AS [STEP_NO], + [TICKET_DETAIL].[PRODUCT_CODE] AS [PRODUCT_CODE], + [TICKET_DETAIL].[PRODUCT_TYPE] AS [PRODUCT_TYPE], + [TICKET_DETAIL].[TARGET_WT] AS [TARGET_WT], + [TICKET_DETAIL].[ACTUAL_WT] AS [ACTUAL_WT], + [TICKET_DETAIL].[UNIT] AS [UNIT], + [TICKET_DETAIL].[COMP_DATE] AS [COMP_DATE], + [TICKET_DETAIL].[COMP_TIME] AS [COMP_TIME], + [TICKET_DETAIL].[TRANSFER_STATE] AS [TRANSFER_STATE], + [TICKET_DETAIL].[ERROR_CODE] AS [ERROR_CODE], + [TICKET_DETAIL].[MACHINE] AS [MACHINE], + [TICKET_DETAIL].[TANK_NO] AS [TANK_NO], + [TICKET_DETAIL].[ID_TYPE] AS [ID_TYPE], + [TICKET_DETAIL].[PRODUCT_LOT] AS [PRODUCT_LOT], + [TICKET_DETAIL].[RECIPE_CODE] AS [RECIPE_CODE], + [TICKET_DETAIL].[LR] AS [LR], + [TICKET_DETAIL].[RECIPE_TYPE] AS [RECIPE_TYPE], + [TICKET_DETAIL].[CONC] AS [CONC], + [TICKET_DETAIL].[CONCUNIT] AS [CONCUNIT], + [TICKET_DETAIL].[REMARK] AS [REMARK], + [TICKET_DETAIL].[ADJUST] AS [ADJUST], + [TICKET_DETAIL].[PRICE] AS [PRICE], + [TICKET_DETAIL].[RES_DOUBLE1] AS [RES_DOUBLE1], + [TICKET_DETAIL].[RES_DOUBLE2] AS [RES_DOUBLE2], + [TICKET_DETAIL].[RES_DOUBLE3] AS [RES_DOUBLE3], + [TICKET_DETAIL].[RES_DOUBLE4] AS [RES_DOUBLE4], + [TICKET_DETAIL].[RES_STRING1] AS [RES_STRING1], + [TICKET_DETAIL].[RES_STRING2] AS [RES_STRING2], + [TICKET_DETAIL].[RES_STRING3] AS [RES_STRING3], + [TICKET_DETAIL].[RES_STRING4] AS [RES_STRING4], + [TICKET_DETAIL].[REWEIGHT] AS [REWEIGHT], + [TICKET_DETAIL].[Redye] AS [Redye], + [TICKET_DETAIL].[DyeWeightTime] AS [DyeWeightTime], + [TICKET_DETAIL].[UserAccount] AS [UserAccount], + [TICKET_DETAIL].[Batch_NO] AS [Batch_NO], + [TICKET_DETAIL].[lldmxid] AS [lldmxid], + [TICKET_DETAIL].[Station] AS [Station], + [TICKET_DETAIL].[UserCode] AS [UserCode], + [TICKET_DETAIL].[FABRIC_WEIGHT] AS [FABRIC_WEIGHT], + [TICKET_DETAIL].[VOLUME] AS [VOLUME], + [TICKET_DETAIL].[RECORD_ORDER] AS [RECORD_ORDER], + [TICKET_DETAIL].[Process] AS [Process], + [TICKET_DETAIL].[GRAVITY] AS [GRAVITY], + [TICKET_DETAIL].[CurrentStock] AS [CurrentStock] + FROM [dbo].[TICKET_DETAIL] AS [TICKET_DETAIL] + + + SELECT + [TicketSerial].[tmp_field] AS [tmp_field], + [TicketSerial].[ID_NO] AS [ID_NO], + [TicketSerial].[REDYE_NOW] AS [REDYE_NOW] + FROM [dbo].[TicketSerial] AS [TicketSerial] + + + SELECT + [UserAccount].[tmp_field] AS [tmp_field], + [UserAccount].[UserCode] AS [UserCode], + [UserAccount].[PassWord] AS [PassWord], + [UserAccount].[JobTicket] AS [JobTicket], + [UserAccount].[Report] AS [Report], + [UserAccount].[PathSetup] AS [PathSetup], + [UserAccount].[UserSetup] AS [UserSetup], + [UserAccount].[GROUP_CODE] AS [GROUP_CODE] + FROM [dbo].[UserAccount] AS [UserAccount] + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/Models/SQL_Ti.edmx.diagram b/Models/SQL_Ti.edmx.diagram new file mode 100644 index 0000000..36a64b6 --- /dev/null +++ b/Models/SQL_Ti.edmx.diagram @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/Models/SQL_Ti.tt b/Models/SQL_Ti.tt new file mode 100644 index 0000000..80ba056 --- /dev/null +++ b/Models/SQL_Ti.tt @@ -0,0 +1,733 @@ +<#@ template language="C#" debug="false" hostspecific="true"#> +<#@ include file="EF6.Utility.CS.ttinclude"#><#@ + output extension=".cs"#><# + +const string inputFile = @"SQL_Ti.edmx"; +var textTransform = DynamicTextTransformation.Create(this); +var code = new CodeGenerationTools(this); +var ef = new MetadataTools(this); +var typeMapper = new TypeMapper(code, ef, textTransform.Errors); +var fileManager = EntityFrameworkTemplateFileManager.Create(this); +var itemCollection = new EdmMetadataLoader(textTransform.Host, textTransform.Errors).CreateEdmItemCollection(inputFile); +var codeStringGenerator = new CodeStringGenerator(code, typeMapper, ef); + +if (!typeMapper.VerifyCaseInsensitiveTypeUniqueness(typeMapper.GetAllGlobalItems(itemCollection), inputFile)) +{ + return string.Empty; +} + +WriteHeader(codeStringGenerator, fileManager); + +foreach (var entity in typeMapper.GetItemsToGenerate(itemCollection)) +{ + fileManager.StartNewFile(entity.Name + ".cs"); + BeginNamespace(code); +#> +<#=codeStringGenerator.UsingDirectives(inHeader: false)#> +<#=codeStringGenerator.EntityClassOpening(entity)#> +{ +<# + var propertiesWithDefaultValues = typeMapper.GetPropertiesWithDefaultValues(entity); + var collectionNavigationProperties = typeMapper.GetCollectionNavigationProperties(entity); + var complexProperties = typeMapper.GetComplexProperties(entity); + + if (propertiesWithDefaultValues.Any() || collectionNavigationProperties.Any() || complexProperties.Any()) + { +#> + [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2214:DoNotCallOverridableMethodsInConstructors")] + public <#=code.Escape(entity)#>() + { +<# + foreach (var edmProperty in propertiesWithDefaultValues) + { +#> + this.<#=code.Escape(edmProperty)#> = <#=typeMapper.CreateLiteral(edmProperty.DefaultValue)#>; +<# + } + + foreach (var navigationProperty in collectionNavigationProperties) + { +#> + this.<#=code.Escape(navigationProperty)#> = new HashSet<<#=typeMapper.GetTypeName(navigationProperty.ToEndMember.GetEntityType())#>>(); +<# + } + + foreach (var complexProperty in complexProperties) + { +#> + this.<#=code.Escape(complexProperty)#> = new <#=typeMapper.GetTypeName(complexProperty.TypeUsage)#>(); +<# + } +#> + } + +<# + } + + var simpleProperties = typeMapper.GetSimpleProperties(entity); + if (simpleProperties.Any()) + { + foreach (var edmProperty in simpleProperties) + { +#> + <#=codeStringGenerator.Property(edmProperty)#> +<# + } + } + + if (complexProperties.Any()) + { +#> + +<# + foreach(var complexProperty in complexProperties) + { +#> + <#=codeStringGenerator.Property(complexProperty)#> +<# + } + } + + var navigationProperties = typeMapper.GetNavigationProperties(entity); + if (navigationProperties.Any()) + { +#> + +<# + foreach (var navigationProperty in navigationProperties) + { + if (navigationProperty.ToEndMember.RelationshipMultiplicity == RelationshipMultiplicity.Many) + { +#> + [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2227:CollectionPropertiesShouldBeReadOnly")] +<# + } +#> + <#=codeStringGenerator.NavigationProperty(navigationProperty)#> +<# + } + } +#> +} +<# + EndNamespace(code); +} + +foreach (var complex in typeMapper.GetItemsToGenerate(itemCollection)) +{ + fileManager.StartNewFile(complex.Name + ".cs"); + BeginNamespace(code); +#> +<#=codeStringGenerator.UsingDirectives(inHeader: false, includeCollections: false)#> +<#=Accessibility.ForType(complex)#> partial class <#=code.Escape(complex)#> +{ +<# + var complexProperties = typeMapper.GetComplexProperties(complex); + var propertiesWithDefaultValues = typeMapper.GetPropertiesWithDefaultValues(complex); + + if (propertiesWithDefaultValues.Any() || complexProperties.Any()) + { +#> + public <#=code.Escape(complex)#>() + { +<# + foreach (var edmProperty in propertiesWithDefaultValues) + { +#> + this.<#=code.Escape(edmProperty)#> = <#=typeMapper.CreateLiteral(edmProperty.DefaultValue)#>; +<# + } + + foreach (var complexProperty in complexProperties) + { +#> + this.<#=code.Escape(complexProperty)#> = new <#=typeMapper.GetTypeName(complexProperty.TypeUsage)#>(); +<# + } +#> + } + +<# + } + + var simpleProperties = typeMapper.GetSimpleProperties(complex); + if (simpleProperties.Any()) + { + foreach(var edmProperty in simpleProperties) + { +#> + <#=codeStringGenerator.Property(edmProperty)#> +<# + } + } + + if (complexProperties.Any()) + { +#> + +<# + foreach(var edmProperty in complexProperties) + { +#> + <#=codeStringGenerator.Property(edmProperty)#> +<# + } + } +#> +} +<# + EndNamespace(code); +} + +foreach (var enumType in typeMapper.GetEnumItemsToGenerate(itemCollection)) +{ + fileManager.StartNewFile(enumType.Name + ".cs"); + BeginNamespace(code); +#> +<#=codeStringGenerator.UsingDirectives(inHeader: false, includeCollections: false)#> +<# + if (typeMapper.EnumIsFlags(enumType)) + { +#> +[Flags] +<# + } +#> +<#=codeStringGenerator.EnumOpening(enumType)#> +{ +<# + var foundOne = false; + + foreach (MetadataItem member in typeMapper.GetEnumMembers(enumType)) + { + foundOne = true; +#> + <#=code.Escape(typeMapper.GetEnumMemberName(member))#> = <#=typeMapper.GetEnumMemberValue(member)#>, +<# + } + + if (foundOne) + { + this.GenerationEnvironment.Remove(this.GenerationEnvironment.Length - 3, 1); + } +#> +} +<# + EndNamespace(code); +} + +fileManager.Process(); + +#> +<#+ + +public void WriteHeader(CodeStringGenerator codeStringGenerator, EntityFrameworkTemplateFileManager fileManager) +{ + fileManager.StartHeader(); +#> +//------------------------------------------------------------------------------ +// +// <#=CodeGenerationTools.GetResourceString("Template_GeneratedCodeCommentLine1")#> +// +// <#=CodeGenerationTools.GetResourceString("Template_GeneratedCodeCommentLine2")#> +// <#=CodeGenerationTools.GetResourceString("Template_GeneratedCodeCommentLine3")#> +// +//------------------------------------------------------------------------------ +<#=codeStringGenerator.UsingDirectives(inHeader: true)#> +<#+ + fileManager.EndBlock(); +} + +public void BeginNamespace(CodeGenerationTools code) +{ + var codeNamespace = code.VsNamespaceSuggestion(); + if (!String.IsNullOrEmpty(codeNamespace)) + { +#> +namespace <#=code.EscapeNamespace(codeNamespace)#> +{ +<#+ + PushIndent(" "); + } +} + +public void EndNamespace(CodeGenerationTools code) +{ + if (!String.IsNullOrEmpty(code.VsNamespaceSuggestion())) + { + PopIndent(); +#> +} +<#+ + } +} + +public const string TemplateId = "CSharp_DbContext_Types_EF6"; + +public class CodeStringGenerator +{ + private readonly CodeGenerationTools _code; + private readonly TypeMapper _typeMapper; + private readonly MetadataTools _ef; + + public CodeStringGenerator(CodeGenerationTools code, TypeMapper typeMapper, MetadataTools ef) + { + ArgumentNotNull(code, "code"); + ArgumentNotNull(typeMapper, "typeMapper"); + ArgumentNotNull(ef, "ef"); + + _code = code; + _typeMapper = typeMapper; + _ef = ef; + } + + public string Property(EdmProperty edmProperty) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1} {2} {{ {3}get; {4}set; }}", + Accessibility.ForProperty(edmProperty), + _typeMapper.GetTypeName(edmProperty.TypeUsage), + _code.Escape(edmProperty), + _code.SpaceAfter(Accessibility.ForGetter(edmProperty)), + _code.SpaceAfter(Accessibility.ForSetter(edmProperty))); + } + + public string NavigationProperty(NavigationProperty navProp) + { + var endType = _typeMapper.GetTypeName(navProp.ToEndMember.GetEntityType()); + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1} {2} {{ {3}get; {4}set; }}", + AccessibilityAndVirtual(Accessibility.ForNavigationProperty(navProp)), + navProp.ToEndMember.RelationshipMultiplicity == RelationshipMultiplicity.Many ? ("ICollection<" + endType + ">") : endType, + _code.Escape(navProp), + _code.SpaceAfter(Accessibility.ForGetter(navProp)), + _code.SpaceAfter(Accessibility.ForSetter(navProp))); + } + + public string AccessibilityAndVirtual(string accessibility) + { + return accessibility + (accessibility != "private" ? " virtual" : ""); + } + + public string EntityClassOpening(EntityType entity) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1}partial class {2}{3}", + Accessibility.ForType(entity), + _code.SpaceAfter(_code.AbstractOption(entity)), + _code.Escape(entity), + _code.StringBefore(" : ", _typeMapper.GetTypeName(entity.BaseType))); + } + + public string EnumOpening(SimpleType enumType) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} enum {1} : {2}", + Accessibility.ForType(enumType), + _code.Escape(enumType), + _code.Escape(_typeMapper.UnderlyingClrType(enumType))); + } + + public void WriteFunctionParameters(EdmFunction edmFunction, Action writeParameter) + { + var parameters = FunctionImportParameter.Create(edmFunction.Parameters, _code, _ef); + foreach (var parameter in parameters.Where(p => p.NeedsLocalVariable)) + { + var isNotNull = parameter.IsNullableOfT ? parameter.FunctionParameterName + ".HasValue" : parameter.FunctionParameterName + " != null"; + var notNullInit = "new ObjectParameter(\"" + parameter.EsqlParameterName + "\", " + parameter.FunctionParameterName + ")"; + var nullInit = "new ObjectParameter(\"" + parameter.EsqlParameterName + "\", typeof(" + TypeMapper.FixNamespaces(parameter.RawClrTypeName) + "))"; + writeParameter(parameter.LocalVariableName, isNotNull, notNullInit, nullInit); + } + } + + public string ComposableFunctionMethod(EdmFunction edmFunction, string modelNamespace) + { + var parameters = _typeMapper.GetParameters(edmFunction); + + return string.Format( + CultureInfo.InvariantCulture, + "{0} IQueryable<{1}> {2}({3})", + AccessibilityAndVirtual(Accessibility.ForMethod(edmFunction)), + _typeMapper.GetTypeName(_typeMapper.GetReturnType(edmFunction), modelNamespace), + _code.Escape(edmFunction), + string.Join(", ", parameters.Select(p => TypeMapper.FixNamespaces(p.FunctionParameterType) + " " + p.FunctionParameterName).ToArray())); + } + + public string ComposableCreateQuery(EdmFunction edmFunction, string modelNamespace) + { + var parameters = _typeMapper.GetParameters(edmFunction); + + return string.Format( + CultureInfo.InvariantCulture, + "return ((IObjectContextAdapter)this).ObjectContext.CreateQuery<{0}>(\"[{1}].[{2}]({3})\"{4});", + _typeMapper.GetTypeName(_typeMapper.GetReturnType(edmFunction), modelNamespace), + edmFunction.NamespaceName, + edmFunction.Name, + string.Join(", ", parameters.Select(p => "@" + p.EsqlParameterName).ToArray()), + _code.StringBefore(", ", string.Join(", ", parameters.Select(p => p.ExecuteParameterName).ToArray()))); + } + + public string FunctionMethod(EdmFunction edmFunction, string modelNamespace, bool includeMergeOption) + { + var parameters = _typeMapper.GetParameters(edmFunction); + var returnType = _typeMapper.GetReturnType(edmFunction); + + var paramList = String.Join(", ", parameters.Select(p => TypeMapper.FixNamespaces(p.FunctionParameterType) + " " + p.FunctionParameterName).ToArray()); + if (includeMergeOption) + { + paramList = _code.StringAfter(paramList, ", ") + "MergeOption mergeOption"; + } + + return string.Format( + CultureInfo.InvariantCulture, + "{0} {1} {2}({3})", + AccessibilityAndVirtual(Accessibility.ForMethod(edmFunction)), + returnType == null ? "int" : "ObjectResult<" + _typeMapper.GetTypeName(returnType, modelNamespace) + ">", + _code.Escape(edmFunction), + paramList); + } + + public string ExecuteFunction(EdmFunction edmFunction, string modelNamespace, bool includeMergeOption) + { + var parameters = _typeMapper.GetParameters(edmFunction); + var returnType = _typeMapper.GetReturnType(edmFunction); + + var callParams = _code.StringBefore(", ", String.Join(", ", parameters.Select(p => p.ExecuteParameterName).ToArray())); + if (includeMergeOption) + { + callParams = ", mergeOption" + callParams; + } + + return string.Format( + CultureInfo.InvariantCulture, + "return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction{0}(\"{1}\"{2});", + returnType == null ? "" : "<" + _typeMapper.GetTypeName(returnType, modelNamespace) + ">", + edmFunction.Name, + callParams); + } + + public string DbSet(EntitySet entitySet) + { + return string.Format( + CultureInfo.InvariantCulture, + "{0} virtual DbSet<{1}> {2} {{ get; set; }}", + Accessibility.ForReadOnlyProperty(entitySet), + _typeMapper.GetTypeName(entitySet.ElementType), + _code.Escape(entitySet)); + } + + public string UsingDirectives(bool inHeader, bool includeCollections = true) + { + return inHeader == string.IsNullOrEmpty(_code.VsNamespaceSuggestion()) + ? string.Format( + CultureInfo.InvariantCulture, + "{0}using System;{1}" + + "{2}", + inHeader ? Environment.NewLine : "", + includeCollections ? (Environment.NewLine + "using System.Collections.Generic;") : "", + inHeader ? "" : Environment.NewLine) + : ""; + } +} + +public class TypeMapper +{ + private const string ExternalTypeNameAttributeName = @"http://schemas.microsoft.com/ado/2006/04/codegeneration:ExternalTypeName"; + + private readonly System.Collections.IList _errors; + private readonly CodeGenerationTools _code; + private readonly MetadataTools _ef; + + public TypeMapper(CodeGenerationTools code, MetadataTools ef, System.Collections.IList errors) + { + ArgumentNotNull(code, "code"); + ArgumentNotNull(ef, "ef"); + ArgumentNotNull(errors, "errors"); + + _code = code; + _ef = ef; + _errors = errors; + } + + public static string FixNamespaces(string typeName) + { + return typeName.Replace("System.Data.Spatial.", "System.Data.Entity.Spatial."); + } + + public string GetTypeName(TypeUsage typeUsage) + { + return typeUsage == null ? null : GetTypeName(typeUsage.EdmType, _ef.IsNullable(typeUsage), modelNamespace: null); + } + + public string GetTypeName(EdmType edmType) + { + return GetTypeName(edmType, isNullable: null, modelNamespace: null); + } + + public string GetTypeName(TypeUsage typeUsage, string modelNamespace) + { + return typeUsage == null ? null : GetTypeName(typeUsage.EdmType, _ef.IsNullable(typeUsage), modelNamespace); + } + + public string GetTypeName(EdmType edmType, string modelNamespace) + { + return GetTypeName(edmType, isNullable: null, modelNamespace: modelNamespace); + } + + public string GetTypeName(EdmType edmType, bool? isNullable, string modelNamespace) + { + if (edmType == null) + { + return null; + } + + var collectionType = edmType as CollectionType; + if (collectionType != null) + { + return String.Format(CultureInfo.InvariantCulture, "ICollection<{0}>", GetTypeName(collectionType.TypeUsage, modelNamespace)); + } + + var typeName = _code.Escape(edmType.MetadataProperties + .Where(p => p.Name == ExternalTypeNameAttributeName) + .Select(p => (string)p.Value) + .FirstOrDefault()) + ?? (modelNamespace != null && edmType.NamespaceName != modelNamespace ? + _code.CreateFullName(_code.EscapeNamespace(edmType.NamespaceName), _code.Escape(edmType)) : + _code.Escape(edmType)); + + if (edmType is StructuralType) + { + return typeName; + } + + if (edmType is SimpleType) + { + var clrType = UnderlyingClrType(edmType); + if (!IsEnumType(edmType)) + { + typeName = _code.Escape(clrType); + } + + typeName = FixNamespaces(typeName); + + return clrType.IsValueType && isNullable == true ? + String.Format(CultureInfo.InvariantCulture, "Nullable<{0}>", typeName) : + typeName; + } + + throw new ArgumentException("edmType"); + } + + public Type UnderlyingClrType(EdmType edmType) + { + ArgumentNotNull(edmType, "edmType"); + + var primitiveType = edmType as PrimitiveType; + if (primitiveType != null) + { + return primitiveType.ClrEquivalentType; + } + + if (IsEnumType(edmType)) + { + return GetEnumUnderlyingType(edmType).ClrEquivalentType; + } + + return typeof(object); + } + + public object GetEnumMemberValue(MetadataItem enumMember) + { + ArgumentNotNull(enumMember, "enumMember"); + + var valueProperty = enumMember.GetType().GetProperty("Value"); + return valueProperty == null ? null : valueProperty.GetValue(enumMember, null); + } + + public string GetEnumMemberName(MetadataItem enumMember) + { + ArgumentNotNull(enumMember, "enumMember"); + + var nameProperty = enumMember.GetType().GetProperty("Name"); + return nameProperty == null ? null : (string)nameProperty.GetValue(enumMember, null); + } + + public System.Collections.IEnumerable GetEnumMembers(EdmType enumType) + { + ArgumentNotNull(enumType, "enumType"); + + var membersProperty = enumType.GetType().GetProperty("Members"); + return membersProperty != null + ? (System.Collections.IEnumerable)membersProperty.GetValue(enumType, null) + : Enumerable.Empty(); + } + + public bool EnumIsFlags(EdmType enumType) + { + ArgumentNotNull(enumType, "enumType"); + + var isFlagsProperty = enumType.GetType().GetProperty("IsFlags"); + return isFlagsProperty != null && (bool)isFlagsProperty.GetValue(enumType, null); + } + + public bool IsEnumType(GlobalItem edmType) + { + ArgumentNotNull(edmType, "edmType"); + + return edmType.GetType().Name == "EnumType"; + } + + public PrimitiveType GetEnumUnderlyingType(EdmType enumType) + { + ArgumentNotNull(enumType, "enumType"); + + return (PrimitiveType)enumType.GetType().GetProperty("UnderlyingType").GetValue(enumType, null); + } + + public string CreateLiteral(object value) + { + if (value == null || value.GetType() != typeof(TimeSpan)) + { + return _code.CreateLiteral(value); + } + + return string.Format(CultureInfo.InvariantCulture, "new TimeSpan({0})", ((TimeSpan)value).Ticks); + } + + public bool VerifyCaseInsensitiveTypeUniqueness(IEnumerable types, string sourceFile) + { + ArgumentNotNull(types, "types"); + ArgumentNotNull(sourceFile, "sourceFile"); + + var hash = new HashSet(StringComparer.InvariantCultureIgnoreCase); + if (types.Any(item => !hash.Add(item))) + { + _errors.Add( + new CompilerError(sourceFile, -1, -1, "6023", + String.Format(CultureInfo.CurrentCulture, CodeGenerationTools.GetResourceString("Template_CaseInsensitiveTypeConflict")))); + return false; + } + return true; + } + + public IEnumerable GetEnumItemsToGenerate(IEnumerable itemCollection) + { + return GetItemsToGenerate(itemCollection) + .Where(e => IsEnumType(e)); + } + + public IEnumerable GetItemsToGenerate(IEnumerable itemCollection) where T: EdmType + { + return itemCollection + .OfType() + .Where(i => !i.MetadataProperties.Any(p => p.Name == ExternalTypeNameAttributeName)) + .OrderBy(i => i.Name); + } + + public IEnumerable GetAllGlobalItems(IEnumerable itemCollection) + { + return itemCollection + .Where(i => i is EntityType || i is ComplexType || i is EntityContainer || IsEnumType(i)) + .Select(g => GetGlobalItemName(g)); + } + + public string GetGlobalItemName(GlobalItem item) + { + if (item is EdmType) + { + return ((EdmType)item).Name; + } + else + { + return ((EntityContainer)item).Name; + } + } + + public IEnumerable GetSimpleProperties(EntityType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type); + } + + public IEnumerable GetSimpleProperties(ComplexType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type); + } + + public IEnumerable GetComplexProperties(EntityType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is ComplexType && p.DeclaringType == type); + } + + public IEnumerable GetComplexProperties(ComplexType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is ComplexType && p.DeclaringType == type); + } + + public IEnumerable GetPropertiesWithDefaultValues(EntityType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type && p.DefaultValue != null); + } + + public IEnumerable GetPropertiesWithDefaultValues(ComplexType type) + { + return type.Properties.Where(p => p.TypeUsage.EdmType is SimpleType && p.DeclaringType == type && p.DefaultValue != null); + } + + public IEnumerable GetNavigationProperties(EntityType type) + { + return type.NavigationProperties.Where(np => np.DeclaringType == type); + } + + public IEnumerable GetCollectionNavigationProperties(EntityType type) + { + return type.NavigationProperties.Where(np => np.DeclaringType == type && np.ToEndMember.RelationshipMultiplicity == RelationshipMultiplicity.Many); + } + + public FunctionParameter GetReturnParameter(EdmFunction edmFunction) + { + ArgumentNotNull(edmFunction, "edmFunction"); + + var returnParamsProperty = edmFunction.GetType().GetProperty("ReturnParameters"); + return returnParamsProperty == null + ? edmFunction.ReturnParameter + : ((IEnumerable)returnParamsProperty.GetValue(edmFunction, null)).FirstOrDefault(); + } + + public bool IsComposable(EdmFunction edmFunction) + { + ArgumentNotNull(edmFunction, "edmFunction"); + + var isComposableProperty = edmFunction.GetType().GetProperty("IsComposableAttribute"); + return isComposableProperty != null && (bool)isComposableProperty.GetValue(edmFunction, null); + } + + public IEnumerable GetParameters(EdmFunction edmFunction) + { + return FunctionImportParameter.Create(edmFunction.Parameters, _code, _ef); + } + + public TypeUsage GetReturnType(EdmFunction edmFunction) + { + var returnParam = GetReturnParameter(edmFunction); + return returnParam == null ? null : _ef.GetElementType(returnParam.TypeUsage); + } + + public bool GenerateMergeOptionFunction(EdmFunction edmFunction, bool includeMergeOption) + { + var returnType = GetReturnType(edmFunction); + return !includeMergeOption && returnType != null && returnType.EdmType.BuiltInTypeKind == BuiltInTypeKind.EntityType; + } +} + +public static void ArgumentNotNull(T arg, string name) where T : class +{ + if (arg == null) + { + throw new ArgumentNullException(name); + } +} +#> \ No newline at end of file diff --git a/Models/TEMPCHEMICALTKT.cs b/Models/TEMPCHEMICALTKT.cs new file mode 100644 index 0000000..f308681 --- /dev/null +++ b/Models/TEMPCHEMICALTKT.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class TEMPCHEMICALTKT + { + public string tmp_field { get; set; } + public string IDNO { get; set; } + public Nullable FNDATE { get; set; } + public string IDTYPE { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/TEMPDYESTUFFTKT.cs b/Models/TEMPDYESTUFFTKT.cs new file mode 100644 index 0000000..d2a42fd --- /dev/null +++ b/Models/TEMPDYESTUFFTKT.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class TEMPDYESTUFFTKT + { + public string tmp_field { get; set; } + public string IDNO { get; set; } + public Nullable FNDATE { get; set; } + public string IDTYPE { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/TEMPPOWDER.cs b/Models/TEMPPOWDER.cs new file mode 100644 index 0000000..71a6f80 --- /dev/null +++ b/Models/TEMPPOWDER.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class TEMPPOWDER + { + public string tmp_field { get; set; } + public string IDNO { get; set; } + public Nullable FNDATE { get; set; } + public string IDTYPE { get; set; } + public string FIRST_KEY { get; set; } + public string SECOND_KEY { get; set; } + public int ReDye { get; set; } + } +} diff --git a/Models/TICKET_DETAIL.cs b/Models/TICKET_DETAIL.cs new file mode 100644 index 0000000..9c466d9 --- /dev/null +++ b/Models/TICKET_DETAIL.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class TICKET_DETAIL + { + public string ID_NO { get; set; } + public Nullable STEP_NO { get; set; } + public string PRODUCT_CODE { get; set; } + public string PRODUCT_TYPE { get; set; } + public Nullable TARGET_WT { get; set; } + public Nullable ACTUAL_WT { get; set; } + public string UNIT { get; set; } + public string COMP_DATE { get; set; } + public string COMP_TIME { get; set; } + public Nullable TRANSFER_STATE { get; set; } + public string ERROR_CODE { get; set; } + public string MACHINE { get; set; } + public string TANK_NO { get; set; } + public string ID_TYPE { get; set; } + public string PRODUCT_LOT { get; set; } + public string RECIPE_CODE { get; set; } + public Nullable LR { get; set; } + public string RECIPE_TYPE { get; set; } + public string CONC { get; set; } + public string CONCUNIT { get; set; } + public string REMARK { get; set; } + public string ADJUST { get; set; } + public Nullable PRICE { get; set; } + public Nullable RES_DOUBLE1 { get; set; } + public Nullable RES_DOUBLE2 { get; set; } + public Nullable RES_DOUBLE3 { get; set; } + public Nullable RES_DOUBLE4 { get; set; } + public string RES_STRING1 { get; set; } + public string RES_STRING2 { get; set; } + public string RES_STRING3 { get; set; } + public string RES_STRING4 { get; set; } + public string REWEIGHT { get; set; } + public Nullable Redye { get; set; } + public Nullable DyeWeightTime { get; set; } + public string UserAccount { get; set; } + public string Batch_NO { get; set; } + public Nullable lldmxid { get; set; } + public string Station { get; set; } + public string UserCode { get; set; } + public Nullable FABRIC_WEIGHT { get; set; } + public Nullable VOLUME { get; set; } + public Nullable RECORD_ORDER { get; set; } + public string Process { get; set; } + public double GRAVITY { get; set; } + public Nullable CurrentStock { get; set; } + } +} diff --git a/Models/TicketSerial.cs b/Models/TicketSerial.cs new file mode 100644 index 0000000..e902611 --- /dev/null +++ b/Models/TicketSerial.cs @@ -0,0 +1,21 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class TicketSerial + { + public string tmp_field { get; set; } + public string ID_NO { get; set; } + public int REDYE_NOW { get; set; } + } +} diff --git a/Models/UserAccount.cs b/Models/UserAccount.cs new file mode 100644 index 0000000..2c2a01d --- /dev/null +++ b/Models/UserAccount.cs @@ -0,0 +1,26 @@ +//------------------------------------------------------------------------------ +// +// 此代码已从模板生成。 +// +// 手动更改此文件可能导致应用程序出现意外的行为。 +// 如果重新生成代码,将覆盖对此文件的手动更改。 +// +//------------------------------------------------------------------------------ + +namespace Models +{ + using System; + using System.Collections.Generic; + + public partial class UserAccount + { + public string tmp_field { get; set; } + public string UserCode { get; set; } + public string PassWord { get; set; } + public Nullable JobTicket { get; set; } + public Nullable Report { get; set; } + public Nullable PathSetup { get; set; } + public Nullable UserSetup { get; set; } + public string GROUP_CODE { get; set; } + } +}