在 VB6 中从 ComboBox 保存数据的问题
Problem to save data from ComboBox in VB6
我有一个 ComboBox
但问题是当我尝试保存所选值时,因为我用 SQLServer
的值加载 ComboBox
并且应用程序显示我的下一个错误:
[Microsoft][ODBC SQL Server Driver][SQL Server]Invalid column name 'celular'.
我用 SQL
的值加载 ComboBox
:
Private Sub Form_Load()
Set rs = New Recordset
rs.CursorLocation = adUseServer
Call IniciarConexion
CargaIDTipoNumero
End Sub
Private Sub CargaIDTipoNumero()
cmbAddExample(indice).Clear
rs.Open "SELECT tipo FROM tipo_Numero", cnn, adOpenDynamic, adLockOptimistic
Do While rs.EOF = False
cmbAddExample(indice).AddItem rs!tipo
rs.MoveNext
Loop
rs.Close
End Sub
Private Sub IniciarConexion()
Set cnn = New ADODB.Connection
With cnn
.CursorLocation = adUseClient
.Open "PROVIDER=MSDASQL;driver={SQL Server};server=server;uid=uid;pwd=pwd;database=database;"
End With
End Sub
table 保存 ComboBox
值的地方:
CREATE TABLE ejTres(
combo int
)
table 我加载 ComboBox
:
CREATE TABLE tipo_Numero(
idTipo INT IDENTITY (1,1) NOT NULL,
tipo VARCHAR (10) NOT NULL,
CONSTRAINT pk_tipo PRIMARY KEY(idTipo)
)
INSERT INTO tipo_Numero(tipo)
VALUES('celular'), ('fijo')
以及我保存值的 Button
:
Private Sub btnGuardar_Click()
Dim i As Integer
Dim CM As ADODB.Command
Set CM = New ADODB.Command
Set CM.ActiveConnection = cnn
CM.CommandType = adCmdText
CM.CommandText = "INSERT INTO ejTres (combo) VALUES (?)"
CM.Parameters.Append CM.CreateParameter("@combo", adInteger, , , cmbAddExample(i))
CM.Execute , , adExecuteNoRecords
End Sub
只关注如何将 Identity 值放入您的 table 问题,尝试如下操作:
''as you load the combo, also save the identity value
Do While rs.EOF = False
cmbAddExample(indice).AddItem rs!tipo
cmbAddExample(indice).ItemData(cmbAddExample(indice).NewIndex) = rs!idTipo
rs.MoveNext
Loop
''now retrieve the identity value when creating the parameter
id = cmbAddExample(i).ItemData(cmbAddExample(i).ListIndex)
Set CM = New ADODB.Command
Set CM.ActiveConnection = cnn
CM.CommandType = adCmdText
CM.CommandText = "INSERT INTO ejTres (combo) VALUES (?)"
CM.Parameters.Append CM.CreateParameter("@combo", adInteger, , , id)
CM.Execute , , adExecuteNoRecords
我有一个 ComboBox
但问题是当我尝试保存所选值时,因为我用 SQLServer
的值加载 ComboBox
并且应用程序显示我的下一个错误:
[Microsoft][ODBC SQL Server Driver][SQL Server]Invalid column name 'celular'.
我用 SQL
的值加载 ComboBox
:
Private Sub Form_Load()
Set rs = New Recordset
rs.CursorLocation = adUseServer
Call IniciarConexion
CargaIDTipoNumero
End Sub
Private Sub CargaIDTipoNumero()
cmbAddExample(indice).Clear
rs.Open "SELECT tipo FROM tipo_Numero", cnn, adOpenDynamic, adLockOptimistic
Do While rs.EOF = False
cmbAddExample(indice).AddItem rs!tipo
rs.MoveNext
Loop
rs.Close
End Sub
Private Sub IniciarConexion()
Set cnn = New ADODB.Connection
With cnn
.CursorLocation = adUseClient
.Open "PROVIDER=MSDASQL;driver={SQL Server};server=server;uid=uid;pwd=pwd;database=database;"
End With
End Sub
table 保存 ComboBox
值的地方:
CREATE TABLE ejTres(
combo int
)
table 我加载 ComboBox
:
CREATE TABLE tipo_Numero(
idTipo INT IDENTITY (1,1) NOT NULL,
tipo VARCHAR (10) NOT NULL,
CONSTRAINT pk_tipo PRIMARY KEY(idTipo)
)
INSERT INTO tipo_Numero(tipo)
VALUES('celular'), ('fijo')
以及我保存值的 Button
:
Private Sub btnGuardar_Click()
Dim i As Integer
Dim CM As ADODB.Command
Set CM = New ADODB.Command
Set CM.ActiveConnection = cnn
CM.CommandType = adCmdText
CM.CommandText = "INSERT INTO ejTres (combo) VALUES (?)"
CM.Parameters.Append CM.CreateParameter("@combo", adInteger, , , cmbAddExample(i))
CM.Execute , , adExecuteNoRecords
End Sub
只关注如何将 Identity 值放入您的 table 问题,尝试如下操作:
''as you load the combo, also save the identity value
Do While rs.EOF = False
cmbAddExample(indice).AddItem rs!tipo
cmbAddExample(indice).ItemData(cmbAddExample(indice).NewIndex) = rs!idTipo
rs.MoveNext
Loop
''now retrieve the identity value when creating the parameter
id = cmbAddExample(i).ItemData(cmbAddExample(i).ListIndex)
Set CM = New ADODB.Command
Set CM.ActiveConnection = cnn
CM.CommandType = adCmdText
CM.CommandText = "INSERT INTO ejTres (combo) VALUES (?)"
CM.Parameters.Append CM.CreateParameter("@combo", adInteger, , , id)
CM.Execute , , adExecuteNoRecords