2012-02-16 10 views
0

で、私は他のドロップダウンリストに基づいてドロップダウンリストを移入していないた... 私は第一ドロップダウンリストで値を選択すると、私はこのエラーを取得しておく。..例外の詳細:にSystem.FormatException:入力文字列が正しい形式

誰かが..私は私の問題は、ここでラインだと思います..ここでのコードだ...私にvarchar型を使用して

int CountryID = Convert.ToInt32(ddlCountry.SelectedValue.ToString()); 

イムを

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Configuration; 
using System.Data.SqlClient; 
using System.Data; 

public partial class _Default : System.Web.UI.Page 
{ 
protected void Page_Load(object sender, EventArgs e) 
{ 
    if (!IsPostBack) 
    { 
     FillCountry(); 
    } 
} 
protected void ddlCountry_SelectedIndexChanged(object sender, EventArgs e) 
{ 
    int CountryID = Convert.ToInt32(ddlCountry.SelectedValue.ToString()); 
    FillStates(CountryID); 
    ddlCity.SelectedIndex = 0; 
} 
protected void ddlState_SelectedIndexChanged(object sender, EventArgs e) 
{ 
    int StateID = Convert.ToInt32(ddlState.SelectedValue.ToString()); 
    FillCities(StateID); 
} 

private void FillCountry() 
{ 
    string strConn =  ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; 
    SqlConnection con = new SqlConnection(strConn); 
    SqlCommand cmd = new SqlCommand(); 
    cmd.Connection = con; 
    cmd.CommandType = CommandType.Text; 
    cmd.CommandText = "SELECT CountryID, CountryName FROM Country"; 
    DataSet objDs = new DataSet(); 
    SqlDataAdapter dAdapter = new SqlDataAdapter(); 
    dAdapter.SelectCommand = cmd; 
    con.Open(); 
    dAdapter.Fill(objDs); 
    con.Close(); 
    if (objDs.Tables[0].Rows.Count > 0) 
    { 
     ddlCountry.DataSource = objDs.Tables[0]; 
     ddlCountry.DataTextField = "CountryName"; 
     ddlCountry.DataValueField = "CountryID"; 
     ddlCountry.DataBind(); 
     ddlCountry.Items.Insert(0, "--Select--"); 
    } 
    else 
    { 
     lblMsg.Text = "No Countries found"; 
    } 


} 

private void FillStates(int countryID) 
{ 
    string strConn = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; 
    SqlConnection con = new SqlConnection(strConn); 
    SqlCommand cmd = new SqlCommand(); 
    cmd.Connection = con; 
    cmd.CommandType = CommandType.Text; 
    cmd.CommandText = "SELECT StateID, StateName FROM State WHERE CountryID [email protected]"; 
    cmd.Parameters.AddWithValue("@CountryID", countryID); 
    DataSet objDs = new DataSet(); 
    SqlDataAdapter dAdapter = new SqlDataAdapter(); 
    dAdapter.SelectCommand = cmd; 
    con.Open(); 
    dAdapter.Fill(objDs); 
    con.Close(); 
    if (objDs.Tables[0].Rows.Count > 0) 
    { 
     ddlState.DataSource = objDs.Tables[0]; 
     ddlState.DataTextField = "StateName"; 
     ddlState.DataValueField = "StateID"; 
     ddlState.DataBind(); 
     ddlState.Items.Insert(0, "--Select--"); 
    } 
    else 
    { 
     lblMsg.Text = "No states found"; 
    } 
} 

private void FillCities(int stateID) 
{ 
    string strConn = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; 
    SqlConnection con = new SqlConnection(strConn); 
    SqlCommand cmd = new SqlCommand(); 
    cmd.Connection = con; 
    cmd.CommandType = CommandType.Text; 
    cmd.CommandText = "SELECT CityID, CityName FROM City WHERE StateID [email protected]"; 
    cmd.Parameters.AddWithValue("@StateID", stateID); 
    DataSet objDs = new DataSet(); 
    SqlDataAdapter dAdapter = new SqlDataAdapter(); 
    dAdapter.SelectCommand = cmd; 
    con.Open(); 
    dAdapter.Fill(objDs); 
    con.Close(); 
    if (objDs.Tables[0].Rows.Count > 0) 
    { 
     ddlCity.DataSource = objDs.Tables[0]; 
     ddlCity.DataTextField = "CityName"; 
     ddlCity.DataValueField = "CItyID"; 
     ddlCity.DataBind(); 
     ddlCity.Items.Insert(0, "--Select--"); 
    } 
    else 
    { 
     lblMsg.Text = "No Cities found"; 
    } 
} 
} 

それを説明することができます

+0

だから、 'ddlCountry.SelectedValue'は有効な' Int32' – Shai

+0

CountryID列が速い応答の数値 –

+0

感謝する必要があります..しかし、あなたはそれを詳しく説明してくださいすることができます.. C#.. – drayl

答えて

-1

このエラーは、ddlCountry.SelectedValue.ToString()の値が数値でないか空である場合に発生します。 try catchブロックに入れてみてください。

+0

この男は同じ意図を持って見て.. :) –

2

おそらくドロップダウンリストの値は、整数の文字列表現ではありません。あなたはいずれかint.TryParseまたは(より悪い)try/catchブロックを使用することもできますが

は、おそらくSelectedValueオプションではなく、ユーザーよりあなたによって制御されるものなので、すべて君何のために有効である必要があり彼らと一緒に行くだろう。

最初に行うべきことは、おそらくデバッガでこれを調べることです。例外が発生すると(デバッガがブレークするはずです)、変換しようとしている値は何ですか? 「悪い価値」を得たら、そこにどのように到達したのかを考えてください。

編集:値が "PRC0001"の場合は、明らかには整数ではないです。すべてのテーブルでvarcharを使用している場合、おそらくあなたの国IDフィールドはvarcharとなります。なぜ最初に整数に変換しようとしていますか?

+0

私はサンプルコードを表示することができますか? – drayl

+0

@ user1213269サンプルコードはありません。アプリケーションをデバッグし、 'DropDownList'が保持するWHICH値を確認する必要があります。数値以外の値がある場合は、*あなたの問題です。 – Shai

+0

私はすでにCountryIDのための私のデータ型としてvarcharを使用していることを言及しました..そこに代わりのコードがありますか? – drayl

関連する問題