Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   

Die mobilen Seiten von c++.de:
http://m.c-plusplus.de
Infos hier [BETA]

  
c++.de :: C++/CLI mit .NET ::  CLR Sql Table Funktions     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
Dean
Unregistrierter




Beitrag Dean Unregistrierter 12:44:19 01.04.2012   Titel:   CLR Sql Table Funktions            Zitieren

Hallo,

bin gerade dabei mit die CLR Integration vom SQL Server mit der CLI anzuschauen, da Extendes SP dll´s mit Srv.h ab Sql 2012 nicht mehr unterstützt werden.

Mit Stored Procs funktioniert alles, allerdings bei Tabellenwertfunktionen gibt es einige Schwierigkeiten.

Von C# werden einige Dinge nicht von der CLI akzeptiert:

DataAccess=DataAccessKind.Read und IEnumerable als Rückgabewert.

Hat da jemand Erfahrungen?
Dean
Unregistrierter




Beitrag Dean Unregistrierter 12:46:25 01.04.2012   Titel:              Zitieren

C++/CLI:
1
2
3
4
5
6
7
8
9
10
namespace UTF_Querry_File_Typ {
 
    public ref class UTF_Querry_File_TypClass
    {
    public:
        //DataAccess = DataAccessKind.Read,
        [Microsoft::SqlServer::Server::SqlFunction(DataAccess = DataAccessKind.Read,FillRowMethodName = "FillDataRow",TableDefinition = "File_Typ_Id bigint, File_Typen nvarchar(10)")]
        static IEnumerable UTF_Querry_File_Typ();
    };
}
Dean
Unregistrierter




Beitrag Dean Unregistrierter 23:02:33 01.04.2012   Titel:              Zitieren

Problem ist gelöst, Tippfehler:

C++/CLI:
[Microsoft::SqlServer::Server::SqlFunction(DataAccess = DataAccessKind::Read,FillRowMethodName = "FillDataRow",TableDefinition = "File_Typ_Id bigint, File_Typen nvarchar(10)")]
        static System::Collections::IEnumerable^ UTF_Querry_File_Typ();


Ein Problem habe ich jetzt noch, der SQL Server erwartet in der FillRowMethodName ein System::Objekt, der eigentliche Typ darf nicht übergeben werden DataRow.

C++/CLI:
void UTF_Querry_File_Typ::UTF_Querry_File_TypClass::FillDataRow(Object obj, System::Int32 ^% File_Typ_Id , String ^% File_Typen)
{
   
    DataRow row= safe_cast<DataRow>(obj);
    File_Typ_Id = (System::Int32)row[0];
    File_Typen=row[1]->ToString();
}


im C# Beispiel wird es so gecastet:
C#:
DataRow row= (DataRow)obj;


Wie geht das in CLI ?
Dean
Unregistrierter




Beitrag Dean Unregistrierter 20:49:43 02.04.2012   Titel:   Erledigt            Zitieren

So lauter krims krams Fehler, lange nicht mit CLI gemacht.

Hier mal ein Beispiel für Tabellenwertfunktionen:

C++/CLI:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#pragma once
 
using namespace System;
using namespace System::Data;
using namespace System::Data::Sql;
using namespace System::Data::SqlClient;
using namespace System::Data::SqlTypes;
using namespace Microsoft::SqlServer::Server;
 
namespace UTF_Querry_File_Typ {
 
    public ref class UTF_Querry_File_TypClass
    {
    public:
        //DataAccess = DataAccessKind.Read,
        [Microsoft::SqlServer::Server::SqlFunction(DataAccess = DataAccessKind::Read,FillRowMethodName = "FillDataRow",TableDefinition = "File_Typ_Id bigint, File_Typen nvarchar(10)")]
        static System::Collections::IEnumerable^ UTF_Querry_File_Typ();
        static void FillDataRow(Object ^obj, SqlTypes::SqlInt64 % File_Typ_Id , SqlTypes::SqlString % File_Typen);
    };
}

C++/CLI:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include "stdafx.h"

#include "UTF_Querry_File_Typ.h"

 
using namespace UTF_Querry_File_Typ;
 
System::Collections::IEnumerable^ UTF_Querry_File_TypClass::UTF_Querry_File_Typ()
{  
       
   
        SqlConnection ^conn = gcnew SqlConnection("Context connection = true");
        String ^SqlString = "SELECT File_Typ_Id ,File_Typen FROM File_Typ";
        SqlDataAdapter ^da = gcnew SqlDataAdapter(SqlString,conn);
        DataTable ^tbl = gcnew DataTable();
        da->Fill(tbl);
       
        return tbl->Rows;
   
}
 
void UTF_Querry_File_Typ::UTF_Querry_File_TypClass::FillDataRow(Object  ^obj, SqlTypes::SqlInt64 % File_Typ_Id , SqlTypes::SqlString % File_Typen)
{
   
    DataRow ^row= (DataRow^)obj;
    File_Typ_Id = Convert::ToInt64(row[0]);
    File_Typen=  row[1]->ToString();
}


Mann kann auch über SQLPipe in einer SP mit execute and send eine Tabelle zurückgeben, in einer Funktion wird die Ausgabe aber gestreamt. Sobald eine row verfügbar ist wir sie gesendet reihe für reihe.

Bei dem Beispiel nicht so relevant aber bei großen und vor allem berechneten Tabellen ein großer Unterschied.
c++.de :: C++/CLI mit .NET ::  CLR Sql Table Funktions   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info und www.c-plusplus.net enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.