Artikel-ID: 310207 - Geändert am: Donnerstag, 29. November 2007 - Version: 3.3

Wie Sie ADO und der Exchange 2000 OLE DB-Provider, um Elemente in einem Ordner suchen, indem Visual c#

SystemtippDieser Artikel bezieht sich auf ein anderes Betriebssystem als das von Ihnen verwendete. Für Sie möglicherweise nicht relevante Artikelinhalte wurden deaktiviert.
Vorsicht ADO und ADO MD sind nicht vollständig in einer Microsoft .NET Framework-Umgebung getestet worden. Sie können zeitweise Probleme verursachen, insbesondere in Dienst-basierte Anwendungen oder Multithread-Anwendungen. Die Techniken, die in diesem Artikel behandelt werden sollte nur als vorübergehende Maßnahme während Migration zu ADO.NET verwendet werden. Sie sollten diese Techniken nur verwenden, nachdem Sie umfassende Tests sicherzustellen, dass keine Kompatibilitätsprobleme durchgeführt haben. Alle Probleme, die durch Verwendung von ADO oder ADO MD auf diese Weise werden nicht unterstützt. Weitere Informationen finden Sie unter den folgenden Artikel der Microsoft Knowledge Base:
840667   (http://support.microsoft.com/kb/840667/ ) Unerwartete Fehler angezeigt, wenn in einer .NET Framework-Anwendung ADO und ADO MD verwenden
Alles erweitern | Alles schließen

Zusammenfassung

Dieser Artikel beschreibt die ActiveX Data Objects (ADO) und den Microsoft Exchange 2000 Server OLE DB-Provider verwenden, um mithilfe von Microsoft Visual c# .NET oder Microsoft Visual c# 2005 für Elemente in einem Ordner zu suchen.

Weitere Informationen

  1. Starten Sie Microsoft Visual Studio .NET oder Microsoft Visual Studio 2005.
  2. Zeigen im Menü Datei auf neu , und klicken Sie dann auf Projekt .
  3. Klicken Sie in der Liste Visual C#-Projekttypen auf Konsolenanwendung . Die Datei Class1.cs wird standardmäßig erstellt.

    Hinweis: Klicken Sie in Microsoft Visual c# 2005 auf Visual c# . Standardmäßig ist die Datei Program.cs erstellt.
  4. Fügen Sie einen Verweis auf Microsoft ActiveX Data Objects 2.5 Library. Gehen Sie dazu folgendermaßen vor:
    1. Klicken Sie im Menü Projekt auf Verweis hinzufügen .
    2. Klicken Sie auf die Registerkarte COM , suchen Sie Microsoft ActiveX Data Objects 2.5 Library und klicken Sie dann auf auswählen .

      Hinweis: Microsoft Visual c# 2005 müssen Sie keinen auf auswählen klicken.
    3. Klicken Sie im Dialogfeld Verweis hinzufügen auf OK .
    4. Wenn Sie aufgefordert werden, ob für die Bibliotheken Wrapper erstellt, die Sie ausgewählt, klicken Sie auf Ja .
  5. Ersetzen Sie in das Codefenster den Code mit den folgenden: mithilfe von
    using System;
    
    namespace Samples
    {
    	class Class1
    	{
    		static void Main(string[] args)
    		{
    			try 
    			{
    			ADODB.Connection oCn = new ADODB.Connection();
    			ADODB.Recordset oRs = new ADODB.Recordset();
    			
    
    			ADODB.Fields oFields;
    			ADODB.Field oField;
    
                            // TODO: Replace with your folder's URL.
    			string sFdUrl = "http://ExchServer/Exchange/UserAlias/Inbox";
    			
    			oCn.Provider = "exoledb.datasource";
    			oCn.Open(sFdUrl, "", "", -1);  
    
    			if(oCn.State == 1)
    			{
    				Console.WriteLine("Good Connection");
    			}
    			else
    			{
    				Console.WriteLine("Bad Connection");
    			}
    
    
    			string strSql;
    			strSql = "";
    			strSql = "select ";
    			strSql = strSql + " \"urn:schemas:mailheader:content-class\"";
    			strSql = strSql + ", \"DAV:href\" ";
    			strSql = strSql + ", \"DAV:displayname\"";
    			strSql = strSql + " from scope ('shallow traversal of " + "\"";
    			strSql = strSql + sFdUrl + "\"') ";
    			strSql = strSql + " WHERE \"DAV:ishidden\" = false";
    			strSql = strSql + " AND \"DAV:isfolder\" = false";
    
    
    			oRs.Open(strSql, oCn,
    				ADODB.CursorTypeEnum.adOpenStatic,
    				ADODB.LockTypeEnum.adLockUnspecified, 1);
    
    
    			if(oRs.State == 1)
    			{
    				Console.WriteLine("Recordset Opened");
    			}
    			else
    			{
    				Console.WriteLine("Recordset Failed Opened");
    			}
    
    			oRs.MoveFirst();
    			while(!oRs.EOF)
    			{
    				oFields = oRs.Fields;
                                        oField = oFields["DAV:href"];
    				Console.WriteLine(oField.Value);
    
    				oField = oFields["DAV:displayname"];
    				Console.WriteLine(oField.Value);
    
    				oRs.MoveNext();  
    				                             Console.WriteLine("--------------------------");
    
    			}
    
    			oRs.Close();
    			oCn.Close();
    
    			oCn = null;
    			oRs = null;
    			oFields = null;
    			oField = null;
    			}
    			catch (Exception e)
    			{
    				Console.WriteLine("{0} Exception caught.", e);
    			}			
    		}
            }
    }
    					
  6. Die TODO-Textzeichenfolge im Code suchen Sie, und ändern Sie den Code für Ihre Umgebung.
  7. Drücken Sie F5, um erstellen und Ausführen des Programms.

Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft ActiveX Data Objects 2.5
  • Microsoft Exchange Server 2000 Service Pack 1
  • Microsoft Visual C# .NET 2003 Standard Edition
  • Microsoft Visual C# .NET 2002 Standard Edition
  • Microsoft Visual C# 2005
Keywords: 
kbmt kbhowto kbmsg kbxml kbcode KB310207 KbMtde
Maschinell übersetzter ArtikelMaschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 310207  (http://support.microsoft.com/kb/310207/en-us/ )
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.