mysql - 我的 SQL 在不应该 O.o 的情况下转换为 Int

标签 mysql sql vb.net

好的,我在从程序更新 SQL 记录时收到以下错误:

An unhandled exception of type 'System.Data.SqlClient.SqlException' occurred in System.Data.dll

Additional information: Conversion failed when converting the nvarchar value 'Full Member' to data type int.

这是更新代码; (我已经标记了引用包含 TEXT 的文本框的两个点,但无缘无故地试图转换为 INT。

Public Class EditSelected
Dim con As SqlConnection
Dim stcon As String
Dim cmd As SqlCommand
Dim ds As DataSet
Dim da As SqlDataAdapter

.

Private Sub EditSelected_Load(sender As Object, e As EventArgs) Handles MyBase.Load    
stcon = "{Censored Connection String}"
        con = New SqlConnection(stcon)

        con.Open()


        cmd = New SqlCommand("UPDATE PersonsA SET Members_ID=@id, Gamer_Tag=@gt, " & _
        "Screenname=@screen, First_Name=@first, Last_Name=@last, DoB=@dob," & _
        "E_Mail_Address=@email, Position=@pos, U_G_Studio=@ustudio, Cautions=@caution," & _
        "Record=@record, Event_Attendance=@event, Member_Status=@memstatus, " & _ '<---ERROR HERE
        "GTA_V_Crew_Member=@gtva, Games_Owned=@gameowned, Rep_Group=@repgroup " & _
        "WHERE Members_ID=@id", con)

        cmd.Parameters.AddWithValue("@id", midtxt.Text)
        cmd.Parameters.AddWithValue("@gt", gttxt.Text)
        cmd.Parameters.AddWithValue("@screen", sntxt.Text)
        cmd.Parameters.AddWithValue("@first", fntxt.Text)
        cmd.Parameters.AddWithValue("@last", lntxt.Text)
        cmd.Parameters.AddWithValue("@dob", dobtxt.Text)
        cmd.Parameters.AddWithValue("@email", emailtxt.Text)
        cmd.Parameters.AddWithValue("@pos", teamptxt.Text)
        cmd.Parameters.AddWithValue("@ustudio", ugptxt.Text)
        cmd.Parameters.AddWithValue("@caution", ugctxt.Text)
        cmd.Parameters.AddWithValue("@record", recordtxt.Text)
        cmd.Parameters.AddWithValue("@event", eventatxt.Text)
        cmd.Parameters.AddWithValue("@memstatus", memberstatcombo.Text) '<---ERROR HERE
        cmd.Parameters.AddWithValue("@gtva", gtavcrewmembercombo.Text)
        cmd.Parameters.AddWithValue("@gameowned", gamesownedtxt.Text)
        cmd.Parameters.AddWithValue("@repgroup", RepGroupcombo.Text)
        cmd.ExecuteNonQuery()
        MsgBox("Data has been saved!")

        da = New SqlDataAdapter("SELECT * FROM PersonsA", con)
        ds = New DataSet
        da.Fill(ds, "PersonsA")

        LeadersAccessTable.DataGridView1.DataMember = "PersonsA"
        LeadersAccessTable.DataGridView1.DataSource = ds

        con.Close()

我的 SQL 列“Member_Status”的数据类型为 varchar(35) 并且可为空。

这是怎么回事;为什么它试图将其转换为整数?

{编辑1}

我提供了表列及其数据类型的屏幕截图 - 来自 SQL Management Studio 的屏幕截图。

Columns & File Names

最佳答案

糟糕,这取决于我的其他代码,它用所选索引的数据填充字段。事实证明,“正式成员”实际上并不在正确的文本框中,因此被发送到 INT 列之一。调试器应该更明显一点:/感谢您的帮助!

关于mysql - 我的 SQL 在不应该 O.o 的情况下转换为 Int,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21223091/

相关文章:

php - 如何检查所选日期是否在开始和结束之间?

php - 如何从两个没有任何连接的不同表中获取值

.net - String.Join 方法忽略空字符串?

mysql - 从mysql中的多个表中获取数据

mysql - 在一个事件调度程序中更新和删除

.net - 运行两个实例时自动增量不正确

.net - 如何根据传递给 VB.NET 泛型方法的类型执行条件逻辑

mysql - 跨 2 个表的 SUM IF 未反射(reflect)正确的数字

javascript - JQUERY onchange() 获取选定的选项并传递给要插入到 Mysql 数据库中的变量

mysql - 使用 mysql CONVERT_TZ 仅包含时间,而不包含日期