2014-01-21 70 views
3

我想從Visual Studio 2012插件創建連接的查詢窗口。從Visual Studio 2012插件創建連接的查詢窗口

這是我使用的代碼:當你從Visual Studio 2012

scriptFactory.FileOpenMode manualy打開一個查詢窗口,

 UIConnectionInfo u = new UIConnectionInfo 
     { 
      ServerName = serverName, 
      ServerType = new Guid(serverType), 
      AuthenticationType = authType 
     }; 

     u.AdvancedOptions.Set("DATABASE", databaseName); 
     u.AdvancedOptions.Set("PACKET_SIZE", "4096"); 
     u.AdvancedOptions.Set("CONNECTION_TIMEOUT", "15"); 
     u.AdvancedOptions.Set("EXEC_TIMEOUT", "0"); 
     u.AdvancedOptions.Set("ENCRYPT_CONNECTION", "False"); 
     u.AdvancedOptions.Set("USE_CUSTOM_CONNECTION_COLOR", "False"); 
     u.AdvancedOptions.Set("CUSTOM_CONNECTION_COLOR", "-986896"); 

     u.ApplicationName = "Microsoft SQL Server Data Tools, T-SQL Editor"; 
     u.UserName = userName; 

     if(authType == 1) 
     { 
      u.Password = password; 
     } 

     ScriptFactory scriptFactory = ScriptFactory.Instance; 
     if(scriptFactory != null) 
     { 
      scriptFactory.CreateNewBlankScript(ScriptType.Sql, u, null); 
     } 

在UIConnectionInfo所有屬性都設置爲精確值被設置爲連接。

我甚至試圖通過打開和關閉連接到CreateNewBlankScript(這有助於Visual Studio 2010)的SQLConnection對象,但沒有結果。

在其他程序集中,我引用了SQLEditors.dll和SQLWorkbench.Interfaces,均爲11.0版本。

任何信息將非常有幫助。

謝謝。

回答

1

凡UIConnectionInfo和SqlConnection的是你的連接,並queryWindow當前打開的窗口中

private static void SetConnectionForQueryWindow(Window queryWindow, 
UIConnectionInfo uiConnectionInfo, SqlConnection conn) 
    { 
     object tempQueryWindow; 
     Dictionary<string, object> openedQueryWindows; 
     List<Window> temp = new List<Window> { queryWindow }; 

     openedQueryWindows = GetAllOpenedQueryWindows2012(temp); 
     openedQueryWindows.TryGetValue(queryWindow.Document.FullName, out tempQueryWindow); 

     if(tempQueryWindow == null) 
     { 
      return; 
     } 

     Assembly sqlEditor = Assembly.LoadFrom(tempQueryWindow.GetType().Assembly.Location); 
     var sqlScriptEditorControl = new SqlEditorTabbedEditorPane(sqlEditor); 
     var displaySqlResultsTabControl = new DisplaySqlResultsTabControl2012(tempQueryWindow, sqlScriptEditorControl); 

     try 
     { 
      var connectionStrategyField = 
       displaySqlResultsTabControl.QueryExecutorWrapper.QueryExec.GetType() 
        .GetField("_connectionStrategy", BindingFlags.Instance | BindingFlags.NonPublic); 
      var connectionStrategy = connectionStrategyField.GetValue(displaySqlResultsTabControl.QueryExecutorWrapper.QueryExec); 

      var connection = connectionStrategy.GetType() 
       .GetField("_connectionInfo", BindingFlags.Instance | BindingFlags.NonPublic); 
      connection.SetValue(connectionStrategy, uiConnectionInfo); 

      var setDbConn = connectionStrategy.GetType() 
       .GetMethod("SetDbConnection", BindingFlags.NonPublic | BindingFlags.Instance); 

      object[] parametersArray = { conn }; 
      setDbConn.Invoke(connectionStrategy, parametersArray); 

     } 
     catch(NullReferenceException nullReferenceException) 
     { 

     } 
    } 

internal static Dictionary<string, object> GetAllOpenedQueryWindows2012(List<Window> windows) 
    { 
     Dictionary<string, object> openedQuerySqlWindows = new Dictionary<string, object>(); 
     foreach(Window window in windows) 
     { 
      foreach(Window queryWindow in window.Document.ActiveWindow.Collection) 
      { 
       if(queryWindow.Object == null) 
       { 
        continue; 
       } 

       if(queryWindow.Object.ToString() 
        != "Microsoft.VisualStudio.Data.Tools.SqlEditor.UI.TabbedEditor.SqlEditorTabbedEditorPane") 
       { 
        continue; 
       } 

       object sqlEditorTabbedEditorPane = queryWindow.Object; 
       if(!openedQuerySqlWindows.ContainsKey(queryWindow.Document.FullName)) 
       { 
        openedQuerySqlWindows.Add(queryWindow.Document.FullName, sqlEditorTabbedEditorPane); 
       } 
      } 
     } 

     return openedQuerySqlWindows; 
    } 

其中

public class SqlEditorTabbedEditorPane 
{ 
    private readonly FieldInfo m_displaySqlResultsControl; 

    public SqlEditorTabbedEditorPane(Assembly sqlEditor) 
    { 
     Type sqlEditorTabbedEditorPane = 
      sqlEditor.GetType(
       "Microsoft.VisualStudio.Data.Tools.SqlEditor.UI.TabbedEditor.SqlEditorTabbedEditorPane"); 
     m_displaySqlResultsControl = sqlEditorTabbedEditorPane.GetField(
      "_resultsControl", 
      BindingFlags.NonPublic | BindingFlags.Instance); 
    } 

    public FieldInfo DisplaySqlResultsControl 
    { 
     get 
     { 
      return this.m_displaySqlResultsControl; 
     } 
    } 
} 

public class DisplaySqlResultsTabControl2012 
{ 
    private readonly object m_displaySqlResultsTabControl; 

    private readonly QueryExecutor m_queryExecutor; 

    public DisplaySqlResultsTabControl2012(
     object scriptEditor, 
     SqlEditorTabbedEditorPane sqlScriptEditorControl) 
    { 
     m_displaySqlResultsTabControl = sqlScriptEditorControl.DisplaySqlResultsControl.GetValue(scriptEditor); 
     m_queryExecutor = new QueryExecutor(m_displaySqlResultsTabControl);    
    } 

    public DisplaySqlResultsTabControl2012(object scriptEditor, SqlEditorTabbedEditorPane sqlScriptEditorControl) 
    { 
     m_displaySqlResultsTabControl = sqlScriptEditorControl.DisplaySqlResultsControl.GetValue(scriptEditor); 
     m_queryExecutor = new QueryExecutor(m_displaySqlResultsTabControl); 
    } 

    public object DisplaySqlResultsTabCtr 
    { 
     get 
     { 
      return m_displaySqlResultsTabControl; 
     } 
    } 

    public QueryExecutor QueryExecutorWrapper 
    { 
     get 
     { 
      return m_queryExecutor; 
     } 
    } 

    public class QueryExecutor 
    { 
     private readonly object m_queryExecutor; 

     public QueryExecutor(object displaySqlResultsTabControl) 
     { 
      FieldInfo queryExecutor = displaySqlResultsTabControl.GetType() 
       .GetField("_queryExecutor", BindingFlags.Instance | BindingFlags.NonPublic); 
      if(queryExecutor != null) 
      { 
       this.m_queryExecutor = queryExecutor.GetValue(displaySqlResultsTabControl); 
      } 
     } 

     public object QueryExec 
     { 
      get 
      { 
       return m_queryExecutor; 
      } 
     } 
    }   
} 
相關問題