2

我有以下代码,它与花括号和其他东西有关。

<#@ template language="C#" debug="True" hostspecific="True" #>
<#@ output extension=".cs" #>
<#@ assembly name="System.Data" #>

<#@ assembly name="System.xml" #>
<#@ import namespace="System.Collections.Generic" #>
<#@ import namespace="System.Data.SqlClient" #>

namespace MyProject.Entities 
{   
    public class     
    {
        <#
        string connectionString = 
            "Server=localhost;Database=GridViewGuy;Trusted_Connection=true"; 
        SqlConnection conn = new SqlConnection(connectionString); 
        conn.Open(); 
        System.Data.DataTable schema = conn.GetSchema("TABLES"); 

        foreach(System.Data.DataRow row in schema.Rows) 
        { 

        #> 

        public class <#= row["TABLE_NAME"].ToString() #>            


        {

        }               

        } 

    }   

}

谁能发现问题?

4

2 回答 2

4

它不编译的原因是因为<# #>标签内的 foreach 块没有相应的右括号。您需要进行以下更改:

foreach(System.Data.DataRow row in schema.Rows)                 
{                 
#>                 
  public class <#= row["TABLE_NAME"].ToString()#> 
  {                
  } 
<#
  } //this was missing.
#> 

此外,请记住,您的代码将创建一个没有名称的类,然后是带有表名称的嵌套类列表。像这样:

public class
{
  public class Table1
  {
  }

  public class Table2
  {
  }
  //... and so on..
}

这可能不是您想要完成的。

于 2009-05-10T23:51:08.733 回答
2

在您的第一个块中,您启动一​​个代码块

            foreach(System.Data.DataRow row in schema.Rows) 
            { 

            #> 

但永远不要终止它。在下面的某个地方你需要这个:

            <# } #>

编辑- 看起来它将是嵌套类定义下方的右花括号

于 2009-05-10T23:47:00.830 回答