Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-08-2007, 11:59   #1
voyager18
Member
 
Iscritto dal: Aug 2007
Messaggi: 138
[ASP.NET] Errore query sul server

Ciao ho scritto questo codice in C#. E' una semplicissima applicazione web in ASP.NET che aggiunge un record in un database Access utilizzando la query SQL INSERT INTO. Sul mio PC ho installato il server di sviluppo ASP.NET della Microsoft e l'applicazione con quello funziona ma quando da Visual Studio 2005 la pubblico sul server web, arrivato all'istruzione ExecuteNonQuery() il server mi restituisce questo errore: Operation must use an updateable query.

Ecco il codice che ho scritto:

Questo è il codice sorgente della pagina (Default.aspx.cs):

Codice:
using System;
using System.Data;
using System.Data.OleDb;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

namespace Forum
{
    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {

        }

        protected void Button1_Click(object sender, EventArgs e)
        {
            Forum.components.mbdataaccess Pippo = new Forum.components.mbdataaccess(Server.MapPath("MessageDb.mdb"));
            OleDbException ex;
            ex = Pippo.addMessage("'Pippo'", "'Provatr'", "'Provas'", "'lopo@poli'", "'9'");
            Label1.Text = ex.Message;
        }
    }
}
E quest'altro è il codice della classe 'mbdataaccess' contenuta nel namespace 'Forum.components' che ho scritto io:

Codice:
using System;
using System.Data;
using System.Data.OleDb;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

namespace Forum.components
{
    public class mbdataaccess
    {
        private string ServerPath;
        private string connection;

        public mbdataaccess(string ServerPath)
        {
            this.ServerPath = ServerPath;
            connection = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                         "Data Source=" + ServerPath + ";" +
                         "Persist Security Info=False";
        }

        public OleDbException addMessage(string MsName, string MsMessage, string MsSubject, string MsEmail, string GpID)
        {
            string ID = "11";
            string addMessage = "INSERT INTO Message " +
                                "(MsID, MsName, MsMessage, MsSubject, MsEmail, GpID, MsDate) " +
                                "VALUES (" + ID + ", " + MsName + ", " + MsMessage + ", " + MsSubject + ", " + MsEmail + ", " + GpID +", '777')";

            OleDbConnection connAddMess = new OleDbConnection(this.connection);
            OleDbCommand cmdAddMess = new OleDbCommand(addMessage, connAddMess);
            cmdAddMess.CommandType = CommandType.Text;
            connAddMess.Open();
            try
            {
                cmdAddMess.ExecuteNonQuery();
            }
            catch (OleDbException ex)
            {
                return ex;
            }
            connAddMess.Close();
            OleDbException e = null;
            return e;
        }
    }
}
Aiutatemi!!
voyager18 è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 12:25   #2
qwerty86
Senior Member
 
L'Avatar di qwerty86
 
Iscritto dal: Jun 2007
Messaggi: 1232
Quote:
Originariamente inviato da voyager18 Guarda i messaggi
Ciao ho scritto questo codice in C#. E' una semplicissima applicazione web in ASP.NET che aggiunge un record in un database Access utilizzando la query SQL INSERT INTO. Sul mio PC ho installato il server di sviluppo ASP.NET della Microsoft e l'applicazione con quello funziona ma quando da Visual Studio 2005 la pubblico sul server web, arrivato all'istruzione ExecuteNonQuery() il server mi restituisce questo errore: Operation must use an updateable query.

Ecco il codice che ho scritto:

Questo è il codice sorgente della pagina (Default.aspx.cs):

Codice:
using System;
using System.Data;
using System.Data.OleDb;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

namespace Forum
{
    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {

        }

        protected void Button1_Click(object sender, EventArgs e)
        {
            Forum.components.mbdataaccess Pippo = new Forum.components.mbdataaccess(Server.MapPath("MessageDb.mdb"));
            OleDbException ex;
            ex = Pippo.addMessage("'Pippo'", "'Provatr'", "'Provas'", "'lopo@poli'", "'9'");
            Label1.Text = ex.Message;
        }
    }
}
E quest'altro è il codice della classe 'mbdataaccess' contenuta nel namespace 'Forum.components' che ho scritto io:

Codice:
using System;
using System.Data;
using System.Data.OleDb;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

namespace Forum.components
{
    public class mbdataaccess
    {
        private string ServerPath;
        private string connection;

        public mbdataaccess(string ServerPath)
        {
            this.ServerPath = ServerPath;
            connection = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                         "Data Source=" + ServerPath + ";" +
                         "Persist Security Info=False";
        }

        public OleDbException addMessage(string MsName, string MsMessage, string MsSubject, string MsEmail, string GpID)
        {
            string ID = "11";
            string addMessage = "INSERT INTO Message " +
                                "(MsID, MsName, MsMessage, MsSubject, MsEmail, GpID, MsDate) " +
                                "VALUES (" + ID + ", " + MsName + ", " + MsMessage + ", " + MsSubject + ", " + MsEmail + ", " + GpID +", '777')";

            OleDbConnection connAddMess = new OleDbConnection(this.connection);
            OleDbCommand cmdAddMess = new OleDbCommand(addMessage, connAddMess);
            cmdAddMess.CommandType = CommandType.Text;
            connAddMess.Open();
            try
            {
                cmdAddMess.ExecuteNonQuery();
            }
            catch (OleDbException ex)
            {
                return ex;
            }
            connAddMess.Close();
            OleDbException e = null;
            return e;
        }
    }
}
Aiutatemi!!
cmdAddMess.ExecuteNonQuery(); al posto di ExecuteNonQuery(); c'è qualcosa che inizia per update?? se c'è prova quello
__________________
Cpu: Amd 64 X2 5200+ - Mobo:M2N32SLI DELUXE - Ram: Corsair xms2 800 mhz kit 4gb - SK Video: Gaiward GTS250 - Ali : Enermax Liberty 500 Wat - Mast DVD: 2 Nec AD-5170A - Case : Thermaltake Armor+ - Dissipatore: Thermaltake V1 Notebook: Sony Vaio VGN-Fe21M-Pda: Htc Diamond |Il mio sito|Flickr| Stanco del solito forum? Vieni a parlare di fotografia su Fotoni
qwerty86 è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 13:28   #3
voyager18
Member
 
Iscritto dal: Aug 2007
Messaggi: 138
come puoi vedere dal mio codice io ho scritto cmdAddMess.ExecuteNonQuery(); però mi da quell'errore.
voyager18 è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 13:33   #4
qwerty86
Senior Member
 
L'Avatar di qwerty86
 
Iscritto dal: Jun 2007
Messaggi: 1232
Quote:
Originariamente inviato da voyager18 Guarda i messaggi
come puoi vedere dal mio codice io ho scritto cmdAddMess.ExecuteNonQuery(); però mi da quell'errore.
non c'è qualcosa del tipo update?
__________________
Cpu: Amd 64 X2 5200+ - Mobo:M2N32SLI DELUXE - Ram: Corsair xms2 800 mhz kit 4gb - SK Video: Gaiward GTS250 - Ali : Enermax Liberty 500 Wat - Mast DVD: 2 Nec AD-5170A - Case : Thermaltake Armor+ - Dissipatore: Thermaltake V1 Notebook: Sony Vaio VGN-Fe21M-Pda: Htc Diamond |Il mio sito|Flickr| Stanco del solito forum? Vieni a parlare di fotografia su Fotoni
qwerty86 è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 13:35   #5
voyager18
Member
 
Iscritto dal: Aug 2007
Messaggi: 138
c'è cmdAddMess.UpdatedRowSource ma è una proprietà non un metodo!
voyager18 è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 14:06   #6
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
probabile problema di permessi.
controlla se l'utente "internet guest account" (o il gruppo everyone del quale fa parte) ha il permesso di scrittura sia sul file mdb che sulla cartella che lo contiene! in caso negativo assegnalo e riprova, in caso positivo boh, ne riparleremo

'iao
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 14:09   #7
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
ah, controlla anche che il file non sia in sola lettura!
ah 2, le eccezioni non si usano così!

'iao
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 14:16   #8
voyager18
Member
 
Iscritto dal: Aug 2007
Messaggi: 138
ho aggiunto il gruppo everyone e gli ho assegnato tutti i permessi per la scrittura e lettura del file. però ancora mi da quell'errore Operation must use an updateable query.

se vuoi vai sul direttamente sul sito e clicca sul bottone che contiene le operazioni di aggiunta del record così vedi direttamente il messaggio di errore che restituisce il server. l'indirizzo è questo:

http://www.hobbyelettronica.it
voyager18 è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 14:50   #9
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
hai controllato se il file è in sola lettura?
sei sicuro di non violare alcun vincolo referenziale con quella query?
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 15:02   #10
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
mi sa che ho cannato utente
l'utente corretto a cui assegnare i privilegi dovrebbe chiamarsi "ASPNET"
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2007, 08:27   #11
voyager18
Member
 
Iscritto dal: Aug 2007
Messaggi: 138
allora nessuno mi sa aiutare???
voyager18 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Guida all'acquisto dei prodotti BeatBot ...
Il fornitore di memoria che diventa soci...
Claude Tag: arriva l'agente AI di Anthro...
Prime Day intelligente: costa come un Ma...
Offerta internet casa: da Fastweb fibra ...
LineShine, la Cina torna in vetta ai sup...
Le schede video di AMD potrebbero aument...
I nuovi Redmi Note 17 sono vicini: l'aut...
Formula E svela la stagione dei record: ...
Premiate le miglior innovazioni nel supe...
Autopromotec Dialogues: a Milano abbiamo...
Google Pixel 10 Pro crolla a 699€ in off...
I primi computer quantistici utili a liv...
Washington punta il dito contro ASML: se...
Data center, IA e rinnovabili: cos&igrav...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 08:27.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v