Précédent   Forum des professionnels en informatique > Bases de données > Firebird > SQL
SQL Forum d'entraide sur le SQL pour Firebird
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 31/10/2011, 15h49   #1
Nouveau Membre du Club
 
Inscription : mars 2003
Messages : 203
Détails du profil
Informations forums :
Inscription : mars 2003
Messages : 203
Points : 38
Points : 38
Par défaut erreur après le lancement de fbdataadapter.update

Bonjour,
Je voulais insérer des données d'une datatable dans une table firebird. Pour cela, j'ai crée ma requete sql
Code :
INSERT INTO training (OBSERVATION,pls_01_var_0001,pls_01_var_0002,pls_01_var_0003,pls_01_var_0004,pls_01_var_0005,pls_01_var_0006,pls_01_var_0007,pls_01_var_0008,pls_01_var_0009,pls_01_var_0029,pls_01_var_0010,pls_01_var_0011,pls_01_var_0012,pls_01_var_0013,pls_01_var_0014,pls_01_var_0015,pls_01_var_0016,pls_01_var_0017,pls_01_var_0018,pls_01_var_0019,pls_01_var_0020,pls_01_var_0021,pls_01_var_0022,pls_01_var_0023,pls_01_var_0024,pls_01_var_0025,pls_01_var_0026,pls_01_var_0027,pls_01_var_0028,MODELNAME) VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)
et définit les paramètres nécessaires par exemple
Code :
 command.Parameters.ADD(@"OBSERVATION",FbDbType.TimeStamp,8,"OBSERVATION");
Ensuite, j'utilise les fonctions de fbDataAdapter insertCommand et Update
Code :
1
2
3
dap = new FbDataAdapter();
            dap.InsertCommand = command;
            dap.UPDATE(schema);
j'obtiens un message d'erreur
Citation:
'dataType' argument cannot be null.Parameter name: dataType
Pourtant je n'ai pas de données vides
pbatty1 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/11/2011, 22h34   #2
Membre Expert
 
Avatar de edam
 
Inscription : décembre 2003
Messages : 1 716
Détails du profil
Informations forums :
Inscription : décembre 2003
Messages : 1 716
Points : 1 783
Points : 1 783
normalement les parame s'utilise de cette aniére:
Citation:
INSERT INTO training (OBSERVATION,pls_01_var_0001,pls_01_var_0002) VALUES (:OBSERVATION,:pls_01_var_0001,:pls_01_var_0002)
...
parambyname('OBSERVATION').asstring:='une valeur';
....

j'utilise pas les FBDataset, mais c'est à peut prés ce que je fais
__________________
PAS DE DESTIN, C'EST CE QUE NOUS FAISONS
edam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/12/2011, 20h03   #3
Invité de passage
 
Homme Norbert Saint Georges
Consultant fonctionnel
Inscription : décembre 2011
Messages : 2
Détails du profil
Informations personnelles :
Nom : Homme Norbert Saint Georges
Localisation : Belgique

Informations professionnelles :
Activité : Consultant fonctionnel
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : décembre 2011
Messages : 2
Points : 3
Points : 3
Citation:
Envoyé par pbatty1 Voir le message
Bonjour,
Je voulais insérer des données d'une datatable dans une table firebird. Pour cela, j'ai crée ma requete sql
Code :
INSERT INTO training (OBSERVATION,pls_01_var_0001,pls_01_var_0002,pls_01_var_0003,pls_01_var_0004,pls_01_var_0005,pls_01_var_0006,pls_01_var_0007,pls_01_var_0008,pls_01_var_0009,pls_01_var_0029,pls_01_var_0010,pls_01_var_0011,pls_01_var_0012,pls_01_var_0013,pls_01_var_0014,pls_01_var_0015,pls_01_var_0016,pls_01_var_0017,pls_01_var_0018,pls_01_var_0019,pls_01_var_0020,pls_01_var_0021,pls_01_var_0022,pls_01_var_0023,pls_01_var_0024,pls_01_var_0025,pls_01_var_0026,pls_01_var_0027,pls_01_var_0028,MODELNAME) VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)
et définit les paramètres nécessaires par exemple
Code :
 command.Parameters.ADD(@"OBSERVATION",FbDbType.TimeStamp,8,"OBSERVATION");
Ensuite, j'utilise les fonctions de fbDataAdapter insertCommand et Update
Code :
1
2
3
dap = new FbDataAdapter();
            dap.InsertCommand = command;
            dap.UPDATE(schema);
j'obtiens un message d'erreur
Pourtant je n'ai pas de données vides
Code :
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
 
 StringBuilder sqlCommand = new StringBuilder();
            sqlCommand.Append("INSERT INTO training (OBSERVATION,pls_01_var_0001,pls_01_var_0002,pls_01_var_0003,pls_01_var_0004,pls_01_var_0005,pls_01_var_0006,pls_01_var_0007,pls_01_var_0008,pls_01_var_0009,pls_01_var_0029,pls_01_var_0010,pls_01_var_0011,pls_01_var_0012,pls_01_var_0013,pls_01_var_0014,pls_01_var_0015,pls_01_var_0016,pls_01_var_0017,pls_01_var_0018,pls_01_var_0019,pls_01_var_0020,pls_01_var_0021,pls_01_var_0022,pls_01_var_0023,pls_01_var_0024,pls_01_var_0025,pls_01_var_0026,pls_01_var_0027,pls_01_var_0028,MODELNAME) VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)");
 
            FbParameter[] arParams = new FbParameter[? nombre de param];
 
            arParams[0] = new FbParameter("@Observation", FbDbType.TimeStamp);
            arParams[0].Direction = ParameterDirection.Input;
            arParams[0].Value = OBSERVATION);
 
...
int rowsAffected = FBSqlHelper.ExecuteNonQuery(
                GetConnectionString(),
                sqlCommand.ToString(),
                arParams);
 
    public sealed class FBSqlHelper
    {
        private FBSqlHelper() { }
 
        private static readonly ILog log = LogManager.GetLogger(typeof(FBSqlHelper));
 
        public static String GetParamString(Int32 count)
        {
            IF (count <= 1) { RETURN count < 1 ? "" : "?"; }
            RETURN "?," + GetParamString(count - 1);
        }
 
        private static void PrepareCommand(
            FbCommand command,
            FbConnection connection,
            FbTransaction transaction,
            CommandType commandType,
            string commandText,
            FbParameter[] commandParameters)
        {
            IF (command == NULL) throw new ArgumentNullException("command");
            IF (commandText == NULL || commandText.Length == 0) throw new ArgumentNullException("commandText");
 
            command.Connection = connection;
            command.CommandText = commandText;
            command.CommandType = commandType;
 
            IF (transaction != NULL)
            {
                IF (transaction.Connection == NULL) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");
                command.Transaction = transaction;
            }
 
            IF (commandParameters != NULL)
            {
                AttachParameters(command, commandParameters);
            }
            RETURN;
        }
 
        private static void AttachParameters(FbCommand command, FbParameter[] commandParameters)
        {
            IF (command == NULL) throw new ArgumentNullException("command");
            IF (commandParameters != NULL)
            {
                foreach (FbParameter p IN commandParameters)
                {
                    IF (p != NULL)
                    {
                        IF ((p.Direction == ParameterDirection.InputOutput ||
                            p.Direction == ParameterDirection.Input) &&
                            (p.Value == NULL))
                        {
                            p.Value = DBNull.Value;
                        }
                        command.Parameters.ADD(p);
                    }
                }
            }
        }
 
        public static bool ExecuteBatchScript(
            string connectionString,
            string pathToScriptFile)
        {
            FbScript script = new FbScript(pathToScriptFile);
            IF (script.Parse() > 0)
            {
                USING (FbConnection connection = new FbConnection(connectionString))
                {
                    connection.Open();
                    try
                    {
                        FbBatchExecution batch = new FbBatchExecution(connection, script);
                        batch.Execute(true);
 
 
                    }
                    catch (FbException ex)
                    {
                        log.Error(ex);
                        throw new Exception(pathToScriptFile, ex);
                    }
                    finally
                    {
                        connection.Close();
                    }
 
 
                }
 
            }
 
            RETURN true;
 
        }
 
        public static int ExecuteNonQuery(string connectionString, string commandText, params FbParameter[] commandParameters)
        {
            RETURN ExecuteNonQuery(connectionString, CommandType.Text, commandText, commandParameters);
        }
 
        public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText, params FbParameter[] commandParameters)
        {
            IF (connectionString == NULL || connectionString.Length == 0) { throw new ArgumentNullException("connectionString"); }
 
            USING (FbConnection connection = new FbConnection(connectionString))
            {
                connection.Open();
                USING (FbTransaction transaction = connection.BeginTransaction())
                {
                    USING (FbCommand cmd = new FbCommand())
                    {
                        PrepareCommand(cmd, connection, transaction, commandType, commandText, commandParameters);
                        int rowsAffected = cmd.ExecuteNonQuery();
                        transaction.Commit();
                        RETURN rowsAffected;
                    }
                }
            }
        }
 
        public static int ExecuteNonQuery(FbTransaction transaction, CommandType commandType, string commandText, params FbParameter[] commandParameters)
        {
            IF (transaction == NULL) throw new ArgumentNullException("transaction");
 
            FbCommand cmd = new FbCommand();
            PrepareCommand(cmd, transaction.Connection, transaction, commandType, commandText, commandParameters);
            int retval = cmd.ExecuteNonQuery();
            RETURN retval;
        }
 
        public static FbDataReader ExecuteReader(string connectionString, string commandText, params FbParameter[] commandParameters)
        {
            RETURN ExecuteReader(connectionString, CommandType.Text, commandText, commandParameters);
        }
 
        public static FbDataReader ExecuteReader(string connectionString, CommandType commandType, string commandText, params FbParameter[] commandParameters)
        {
            IF (connectionString == NULL || connectionString.Length == 0) throw new ArgumentNullException("connectionString");
            FbConnection connection = NULL;
            try
            {
                connection = new FbConnection(connectionString);
                connection.Open();
 
                FbCommand command = new FbCommand();
 
                PrepareCommand(
                    command,
                    connection,
                    NULL,
                    commandType,
                    commandText,
                    commandParameters);
 
                RETURN command.ExecuteReader(CommandBehavior.CloseConnection);
 
            }
            catch
            {
                IF ((connection != NULL) && (connection.State == ConnectionState.Open)) { connection.Close(); }
                throw;
            }
        }
 
        public static object ExecuteScalar(string connectionString, string commandText, params FbParameter[] commandParameters)
        {
            RETURN ExecuteScalar(connectionString, CommandType.Text, commandText, commandParameters);
        }
 
        public static object ExecuteScalar(string connectionString, CommandType commandType, string commandText, params FbParameter[] commandParameters)
        {
            IF (connectionString == NULL || connectionString.Length == 0) throw new ArgumentNullException("connectionString");
 
            USING (FbConnection connection = new FbConnection(connectionString))
            {
                connection.Open();
                FbTransaction transaction = NULL;
                bool useTransaction = (commandText.Contains("EXECUTE") || commandText.Contains("INSERT"));
                IF (useTransaction) { transaction = connection.BeginTransaction(); }
 
                USING (FbCommand command = new FbCommand())
                {
                    PrepareCommand(command, connection, transaction, commandType, commandText, commandParameters);
                    object result = command.ExecuteScalar();
 
                    IF (transaction != NULL)
                    {
                        transaction.Commit();
                        transaction.Dispose();
                        transaction = NULL;
 
                    }
 
                    IF (connection.State == ConnectionState.Open)
                        connection.Close();
 
                    RETURN result;
 
                }
            }
        }
 
        public static DataSet ExecuteDataset(string connectionString, string commandText, params FbParameter[] commandParameters)
        {
            RETURN ExecuteDataset(connectionString, CommandType.Text, commandText, commandParameters);
        }
 
        public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText, params FbParameter[] commandParameters)
        {
            IF (connectionString == NULL || connectionString.Length == 0) throw new ArgumentNullException("connectionString");
 
            USING (FbConnection connection = new FbConnection(connectionString))
            {
                connection.Open();
                USING (FbCommand command = new FbCommand())
                {
                    PrepareCommand(command, connection, (FbTransaction)NULL, commandType, commandText, commandParameters);
 
                    USING (FbDataAdapter adapter = new FbDataAdapter(command))
                    {
                        DataSet dataSet = new DataSet();
                        adapter.Fill(dataSet);
                        RETURN dataSet;
                    }
                }
            }
        }
 
    }
Arcantar est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/12/2011, 08h42   #4
Modérateur
 
Avatar de SergioMaster
 
Serge Girard
Développeur informatique
Inscription : janvier 2007
Messages : 3 621
Détails du profil
Informations personnelles :
Nom : Serge Girard
Âge : 55
Localisation : France

Informations professionnelles :
Activité : Développeur informatique
Secteur : Industrie

Informations forums :
Inscription : janvier 2007
Messages : 3 621
Points : 4 526
Points : 4 526
@Arcantar Un peu d'explication de texte (ainsi que l'utilisation des balises de code pour amélioré la lecture) aurait été la bienvenue
__________________
La seule chose absolue dans un monde comme le nôtre, c'est l'humour. » Albert Einstein
J'entends et j'oublie. Je vois et je me souviens. Je fais et je comprends . Confucius
SergioMaster est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/12/2011, 17h59   #5
Invité de passage
 
Homme Norbert Saint Georges
Consultant fonctionnel
Inscription : décembre 2011
Messages : 2
Détails du profil
Informations personnelles :
Nom : Homme Norbert Saint Georges
Localisation : Belgique

Informations professionnelles :
Activité : Consultant fonctionnel
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : décembre 2011
Messages : 2
Points : 3
Points : 3
Citation:
Envoyé par SergioMaster Voir le message
@Arcantar Un peu d'explication de texte (ainsi que l'utilisation des balises de code pour amélioré la lecture) aurait été la bienvenue
Première utilisation de votre front-end et il est vrai que ma réponse est partie un peux vite :-)
je trouve la définition de vos balises ou ?
Arcantar est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 10h12.


 
 
 
 
Partenaires

Hébergement Web