问题:[microsoft][odbc microsoft access driver]标准表达式中数据类型不匹配
原因:Sql语句书写格式不标准
解决办法:
如: string sqlstr="select * from student where studentId>='" + Convert.ToInt32(this.textBox1.Text)+"'";
应改为:string sqlstr="select * from student where studentId>=" + Convert.ToInt32(this.textBox1.Text);
private void button1_Click(object sender, System.EventArgs e)
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
{
DataSet myDS;
myDS=new DataSet();
myDS=cgtdb.GetDataFromAccess(accessDbname,"admin","123","select * from student where studentId>=" + Convert.ToInt32(this.textBox1.Text),"student" );
if(myDS!=null)
data:image/s3,"s3://crabby-images/660db/660dbadd6c9ef03df5698a1947200796a88b70bb" alt=""
{
this.dataGrid1.DataSource =myDS.Tables[0];
MessageBox.Show(myDS.Tables[0].Rows[0][0].GetType().ToString() ) ;
}
}
Public Function DataTransition_ADODBCon() As ADODB.Connection
Dim conn As New ADODB.Connection()
Try
ReadIniFile()
conn.ConnectionString = "Provider=SQLOLEDB;Data Source='" & Trim(SqlServerName_Str_Pub) & " ';Initial Catalog='" & Trim(SqlInitDB_Str_Pub) & "';Integrated Security=SSPI;" & " ," & " '" & Trim(SqlUserName_Str_Pub) & "' " & " , " & " '" & Trim(SqlUserPassWord_Str_Pub) & "'" & ", " & " -1"
Catch
MsgBox(" MyOleConStr 错误号: " & Err.Number.ToString & " 错误描述 : " & Err.Description.ToString)
End Try
DataTransition_ADODBCon = conn
End Function
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Public Function SqlConStr() As String
Dim sqlconstring As String = ""
Try
ReadIniFile()
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
sqlconstring = "data source=" & Trim(SqlServerName_Str_Pub) & "; initial catalog=" & Trim(SqlInitDB_Str_Pub) & "; persist security info=true; user id=" & Trim(SqlUserName_Str_Pub) & "; Password=" & Trim(SqlUserPassWord_Str_Pub) & "; workstation id=" & Trim(SqlServerName_Str_Pub) & "; packet size=4096"
Catch
MsgBox("错误号: " & Err.Number.ToString & " 错误描述 : " & Err.Description.ToString)
End Try
Return sqlconstring
End Function
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Public Function SqlConStr2() As String
Dim sqlconstring As String = ""
Try
ReadIniFile()
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
sqlconstring = Trim(SqlServerName_Str_Pub) & "\" & Trim(SqlInitDB_Str_Pub) & "\" & Trim(SqlUserName_Str_Pub) & "\" & Trim(SqlUserPassWord_Str_Pub)
Catch
MsgBox("SqlConStr 错误号: " & Err.Number.ToString & " 错误描述 : " & Err.Description.ToString)
End Try
Return sqlconstring
End Function
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
'*************************************************************************************************************************************************'
'1.2.连接ACCESS数据库
'*************************************************************************************************************************************************'
Public Function Access_OleDBCon(ByVal DBPath As String) As OleDbConnection
Dim OleCon As OleDbConnection = New OleDbConnection()
'Dim DBPath As String = "d:\mrfu\DriverManager.mdb"
OleCon.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source='" & DBPath & "'"
Return OleCon
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Function
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
'*************************************************************************************************************************************************'
'对ACCESS数据库进行操作
'*************************************************************************************************************************************************'
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Public Function Access_ADODBConNeedPassword(ByVal DBPathAndDatabaseName As String, ByVal UserID As String, ByVal Password As String, ByVal SqlStr As String) As String
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Dim FlagStr As String = "0"
Dim ConnectionString As String = ""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
ConnectionString = "DRIVER={Microsoft Access Driver (*.mdb)};" & _
"DBQ=" & DBPathAndDatabaseName & ";DefaultDir=;" & _
"UID=" & UserID & ";" & _
"PWD=" & Password & ";"
Dim Adocon As ADODB.Connection
Try
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Adocon = New ADODB.Connection
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Adocon.ConnectionString = ConnectionString
Adocon.ConnectionTimeout = 120
Adocon.CommandTimeout = 160
Adocon.Open()
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Adocon.Execute(SqlStr)
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Adocon.Close()
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Adocon = Nothing
FlagStr = "1"
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Catch
If Adocon.State = ConnectionState.Open Then
Adocon.Close()
End If
FlagStr = "0"
MsgBox(Err.Description.ToString, MsgBoxStyle.Exclamation, "错误提示")
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Try
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Return FlagStr
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Function
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
'*************************************************************************************************************************************************'
'访问ACCESS数据库,并返回小批量数据
'*************************************************************************************************************************************************'
Public Function Access_GetDataReturnArrayList(ByVal DBPathAndDatabaseName As String, ByVal UserID As String, ByVal Password As String, ByVal SqlStr As String, ByVal TableName As String, ByVal FiledsName As String) As ArrayList
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Dim TempArrayList As ArrayList
TempArrayList = Nothing
Dim rs As ADODB.Recordset
Dim ConnectionString As String = ""
ConnectionString = "DRIVER={Microsoft Access Driver (*.mdb)};" & _
"DBQ=" & DBPathAndDatabaseName & ";DefaultDir=;" & _
"UID=" & UserID & ";" & _
"PWD=" & Password & ";"
Dim Adocon As ADODB.Connection
Try
Adocon = New ADODB.Connection
Adocon.ConnectionString = ConnectionString
Adocon.ConnectionTimeout = 120
Adocon.CommandTimeout = 160
Adocon.Open()
rs = New ADODB.Recordset
rs.Open(SqlStr, Adocon, ADODB.CursorTypeEnum.adOpenKeyset, ADODB.LockTypeEnum.adLockOptimistic, CInt(ADODB.CommandTypeEnum.adCmdText))
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
TempArrayList = New ArrayList
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
'如果记录集为空,输出一个错误信息
If (rs.BOF Or rs.EOF) Then
Adocon.Close()
Adocon = Nothing
rs = Nothing
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
MsgBox("没有找到任何记录,请检查你的" & TableName & " 表 ", MsgBoxStyle.Information, "系统消息")
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Return TempArrayList
End If
'循环存入数据
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
While (Not rs.EOF)
TempArrayList.Add(rs.Fields(FiledsName).Value.ToString())
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
rs.MoveNext()
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End While
Adocon.Close()
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Adocon = Nothing
rs = Nothing
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Catch
If Adocon.State = ConnectionState.Open Then
Adocon.Close()
End If
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
MsgBox(Err.Description.ToString, MsgBoxStyle.Exclamation, "错误提示")
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Try
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Return TempArrayList
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Function
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
'*************************************************************************************************************************************************'
'访问ACCESS数据库,并返回数据集
'*************************************************************************************************************************************************'
Public Function GetDataFromAccess(ByVal DBPathAndDatabaseName As String, ByVal UserID As String, ByVal Password As String, ByVal SqlStr As String, ByVal TableName As String) As DataSet
Dim custDA As OleDbDataAdapter = New OleDbDataAdapter
Dim custDS As DataSet = New DataSet
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Dim rs As ADODB.Recordset
Dim ConnectionString As String = ""
ConnectionString = "DRIVER={Microsoft Access Driver (*.mdb)};" & _
"DBQ=" & DBPathAndDatabaseName & ";DefaultDir=;" & _
"UID=" & UserID & ";" & _
"PWD=" & Password & ";"
Dim Adocon As ADODB.Connection
Try
Adocon = New ADODB.Connection
Adocon.ConnectionString = ConnectionString
Adocon.ConnectionTimeout = 120
Adocon.CommandTimeout = 160
Adocon.Open()
rs = New ADODB.Recordset
rs.Open(SqlStr, Adocon, ADODB.CursorTypeEnum.adOpenKeyset, ADODB.LockTypeEnum.adLockOptimistic, CInt(ADODB.CommandTypeEnum.adCmdText))
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
'如果记录集为空,输出一个错误信息
If (rs.BOF Or rs.EOF) Then
Adocon.Close()
Adocon = Nothing
rs = Nothing
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
MsgBox("没有找到任何记录,请检查你的" & TableName & " 表 ", MsgBoxStyle.Information, "系统消息")
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Return custDS
End If
'存入dataset数据
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
custDA.Fill(custDS, rs, "Customers")
Adocon.Close()
Adocon = Nothing
rs = Nothing
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Catch
If Adocon.State = ConnectionState.Open Then
Adocon.Close()
End If
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
MsgBox(Err.Description.ToString, MsgBoxStyle.Exclamation, "错误提示")
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Try
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Return custDS
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
End Function