使用C#连接到sql server 2008数据库

时间:2013-07-29 17:01:38

标签: c# sql-server

我尝试使用连接字符串进行连接并收到此错误: “初始化字符串的格式不符合从索引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();

3 个答案:

答案 0 :(得分:0)

您的连接字符串错误。如果您使用SQL Server身份验证,它应该是这种形式:

Server=myServerAddress;Database=myDataBase;User Id=myUsername;
Password=myPassword;

其中myServerAddress是运行SQL Server的计算机的IP或主机名。如果它是您的PC,localhost可能会有效。

myUsernamemyPassword是连接到服务器的用户的凭据。

如果使用“可信连接”,则连接字符串应为以下格式:

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参数。

http://www.connectionstrings.com/sqlconnection/attach-a-database-file-on-connect-to-a-local-sql-server-express-instance-1/

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);