Diskuze: C# MS-SQL problém s klauzulí WHERE
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 11 zpráv z 11.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Nejsem si jist, jestli jsem to napsal úplně správně, výsledek dotazu v dataReaderu je:
Zkus to napsat takto
SqlCommand prikaz = new SqlCommand("SELECT * FROM CESTY1 WHERE cislo = '1500101394'", pripojeni);
Určitě je tam sloupec, který se jmenuje "cislo" a určitě obsahuje
hodnotu "1500101394"?
Jak vypisuješ obsah toho datareaderu?
Když to napíšu podle Tvé rady, nenajde tabulku CESTY1.
Obsah vypisuju takhle:
while (dataReader.Read())
{
MessageBox.Show(dataReader.GetString(0));
hlavniFormular.CisloCPLabel.Text = dataReader.GetString(0);
hlavniFormular.Refresh();
}
}
dataReader.Close();
Ten messagebox tam je jen pro kontrolu, zatím.
Sloupec i hodnota v tabulce CESTY1 jsou. Ten příkaz v SQL funguje, jen tady mi
nevrací žádný výsledky.
Jak už jsem psal, když tu podmínku vyndám, dotaz funguje a dataReader se naplní. To, jak ten dotaz mám teď, je jen kvůli tomu, abych zjistil, proč mi to nefunguje. Originál vypadá takhle:
SqlCommand prikaz = new SqlCommand("SELECT cislo,convert(varchar, CESTY1.oscis) + oscis_vzt AS PPV,LTRIM(rtrim(daido.jm_jmeno)) + ' ' + ltrim(rtrim(daido.jm_prijm)) AS jmeno,utvar,poc_misto,poc_dat,jedn_misto,kon_misto,kon_dat,etapa FROM Orsoft.dbo.CESTY1 INNER JOIN Orsoft.dbo.daido ON daido.oscis = cesty1.oscis WHERE CESTY1.cislo = '" + cisloCP.Trim() + "'", pripojeni);
No, už mi to funguje. Přepsal jsem to na DataAdapter a výsledek posílám
do DataSetu a tak mi to funguje.
Dík.
neni "cislo" typu integer a ty v tom porovnani porovnavas typ integer se stringem '1500101394' ?
Ještě pro zajímavost, kdyby se s tím někdo taky mořil, mám to takhle:
public DataSet VyhledejCestak(string cisloCP, SqlConnection pripojeni)
{
string cisloCestaku = "1500101394";
string dotazSQL = ("SELECT cislo,convert(varchar, CESTY1.oscis) + oscis_vzt AS PPV,LTRIM(rtrim(daido.jm_jmeno)) + ' ' + ltrim(rtrim(daido.jm_prijm)) AS jmeno,utvar,poc_misto,poc_dat,jedn_misto,kon_misto,kon_dat,etapa FROM Orsoft.dbo.CESTY1 INNER JOIN Orsoft.dbo.daido ON daido.oscis = cesty1.oscis WHERE CESTY1.cislo = @cisloCestaku" );
SqlCommand prikaz = new SqlCommand(dotazSQL, pripojeni);
prikaz.Parameters.Add("@cisloCestaku", SqlDbType.VarChar).Value = cisloCestaku;
DataSet vysledekDotazu = new DataSet();
SqlDataAdapter dataAdapter;
try
{
if (pripojeni.State.Equals(ConnectionState.Open))
{
dataAdapter = new SqlDataAdapter(prikaz);
dataAdapter.Fill(vysledekDotazu);
}
}
catch(Exception ex)
{
MessageBox.Show(ex.Message);
}
return vysledekDotazu;
Zobrazeno 11 zpráv z 11.