2

似乎包含的 T4 模板(或 SVN 主干中的模板)只是跳过了为 MySQL 生成 SP...当与 MySQL.ttinclude 一起运行 StoredProcedures.ttinclude 时,我收到错误“编译转换:名称” GetSPs' 在当前上下文中不存在”。

GetSPs 是为 SQLServer 定义的,我看到有人为 Oracle 编写了自己的,但是有没有人知道正确的 GetSPs() 方法应该如何用于 MySQL?

就我个人而言,除非我可以运行自己的 SP,否则我认为它并不能真正发挥作用:/

4

3 回答 3

2

我对版本 2 中的代码进行了一些修改,并提出了一些对我有用的小代码(在所有情况下可能不是 100%)。将其放入 MySQL.ttinclude 以生成存储过程。享受!


string[] GetSPList()
{
    var result=new List();
    const string sql = "SELECT routine_name FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA = ?databaseName";
    StringBuilder sList = new StringBuilder();

    using(conn=new MySqlConnection(ConnectionString))
    {
        MySqlCommand cmd = new MySqlCommand(sql, conn);

        cmd.Parameters.AddWithValue("?databaseName", DatabaseName);
        conn.Open();
        using(IDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
        {
            bool isFirst = true;
            while(rdr.Read())
            {
                if(!isFirst)
                    sList.Append('|');
                isFirst = false;
                sList.Append(rdr[0]);
            }
            rdr.Close();
        }
    }
    return sList.ToString().Split(new char[] {'|'}, StringSplitOptions.RemoveEmptyEntries);
}

List GetSPParams(string spName)
{
    var result=new List();
    MySqlCommand cmd = new MySqlCommand();
    using(conn=new MySqlConnection(ConnectionString))
    {
        conn.Open();
        cmd.Connection = conn;
        cmd.CommandText = spName;
        cmd.CommandType = CommandType.StoredProcedure;

        try
        {
            MySqlCommandBuilder.DeriveParameters(cmd);
        }
        catch
        {
        }

        if(cmd.Parameters.Count > 0)
        {
            foreach(MySqlParameter param in cmd.Parameters)
            {
                SPParam p = new SPParam();
                p.SysType = GetSysType(param.MySqlDbType.ToString());
                p.DbType = param.DbType.ToString();
                p.Name = param.ParameterName;
                p.CleanName=CleanUp(p.Name);
                result.Add(p);
            }
        }
        conn.Close();
    }

    return result;
}

List GetSPs(){
    var result=new List();
    string[] spNames = GetSPList();

    foreach(string spName in spNames){
        var sp=new SP();
        sp.Name=spName;
        sp.CleanName=CleanUp(sp.Name);
        sp.Parameters=GetSPParams(sp.Name);
        result.Add(sp);        
    }

    return result;
}
于 2009-07-24T16:11:56.387 回答
1

我通过将它添加到我的 MySQL.ttinclude 来运行此代码,但是我必须将通用列表更改为类型列表。例如:List<SPParam>List<SP>。代码在那之后工作了;-)

于 2009-09-24T14:20:54.253 回答
0

根据克雷格的回答,我将列表更改为类型列表,并且我还需要var result=new List();GetSPList()代码块中删除。干杯

于 2011-02-21T12:36:41.363 回答