1

我正在尝试将参数传递给 sql 选择查询。

出于某种原因,无论我尝试什么,我都会收到相同的错误:输入字符串不是正确格式

和建议:将字符串转换为日期时间时,在将每个变量放入日期时间对象之前解析字符串以获取日期。

我不知道该怎么做。这是代码。

sql查询:

    ALTER PROCEDURE SearchAllPlayers
(
@personName,
@personPay,
@IDs
)

SELECT DISTINCT
                         person.personID, sports.sportsID, person.personName, person.personPay, sports.sport,

FROM            sports INNER JOIN
                person INNER JOIN
                personSport ON personSport.personID = person.personID
                       INNER JOIN
                personSport ON personSport.sportID = sports.sportsID

WHERE        (person.personName LIKE '%' + @personName + '%')
              AND
             (person.personPay >= @personPay OR 0 = @personPay)
              AND
             (person.regDate >= { fn CURDATE() }
              AND
             (sports.sportID IN
                    (SELECT   ID FROM dbo.fnSplitter(@IDs) AS fnSplitter_1) OR @IDs = 0)

代码隐藏:

protected void Button1_Click(object sender, EventArgs e)
{
    searchGrid();
}

protected void searchGrid()
{
    SqlConnection conn = new SqlConnection(connSTR);
    com = new SqlCommand();
    conn.Open();

    com.Connection = conn;

    com.CommandText = "SearchAllPlayers";
    com.CommandType = CommandType.StoredProcedure;

    string StringWithDelimiter = string.Empty;
    for (int i = 0; i < DropDownCheckBoxes1.Items.Count; i++)
    {
        if (DropDownCheckBoxes1.Items[i].Selected)
            StringWithDelimiter += DropDownCheckBoxes1.Items[i].Value + ";";
    }

    com.Parameters.Add("@personName", SqlDbType.VarChar).Value = personName.Text;

    //next line is where I am having problems
    com.Parameters.Add("@personPay", SqlDbType.Decimal).Value = ??????
    com.Parameters.Add("@IDs", SqlDbType.VarChar).Value = StringWithDelimiter;

 so far i've tried the following combinations, all to know avail.


com.parameters.add("@playerPay", sqldbtype.decimal).value = playerPayTextBox.Text;

这似乎不起作用,我收到以下错误:“将数据类型 nvarchar 转换为十进制时出错。”

所以然后我尝试了这个:

com.parameters.add("@playerPay", sqldbtype.decimal).value = playerPayTextBox.tostring();

我得到同样的错误:“将数据类型 nvarchar 转换为十进制时出错。”

这是有道理的,所以我尝试了:

com.parameters.add("@playerPay", sqldbtype.decimal).value = decimal.parse(playerPayTextBox.tostring());

错误:“输入字符串的格式不正确。” - 然后是日期时间的事情......

com.parameters.add("@playerPay", sqldbtype.decimal).value = decimal.parse(playerPayTextBox.text);

错误:“输入字符串的格式不正确。” - 然后是日期时间的事情......

com.parameters.add("@playerPay", sqldbtype.decimal).value = convert.todecimal(playerPayTextBox.text);

错误:“输入字符串的格式不正确。” - 然后是日期时间的事情......

com.parameters.add("@playerPay", sqldbtype.decimal).value = convert.todecimal(playerPayTextBox.text);

错误:“输入字符串的格式不正确。” - 然后是日期时间的事情......

不知道该怎么办

4

1 回答 1

5

确保您的输入字符串为您当前的文化使用小数点符号!。如果您的输入字符串与这些规则不匹配,decimal.Parse则抛出 Input string was not in a correct format 异常

例如,如果您使用不变的文化:

decimal.Parse("17.5", CultureInfo.InvariantCulture)

点将是接受的小数点。

您可以在MSDN上阅读有关它的更多信息

他们还提到该decimal.TryParse方法更适合不变的文化解析

另外(显然),确保您的输入字符串不为空、空或不包含任何非数字字符(除了一个,可选的,点或逗号,具体取决于您的文化)

于 2013-06-07T00:14:22.733 回答