SQL连接问题 [英] Problem with SQL connection

查看:60
本文介绍了SQL连接问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

  Dim  ddi 作为 字符串 = 日期。今天
Dim Mycon As 字符串 =( C:\ Users \ Bruno Soares \Documents\Visual Studio 2012 \Projects \Projecto Castramento \Projecto Ca \Database1.sdf
Dim csvconnectionstring As String = My.Computer.FileSystem.CurrentDirectory& ; Database1.sdf

使用 cn 作为 SqlConnection(Mycon)
cn.Open()

使用 cmd 作为 SqlCommand( INSERT INTO Cliente(Nome,Endereço,Complemento,Número, Bairro,CEP,DDi,DDn,Sexo,Telefone,Celular,Email,Visitas)VALUES('& nome.Text& ','&endereço.Text& ', '& complemento.Text& ','& numero。文本& ','& bairro.Text& ',#& cep.Text& #,& ddi& & niver.Text& & sexo.SelectedItem& telefone.Text& celular.Text& email.Text& 0 & ,cn)

尝试
使用 cmd
.Connection = cn
.CommandType = CommandType.StoredProcedure
。 Parameters.Add( @ Nome,SqlDbType.Int, 4
。参数( @ Nome)。值= nome.Text
结束 使用


< span class =code-keyword> Catch ex As 例外

结束 尝试
cn.Close()
结束 使用
结束 使用





系统。 ArgumentException未处理
HResult = -2147024809
消息= O formato da cadeiadeinicializaçãonãosestádeacordo com aespecificaçãoiniciadanoíndice0。
Source = System.Data
StackTrace:
em System.Data.Common.DbConnectionOptions.GetKeyValuePair(String connectionString,Int32 currentPosition,StringBuilder buffer,Boolean useOdbcRules,String& keyname,String& keyvalue)
em System.Data.Common.DbConnectionOptions.ParseInternal(Hashtable parsetable,String connectionString,Boolean buildChain,Hashtable synonyms definitions,Boolean firstKey)
em System.Data.Common.DbConnectionOptions..ctor(String connectionString ,Hashtable的同义词,布尔值useOdbcRules)
em System.Data.SqlClient.SqlConnectionString..ctor(String connectionString)
em System.Data.SqlClient.SqlConnectionFactory.CreateConnectionOptions(String connectionString,DbConnectionOptions previous)
em System.Data.ProviderBase.DbConnectionFactory.GetConnectionPoolGroup(DbConnectionPoolKey key,DbConnectionPoolGroupOptions poolOptions,DbConnectionOptions& userConnectionOptions)
em System.Data.SqlClient.SqlConnection.ConnectionString_Set(DbConnectionPoolKey key)
em System.Data.SqlClient .SqlConnection.set_ConnectionString(String value)
em System.Data.SqlClient.SqlConnection..ctor(String connectionString,Sq lCredential credential)
em System.Data.SqlClient.SqlConnection..ctor(String connectionString)
em Projecto_cadastro_de_gente_fina.Cadastro.Button1_Click(Object sender,EventArgs e)na C:\ Users \ Bruno Soares \\ \\Documents\Visual Studio 2012 \Projects\Projecto Castramento \Projecto Castramento \ Cadastro.vb:linha 11
em System.Windows.Forms.Control.OnClick(EventArgs e)
em System .Windows.Forms.Button.OnClick(EventArgs e)
em System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
em System.Windows.Forms.Control.WmMouseUp(Message& m,MouseButtons按钮,Int32单击)
em System.Windows.Forms.Control.WndProc(Message& m)
em System.Windows.Forms.ButtonBase.WndProc(Message& m)
em System.Windows.Forms.Button.WndProc(Message& m)
em System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
em System.Windows.Forms.Control.ControlNativeWindow .WndProc(Message& m)
em System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd,Int32 msg,IntPtr wparam,IntPtr lparam)
em System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG& ; msg)
em System.Windows.Forms.Application.ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr dwComponentID,Int32 reason,Int32 pvLoopData)
em System.Windows.Forms。 Application.ThreadContext.RunMessageLoopInner(Int32 reason,ApplicationContext context)
em System.Windows.Forms.Application .ThreadContext.RunMessageLoop(Int32 reason,ApplicationContext context)
em System.Windows.Forms.Application.Run(ApplicationContext context)
em Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.OnRun()
em Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.DoApplicationModel()
em Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.Run(String [] commandLine)
em Projecto_cadastro_de_gente_fina.My.MyApplication.Main(String [] Args)na 17d14f5c-a337-4978-8281-53493378c1071.vb:linha 81
em System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly,String [] args)
em System.AppDomain.nExecuteAssembly(RuntimeAssembly assembly,String [] args)
em System.AppDomain.ExecuteAssembly(String assemblyFile,Evidence assemblySecurity,String [] args)
em Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
em System.Thread ing.ThreadHelper.ThreadStart_Context(Object state)
em System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext,ContextCallback callback,Object state,Boolean preserveSyncCtx)
em System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback回调,对象状态,Boolean preserveSyncCtx)
em System.Threading.ExecutionContext.Run(ExecutionContext executionContext,ContextCallback回调,对象状态)
em System.Threading.ThreadHelper.ThreadStart()
InnerException :



你好!

上面列出的代码导致异常处理

解决方案

< blockquote> 如何使用VBNet将数据插入SQL Server [ ^ ]



更新:



好​​的,.sdf文件是一个SQL Compact数据库,你需要使用'SqlCeConnection'类来连接。



来自MSDN的例子:

  Dim  conn  As  SqlCeConnection =  Nothing  

尝试
conn = SqlCeConnection( Data Source = MyDatabase.sdf;密码='< pwd>'
conn.Open()

Dim cmd As SqlCeCommand = conn.CreateCommand()
cmd.CommandText = 插入客户([客户ID],[公司名称])值('NWIND','Northwind Traders')

cmd.ExecuteNonQuery()
< span class =code-keyword>最后
conn.Close()
结束 尝试


Dim ddi As String = Date.Today
       Dim Mycon As String = ("C:\Users\Bruno Soares\Documents\Visual Studio 2012\Projects\Projecto Castramento\Projecto Ca\Database1.sdf")
       Dim csvconnectionstring As String = My.Computer.FileSystem.CurrentDirectory & "Database1.sdf"

       Using cn As New SqlConnection(Mycon)
           cn.Open()

           Using cmd As New SqlCommand("INSERT INTO Cliente(Nome, Endereço, Complemento, Número, Bairro, CEP, DDi, DDn, Sexo, Telefone, Celular, Email, Visitas) VALUES('" & nome.Text & "','" & endereço.Text & "','" & complemento.Text & "','" & numero.Text & "','" & bairro.Text & "', #" & cep.Text & "#, " & ddi & "," & niver.Text & "," & sexo.SelectedItem & telefone.Text & celular.Text & email.Text & 0 & ")", cn)

               Try
                   With cmd
                       .Connection = cn
                       .CommandType = CommandType.StoredProcedure
                       .Parameters.Add("@Nome", SqlDbType.Int, 4)
                       .Parameters("@Nome").Value = nome.Text
                   End With


               Catch ex As Exception

               End Try
               cn.Close()
           End Using
       End Using



System.ArgumentException was unhandled
  HResult=-2147024809
  Message=O formato da cadeia de inicialização não está de acordo com a especificação iniciada no índice 0.
  Source=System.Data
  StackTrace:
       em System.Data.Common.DbConnectionOptions.GetKeyValuePair(String connectionString, Int32 currentPosition, StringBuilder buffer, Boolean useOdbcRules, String& keyname, String& keyvalue)
       em System.Data.Common.DbConnectionOptions.ParseInternal(Hashtable parsetable, String connectionString, Boolean buildChain, Hashtable synonyms, Boolean firstKey)
       em System.Data.Common.DbConnectionOptions..ctor(String connectionString, Hashtable synonyms, Boolean useOdbcRules)
       em System.Data.SqlClient.SqlConnectionString..ctor(String connectionString)
       em System.Data.SqlClient.SqlConnectionFactory.CreateConnectionOptions(String connectionString, DbConnectionOptions previous)
       em System.Data.ProviderBase.DbConnectionFactory.GetConnectionPoolGroup(DbConnectionPoolKey key, DbConnectionPoolGroupOptions poolOptions, DbConnectionOptions& userConnectionOptions)
       em System.Data.SqlClient.SqlConnection.ConnectionString_Set(DbConnectionPoolKey key)
       em System.Data.SqlClient.SqlConnection.set_ConnectionString(String value)
       em System.Data.SqlClient.SqlConnection..ctor(String connectionString, SqlCredential credential)
       em System.Data.SqlClient.SqlConnection..ctor(String connectionString)
       em Projecto_cadastro_de_gente_fina.Cadastro.Button1_Click(Object sender, EventArgs e) na C:\Users\Bruno Soares\Documents\Visual Studio 2012\Projects\Projecto Castramento\Projecto Castramento\Cadastro.vb:linha 11
       em System.Windows.Forms.Control.OnClick(EventArgs e)
       em System.Windows.Forms.Button.OnClick(EventArgs e)
       em System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
       em System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
       em System.Windows.Forms.Control.WndProc(Message& m)
       em System.Windows.Forms.ButtonBase.WndProc(Message& m)
       em System.Windows.Forms.Button.WndProc(Message& m)
       em System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
       em System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
       em System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
       em System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG& msg)
       em System.Windows.Forms.Application.ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr dwComponentID, Int32 reason, Int32 pvLoopData)
       em System.Windows.Forms.Application.ThreadContext.RunMessageLoopInner(Int32 reason, ApplicationContext context)
       em System.Windows.Forms.Application.ThreadContext.RunMessageLoop(Int32 reason, ApplicationContext context)
       em System.Windows.Forms.Application.Run(ApplicationContext context)
       em Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.OnRun()
       em Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.DoApplicationModel()
       em Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.Run(String[] commandLine)
       em Projecto_cadastro_de_gente_fina.My.MyApplication.Main(String[] Args) na 17d14f5c-a337-4978-8281-53493378c1071.vb:linha 81
       em System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
       em System.AppDomain.nExecuteAssembly(RuntimeAssembly assembly, String[] args)
       em System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
       em Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
       em System.Threading.ThreadHelper.ThreadStart_Context(Object state)
       em System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
       em System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
       em System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
       em System.Threading.ThreadHelper.ThreadStart()
  InnerException: 


Hello!
The code outlined above is causing an exception Handled

解决方案

How can I Insert data into SQL Server using VBNet[^]

Update :

Ok, a .sdf file is a SQL Compact database, and you will need to use the 'SqlCeConnection' class to connect to.

Example from MSDN :

Dim conn As SqlCeConnection = Nothing

Try
    conn = New SqlCeConnection("Data Source = MyDatabase.sdf; Password ='<pwd>'")
    conn.Open()

    Dim cmd As SqlCeCommand = conn.CreateCommand()
    cmd.CommandText = "INSERT INTO Customers ([Customer ID], [Company Name]) Values('NWIND', 'Northwind Traders')"

    cmd.ExecuteNonQuery()
Finally
    conn.Close()
End Try


这篇关于SQL连接问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆