SQL dotaz – .NET – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

SQL dotaz – .NET – Fórum – Programujte.comSQL dotaz – .NET – Fórum – Programujte.com

 

Jirka
~ Anonymní uživatel
305 příspěvků
7. 2. 2010   #1
-
0
-

Ahojte,

potrebuji poradit mam okno kde mam nekolik textboxu a chtel bych kdyz uzivatel do okna nic nezada tak aby mi to naslo vsechny ale nevim jak to udelat?



string jmeno;
string prijmeni;

if (this.txt_vyhledavaniJmeno.Text == String.Empty)
jmeno = "*";
else
jmeno = this.txt_vyhledavaniJmeno.Text;

if (this.txt_vyhledavaniPrijmeni.Text == String.Empty)
prijmeni = "*";
else
prijmeni = this.txt_vyhledavaniPrijmeni.Text;

try
{
using (connection = new SqlConnection(Settings.Default.KlientiConnectionString))
{
connection.Open();

SqlCommand cmd = new SqlCommand("SELECT * FROM Klienti WHERE Jmeno = @Jmeno", connection);

SqlParameter paramJmeno = new SqlParameter("@Jmeno", jmeno);
SqlParameter paramPrijmeni = new SqlParameter("@Prijmeni", prijmeni);

cmd.Parameters.Add(paramJmeno);
cmd.Parameters.Add(paramPrijmeni);

reader = cmd.ExecuteReader();

while (reader.Read())
{
MessageBox.Show(reader["Prijmeni"].ToString());
}
}
}


Problem bude asi v te *.

Dekuji za odpoved

Nahlásit jako SPAM
IP: 89.176.252.–
dannyk0
Věrný člen
7. 2. 2010   #2
-
0
-

Da se pouzit neco takoveho:



SELECT * FROM Klienti WHERE Jmeno = ANY (SELECT Jmeno FROM Klienti)

Ale nevim, jak na reagujou parametry, jestli se musi zadat jako specialni typ nebo jako retezec.

Mozna bych volil vetveni programu podle hodnot.

Nahlásit jako SPAM
IP: 85.135.97.–
Jedu v c++,c#,assembler,ASP.NET,PHP,databaze,bezpecnost softwaru[br] -----------------------------------------------------------[br] Muj blog o programovani,hudbe a vsem moznem,co najdu na netu :) [br] http://dannyk.aspone.cz[br] -----------------------------------------------------------[br] Na foru mam nejake prispevky pod nickem Master,tak jen pro upresneni :)
dandas
~ Anonymní uživatel
3 příspěvky
8. 2. 2010   #3
-
0
-

To Jirka : zkus treba toto..

            bool zadalJmeno = this.txt_vyhledavaniJmeno.Text.Trim().Length > 0;

bool zadalPrijmeni = this.txt_vyhledavaniPrijmeni.Text.Trim().Length > 0;

string commandText = string.Format("SELECT * FROM Klienti {0} {1} {2} {3}",
zadalJmeno||zadalPrijmeni?"WHERE":string.Empty,
zadalJmeno?this.txt_vyhledavaniJmeno.Text:string.Empty,
zadalJmeno&&zadalPrijmeni?"AND":string.Empty,
zadalPrijmeni?this.txt_vyhledavaniPrijmeni.Text:string.Empty
);

try {
using (connection = new SqlConnection(Settings.Default.KlientiConnectionString)) {
connection.Open();
using (SqlCommand cmd = new SqlCommand(commandText, connection)) {
if (zadalJmeno) {
SqlParameter paramJmeno = new SqlParameter("@Jmeno", jmeno);
cmd.Parameters.Add(paramJmeno);
}
if (zadalPrijmeni) {
SqlParameter paramPrijmeni = new SqlParameter("@Prijmeni", prijmeni);
cmd.Parameters.Add(paramPrijmeni);
}
reader = cmd.ExecuteReader();
while (reader.Read()) {
MessageBox.Show(reader["Prijmeni"].ToString());
}
}
}
} catch {

}

Nahlásit jako SPAM
IP: 194.213.32.–
dandas
~ Anonymní uživatel
3 příspěvky
8. 2. 2010   #4
-
0
-

Oprava:

            bool zadalJmeno = this.txt_vyhledavaniJmeno.Text.Trim().Length > 0;

bool zadalPrijmeni = this.txt_vyhledavaniPrijmeni.Text.Trim().Length > 0;

string commandText = string.Format("SELECT * FROM Klienti {0} {1} {2} {3}",
zadalJmeno || zadalPrijmeni ? "WHERE":string.Empty,
zadalJmeno ? "Jmeno = @Jmeno" : string.Empty,
zadalJmeno && zadalPrijmeni? "AND" : string.Empty,
zadalPrijmeni ? "Prijmeni = @Prijmeni" : string.Empty
);

try {
using (connection = new SqlConnection(Settings.Default.KlientiConnectionString)) {
connection.Open();
using (SqlCommand cmd = new SqlCommand(commandText, connection)) {
if (zadalJmeno) {
SqlParameter paramJmeno = new SqlParameter("@Jmeno", this.txt_vyhledavaniJmeno.Text.Trim());
cmd.Parameters.Add(paramJmeno);
}
if (zadalPrijmeni) {
SqlParameter paramPrijmeni = new SqlParameter("@Prijmeni", this.txt_vyhledavaniPrijmeni.Text.Trim());
cmd.Parameters.Add(paramPrijmeni);
}
reader = cmd.ExecuteReader();
while (reader.Read()) {
MessageBox.Show(reader["Prijmeni"].ToString());
}
}
}
} catch {
//Chyba
}

Nahlásit jako SPAM
IP: 194.213.32.–
dandas
~ Anonymní uživatel
3 příspěvky
8. 2. 2010   #5
-
0
-

Pokud to ma vyhledavat mozna bych jeste upravil "Jmeno = @Jmeno" na "Jmeno LIKE @Jmeno" a pri vytvareni Parametru pridal k textu textboxu '%'

Nahlásit jako SPAM
IP: 194.213.32.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 62 hostů

Podobná vlákna

SQL dotaz — založil Zdeněk Písařovic

Dotaz SQL — založil SantaClaus

SQL dotaz — založil Rudolf

SQL dotaz — založil Figa

Sql dotaz — založil Paja

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý