zoukankan      html  css  js  c++  java
  • 做自己的代码生成器

    代码生成器 顾名思义:自动生成代码,这儿我们主要指 生成数据库表的对应实体类代码。

    1 要生成具体表的实体类代码 我们首先需要知道 这个表有哪些字段 每个字段的类型

      通过下面的sql 语句 就可以得到 ‘youtablename’ 表的列名 类型 长度 等相关信息 循环便利的dataset 就可以得到 实体类的属性字段

    SELECT colorder=C.column_id,ColumnName=C.name,TypeName=T.name,
     Length=C.max_length, Preci=C.precision, Scale=C.scale,
     IsIdentity=CASE WHEN C.is_identity=1 THEN N'1'ELSE N'' END,
    isPK=ISNULL(IDX.PrimaryKey,N''),
    Computed=CASE WHEN C.is_computed=1 THEN N'1'ELSE N'' END,
     IndexName=ISNULL(IDX.IndexName,N''), IndexSort=ISNULL(IDX.Sort,N''),
     Create_Date=O.Create_Date, Modify_Date=O.Modify_date,
     cisNull=CASE WHEN C.is_nullable=1 THEN N'1'ELSE N'' END,
     defaultVal=ISNULL(D.definition,N''),
     deText=ISNULL(PFD.[value],N'')
     FROM sys.columns C INNER JOIN sys.objects O 
    ON C.[object_id]=O.[object_id] AND O.type='U' AND O.is_ms_shipped=0 INNER JOIN sys.types T 
    ON C.user_type_id=T.user_type_id LEFT JOIN sys.default_constraints D 
    ON C.[object_id]=D.parent_object_id 
    AND C.column_id=D.parent_column_id 
    AND C.default_object_id=D.[object_id] 
    LEFT JOIN sys.extended_properties PFD ON PFD.class=1 
    AND C.[object_id]=PFD.major_id AND C.column_id=PFD.minor_id 
    LEFT JOIN sys.extended_properties PTB ON PTB.class=1 AND PTB.minor_id=0 
    AND C.[object_id]=PTB.major_id LEFT JOIN 
    ( SELECT IDXC.[object_id], IDXC.column_id, Sort=CASE 
    INDEXKEY_PROPERTY(IDXC.[object_id],IDXC.index_id,IDXC.index_column_id,'IsDescending') 
    WHEN 1 THEN 'DESC' WHEN 0 THEN 'ASC' ELSE '' END, PrimaryKey=CASE WHEN IDX.is_primary_key=1 
    THEN N'1'ELSE N'' END, IndexName=IDX.Name FROM sys.indexes IDX INNER JOIN sys.index_columns IDXC 
    ON IDX.[object_id]=IDXC.[object_id] AND IDX.index_id=IDXC.index_id LEFT JOIN sys.key_constraints KC 
    ON IDX.[object_id]=KC.[parent_object_id] AND IDX.index_id=KC.unique_index_id INNER JOIN 
    ( SELECT [object_id], Column_id, index_id=MIN(index_id) FROM sys.index_columns 
    GROUP BY [object_id], Column_id ) IDXCUQ 
    ON IDXC.[object_id]=IDXCUQ.[object_id] AND 
    IDXC.Column_id=IDXCUQ.Column_id AND IDXC.index_id=IDXCUQ.index_id ) IDX 
    ON C.[object_id]=IDX.[object_id] AND C.column_id=IDX.column_id 
    WHERE O.name=N'youtablename' ORDER BY O.name,C.column_id
    View Code


    2 为了使生成的代码更方便 我们可以建立类似模版 来辅助生成代码

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace &namespace&
    {
        public class &classname&
        {
            #region Property
    
                &property&
    
            #endregion
    
            #region Functions
    
                &functions&
    
            #endregion
    
        }
    }
    View Code

      如上代码提供一个简单的代码模版

      生成之后的代码如下:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace TestInsert
    {
        public class GoodsTable
        {
            #region Property
    
            public string GoodsId { get; set; }
    
            public string GoodsName { get; set; }
    
            public decimal GoodsPrice { get; set; }
    
            public Int16 GoodsInventory { get; set; }
    
            #endregion
    
            #region Functions
    
            public void Insert(string goodsid, string goodsname, decimal goodsprice, Int16 goodsinventory)
            { 
                
            }
                
            #endregion
    
        }
    }
    View Code

    如上可以生成所有表的基本实体类

  • 相关阅读:
    第十六周个人作业
    排球比赛积分程序
    本周个人总结
    本周个人总结
    排球积分规则
    我与计算机
    排球计分(实践)
    观后感
    18周 个人作业
    总结
  • 原文地址:https://www.cnblogs.com/blueker-li/p/3172672.html
Copyright © 2011-2022 走看看