Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-03-2019, 15:11   #1
AndreB82
Junior Member
 
Iscritto dal: Mar 2019
Messaggi: 10
Visual Studio 2017 - Problema SELECT

Ciao a tutti,
sto realizzando un programmino in cui vorrei alimentare due tabelle. Nella prima ad ogni inserimento di un record in una Form si viene a creare un record. Nella seconda invece è necessario controllare l'esistenza di un preciso codice e poi o aggiornare il corrispondente record o altrimenti inserirne uno nuovo.

Ho iniziato a lavorare al codice, non ricevo alcun errore di debug, ma al momento di eseguire il record non viene mai aggiunto nella tabella, ma il codice salta direttamente al "Catch ex As Exception".

Vi riporto il codice di seguito. Qualcuno può aiutarmi?

Grazie,
Andrea

Codice:
Imports System.Data.OleDb
Public Class Form4
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Dim connString As String
        Dim ricerca As String
        Dim drGiocatore As OleDbDataReader
        Dim myConnection As OleDbConnection = New OleDbConnection

        'Connessione e trasmissione dati a DB
        connString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source = " & Application.StartupPath & "\DBGiocatori.accdb"
        myConnection.ConnectionString = connString
        myConnection.Open()
        Dim str As String
        str = "INSERT INTO [Tbl_Partite]([Nome_Giocatore],[Cognome_Giocatore],[Anno_di_nascita],[Luogo_di_nascita],[Codice_giocatore],[Statura],[Coordinazione],[Voto_Coordinazione],[Velocità],[Voto_Velocità], [Resistenza],[Voto_Resistenza], [Forza],[Voto_Forza]VALUES(@NGio,@CGio,@AnnoNasc,@LuogoNasc,@CodGio, @Stat,@Coord,@VCoord,@Vel,@VVel,@Res,@VRes,@For,@VFor)"
        ricerca = "SELECT [Codice_giocatore] FROM [Tbl_Giocatore] WHERE [Codice_giocatore] = @CodGio"
        Dim cmd As OleDbCommand = New OleDbCommand(str, myConnection)
        Dim objcomm As OleDbCommand = New OleDbCommand(ricerca, myConnection)
        cmd.Parameters.Add(New OleDbParameter("@NGio", CType(TextBox4.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@CGio", CType(TextBox5.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@AnnoNasc", CType(TextBox6.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@LuogoNasc", CType(TextBox7.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@CodGio", CType(TextBox57.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Stat", CType(TextBox16.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Coord", CType(TextBox17.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VCoord", CType(TextBox53.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Vel", CType(TextBox19.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VVel", CType(TextBox55.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Res", CType(TextBox18.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VRes", CType(TextBox54.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@For", CType(TextBox20.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VFor", CType(TextBox56.Text, String)))

        Try
            cmd.ExecuteNonQuery()
            MsgBox(TextBox5.Text & " - correttamente salvato")
            drGiocatore = objcomm.ExecuteReader()
            drGiocatore.Read()

            If drGiocatore.HasRows = True Then
                MsgBox("Trovato")
            ElseIf drGiocatore.HasRows = False Then
                MsgBox("Non trovato")
            End If

            myConnection.Close()

          
            TextBox16.Text = ""
            TextBox17.Text = ""
            TextBox18.Text = ""
            TextBox19.Text = ""
            TextBox20.Text = ""
            TextBox4.Text = ""
            TextBox5.Text = ""
            TextBox53.Text = ""
            TextBox54.Text = ""
            TextBox55.Text = ""
            TextBox56.Text = ""
            TextBox57.Text = ""
            TextBox6.Text = ""
            TextBox7.Text = ""

        Catch ex As Exception
            Dim nuovoCod As String
            nuovoCod = "INSERT INTO [Tbl_Partite]([Codice_Giocatore],[Nome_Giocatore],[Cognome_Giocatore]) VALUES (@CodGio,@NGio,@CGio)"
            MsgBox("Nuovo record inserito nella tabella Giocatori")
        End Try

        Form3.Show()

        Dim visible3 As Object = Form3.Visible

        If visible3 Then
            Me.Hide()
        End If

    End Sub
End Class
AndreB82 è offline   Rispondi citando il messaggio o parte di esso
Old 30-03-2019, 03:45   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Codice:
        str = "INSERT INTO [Tbl_Partite]([Nome_Giocatore],[Cognome_Giocatore],[Anno_di_nascita],[Luogo_di_nascita],[Codice_giocatore],[Statura],[Coordinazione],[Voto_Coordinazione],[Velocità],[Voto_Velocità], [Resistenza],[Voto_Resistenza], [Forza],[Voto_Forza]VALUES(@NGio,@CGio,@AnnoNasc,@LuogoNasc,@CodGio, @Stat,@Coord,@VCoord,@Vel,@VVel,@Res,@VRes,@For,@VFor)"
Non hai chiuso la parentesi tonda prima di VALUES
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 30-03-2019, 11:12   #3
AndreB82
Junior Member
 
Iscritto dal: Mar 2019
Messaggi: 10
Grazie mille sottovento.
Quel problema è un problema di copiatura del codice, in realtà su Visual Studio quel controllo funziona benissimo e il programma inserisce il nuovo record in quella tabella.

Il mio problema è la verifica se il parametro @CodGio esista già nell'altra tabella e nel caso esiste si faccia l'update dei valori, mentre nel caso non esiste il programma lo inserisca.

Probabilmente sbaglio la sequenza degli eventi. Potete aiutarmi?

Grazie,
A.
AndreB82 è offline   Rispondi citando il messaggio o parte di esso
Old 30-03-2019, 16:56   #4
CopyL3ft
Junior Member
 
Iscritto dal: Dec 2017
Messaggi: 1
Provando ad eseguire il codice, l'eccezione recita "Nessun valore specificato per alcuni parametri necessari".
Infatti controllando il codice, per il comando objcomm, che fa capo alla select "ricerca", non viene aggiunto il parametro.
Basta fare
Codice:
objcomm.Parameters.Add(New OleDbParameter("@CodGio", CType(TextBox57.Text, String)))
prima di eseguire il comando, e funziona.
CopyL3ft è offline   Rispondi citando il messaggio o parte di esso
Old 30-03-2019, 23:29   #5
AndreB82
Junior Member
 
Iscritto dal: Mar 2019
Messaggi: 10
Grazie mille CopyL3ft!
Funziona con le modifiche che riporto di seguito.

Ho però il seguente problema ora: eseguendo in debug il codice ogni volta mi va a sovrascrivere sia il record sulla tabella Partite che sulla tabella Giocatori.
Il programma è composto di una Form di inserimento dati (Form 3) e, al seguito della pressione sul tasto "Salva" di una Form (la 4) in cui viene eseguito proprio il codice sotto dopo che i dati sono stati copiati dalla Form 3. Preciso che non posso salvare direttamente dalla Form 3 perchè in questa importo i dati da file excel e i comandi
Codice:
Imports System.Data.OleDb
e
Codice:
Imports Microsoft.Office.Interop
mi danno errore se inseriti nella stessa Form.

Sapete dirmi come mai questo comportamento? E' normale dato che sono in modalità Debug?

Grazie,
A.

Codice:
Imports System.Data.OleDb
Public Class Form4
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Dim connString As String
        Dim ricerca As String
        Dim drGiocatore As OleDbDataReader
        Dim myConnection As OleDbConnection = New OleDbConnection

        'Connessione e trasmissione dati a DB
        connString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source = " & Application.StartupPath & "\DBGiocatori.accdb"
        myConnection.ConnectionString = connString
        myConnection.Open()
        Dim str As String
        str = "INSERT INTO [Tbl_Partite]([Nome_Giocatore],[Cognome_Giocatore],[Anno_di_nascita],[Luogo_di_nascita],[Codice_giocatore],[Statura],[Coordinazione],[Voto_Coordinazione],[Velocità],[Voto_Velocità], [Resistenza],[Voto_Resistenza], [Forza],[Voto_Forza]VALUES(@NGio,@CGio,@AnnoNasc,@LuogoNasc,@CodGio, @Stat,@Coord,@VCoord,@Vel,@VVel,@Res,@VRes,@For,@VFor)"
        ricerca = "SELECT [Codice_giocatore] FROM [Tbl_Giocatore] WHERE [Codice_giocatore] = @CodGio"
        Dim cmd As OleDbCommand = New OleDbCommand(str, myConnection)
        Dim objcomm As OleDbCommand = New OleDbCommand(ricerca, myConnection)
        cmd.Parameters.Add(New OleDbParameter("@NGio", CType(TextBox4.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@CGio", CType(TextBox5.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@AnnoNasc", CType(TextBox6.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@LuogoNasc", CType(TextBox7.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@CodGio", CType(TextBox57.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Stat", CType(TextBox16.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Coord", CType(TextBox17.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VCoord", CType(TextBox53.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Vel", CType(TextBox19.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VVel", CType(TextBox55.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@Res", CType(TextBox18.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VRes", CType(TextBox54.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@For", CType(TextBox20.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("@VFor", CType(TextBox56.Text, String)))
 objcomm.Parameters.Add(New OleDbParameter("@CodGio", CType(TextBox57.Text, String)))

        Try
            cmd.ExecuteNonQuery()
            MsgBox(TextBox5.Text & " - correttamente salvato")
            drGiocatore = objcomm.ExecuteReader()
            drGiocatore.Read()

            If drGiocatore.HasRows = True Then
                MsgBox("Trovato")
            ElseIf drGiocatore.HasRows = False Then
                nuovoCod = "INSERT INTO [Tbl_Giocatore]([Codice_Giocatore],[Nome_Giocatore],[Cognome_Giocatore]) VALUES (@CodGio,@NGio,@CGio)"
                Dim inscod As OleDbCommand = New OleDbCommand(nuovoCod, myConnection)
                inscod.Parameters.Add(New OleDbParameter("@CodGio", CType(TextBox57.Text, String)))
                inscod.Parameters.Add(New OleDbParameter("@NGio", CType(TextBox4.Text, String)))
                inscod.Parameters.Add(New OleDbParameter("@CGio", CType(TextBox5.Text, String)))
                inscod.ExecuteNonQuery()
                MsgBox("Nuovo record inserito nella tabella Giocatori")
            End If

            myConnection.Close()

          
            TextBox16.Text = ""
            TextBox17.Text = ""
            TextBox18.Text = ""
            TextBox19.Text = ""
            TextBox20.Text = ""
            TextBox4.Text = ""
            TextBox5.Text = ""
            TextBox53.Text = ""
            TextBox54.Text = ""
            TextBox55.Text = ""
            TextBox56.Text = ""
            TextBox57.Text = ""
            TextBox6.Text = ""
            TextBox7.Text = ""

        Catch ex As Exception
            MessageBox.Show(ex.Message + " " & Environment.NewLine & " " & ex.StackTrace)
        End Try

        Form3.Show()

        Dim visible3 As Object = Form3.Visible

        If visible3 Then
            Me.Hide()
        End If

    End Sub
End Class
AndreB82 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
TV TCL QLED da 65 pollici a 491€ su Amaz...
Windows 11, l'aggiornamento di aprile è ...
Niente iPhone 18 base nel 2026? Ecco la ...
Tinder introduce la scansione dell'iride...
Google sta per aggiungere luci colorate ...
PS6 potrebbe offrire prestazioni tre vol...
SK hynix ha avviato la produzione di mod...
Microsoft non ha pace sul Menu Start di ...
Cinque robot aspirapolvere e lavapavimen...
De'Longhi Tasciugo AriaDry: il deumidifi...
Robot più veloci dell'uomo: la me...
Palantir-manifesto, tra tecnologia e ide...
Classifica Amazon top 10 sconvolta: nuov...
DRAM, domanda fuori controllo: produzion...
HUDIMM e HSODIMM: la risposta dell'indus...
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: 10:21.


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