[英]Insert data to a table - web service in visual studio
我正在嘗試使用Web服務使用Visual Studio將數據插入表中。 當我運行它時,選擇方法並輸入參數,然后單擊“調用”按鈕,我將收到以下錯誤。 我檢查了insert語句的語法,並嘗試使用其他語法。 但是我遇到了同樣的錯誤。 我究竟做錯了什么?
System.Data.SqlClient.SqlException: Incorrect syntax near the keyword 'User'.
at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj)
at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)
at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)
at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)
at System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(DbAsyncResult result, String methodName, Boolean sendToPipe)
at System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
at Service.register(String fname, String lname, String email, String num, Int32 locID)
//將值插入表格的Web方法//
[WebMethod]
public void register(string fname, string lname, string email, string num, int locID)
{
SqlConnection conn;
conn = ConnectionManager.GetConnection();
conn.Open();
string cmdString = "INSERT into User values(@fname,@lname,@email,@num,@locID)";
SqlCommand sqlCommand = new SqlCommand(cmdString, conn);
sqlCommand.CommandType = CommandType.Text;
sqlCommand.Parameters.Add("@fname", SqlDbType.Text).Value = fname;
sqlCommand.Parameters.Add("@lname", SqlDbType.Text).Value = lname;
sqlCommand.Parameters.Add("@email", SqlDbType.Text).Value = email;
sqlCommand.Parameters.Add("@num", SqlDbType.Text).Value = num;
sqlCommand.Parameters.Add("@locID", SqlDbType.Text).Value = locID;
sqlCommand.ExecuteNonQuery();
conn.Close();
}
///連接管理器類///
public class ConnectionManager
{
public static SqlConnection NewCon;
public static string ConStr ="Data Source=ACER-PC\\SQLEXPRESS;Initial Catalog=DisasterAlert;Integrated Security=True";
public static SqlConnection GetConnection()
{
NewCon = new SqlConnection(ConStr);
return NewCon;
}
}
“用戶”是SQL的保留字。 嘗試這個
"INSERT into [User] values(@fname,@lname,@email,@num,@locID)"
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.