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; }
+ }
+}