我尝试使用连接字符串进行连接并收到此错误: “初始化字符串的格式不符合从索引0开始的规范。”
这是我的代码:
SqlConnection Con = new SqlConnection(@"C:\PROGRAM FILES\MICROSOFT SQL SERVER\MSSQL10.SQLEXPRESS\MSSQL\DATA\TARGIL3.MDF");
SqlDataAdapter adapt = new SqlDataAdapter();
adapt.InsertCommand = new SqlCommand(" INSERT INTO tblEmployee VALUES (@employeeNumber, @employeePrivateName, @employeeFamilyName ,@city, @street, @houseNo, @phoneNumber, @birthDate, @startWorkingDate)", Con);
adapt.InsertCommand.Parameters.Add("@employeeNumber", SqlDbType.Char).Value = textBox1.Text;
adapt.InsertCommand.Parameters.Add("@employeePrivateName", SqlDbType.VarChar).Value = textBox2.Text;
adapt.InsertCommand.Parameters.Add("@employeeFamilyName", SqlDbType.VarChar).Value = textBox3.Text;
adapt.InsertCommand.Parameters.Add("@city", SqlDbType.VarChar).Value = textBox4.Text;
adapt.InsertCommand.Parameters.Add("@street", SqlDbType.VarChar).Value = textBox5.Text;
adapt.InsertCommand.Parameters.Add("@houseNo", SqlDbType.Int).Value = textBox6.Text;
adapt.InsertCommand.Parameters.Add("@phoneNumber", SqlDbType.Char).Value = textBox7.Text;
adapt.InsertCommand.Parameters.Add("@birthDate", SqlDbType.DateTime).Value = Convert.ToDateTime(textBox8.Text);
adapt.InsertCommand.Parameters.Add("@startWorkingDate", SqlDbType.DateTime).Value = Convert.ToDateTime(textBox8.Text);
Con.Open();
adapt.InsertCommand.ExecuteNonQuery();
Con.Close();
答案 0 :(得分:0)
您的连接字符串错误。如果您使用SQL Server身份验证,它应该是这种形式:
Server=myServerAddress;Database=myDataBase;User Id=myUsername;
Password=myPassword;
其中myServerAddress
是运行SQL Server的计算机的IP或主机名。如果它是您的PC,localhost
可能会有效。
myUsername
和myPassword
是连接到服务器的用户的凭据。
如果使用“可信连接”,则连接字符串应为以下格式:
Server=myServerAddress;Database=myDataBase;Trusted_Connection=True;
您可以在此处查看更多示例:http://www.connectionstrings.com/sql-server/
答案 1 :(得分:0)
您不能只在连接字符串中放置文件名
C:\PROGRAM FILES\MICROSOFT SQL SERVER\MSSQL10.SQLEXPRESS\MSSQL\DATA\TARGIL3.MDF
Sql Server通常是一个“服务”,你和服务商谈..........
现在。如果您使用的是“Express”版本......那么您可能必须包含AttachDbFilename参数。
Server=.\SQLExpress;AttachDbFilename=C:\MyFolder\MyDataFile.mdf;Database=dbname;
Trusted_Connection=Yes;
但是如果你不使用“Express”,那么你应该只提供有关Sql Server SERVICE的信息(机器\实例名等等),而不关心.MDF的物理路径。
Sql Server不是JET(Access)。使用JET,您只需指定文件名。
如果您仍然遇到问题,您应该发布您正在使用的sql server版本.....执行“select @@ version”并报告。
答案 2 :(得分:0)
使用它:
string connString = "Data Source=SERVERNAME;Initial Catalog=DATABASENAME; User ID = USERNAME; Password=PASSWORD;Integrated Security=false";
SqlConnection Con = new SqlConnection(connString);