Gå til innhold

C#: [Løst] Bla igjennom MySql-linjer i C#?


Anbefalte innlegg

Hei!

 

Lager et program der jeg ønsker å bla igjennom records i en sql server, som en slags "bok".

 

Hver side har sin egen ID som brukes som primary key.

 

Løsningen min nå fungerer delvis, men langt ifra optimalt:

 

En textBox med startverdi 0 blir lest av ved Click på "Neste side". Når "Neste side"-knappen blir trykket inn, blir textBox'en sin verdi økt til 1, og informasjon fra databasen med id 1 skrevet ut til en RTB. Dette går naturligvis om og om igjen så langt som brukeren ønsker å "bla".

 

Hadde det ikke vært for at enkelte sider skal bli fjernet etterhvert hadde dette vært et optimalt system, men problemet ligger i at ID'en øker siden jeg har slått på AUTO INCREMENT.

 

Om jeg oppretter en ny side vil denne havne helt på slutten av ID-rekka, og det vil oppstå et "gap"(som andre kaller det iflg. google :p )

 

Finnes det virkelig ingen måte å få AUTO INCREMENT til å fylle inn gapene?

 

Eller er det noen som har en bedre løsning på dette? Har sittet med dette i et par dager nå, og når jeg trodde ting begynte å falle på plass fant jeg ut dette med gapene, så ganske frustrerende :p

 

Tusen takk for all hjelp, og takk for all hjelp i andre tråder også. :)

 

EDIT: Legger ved koden til "Neste side"-knappen for å vise hva jeg har kommet frem til sålangt.

 

 

 

 

 

	private void button17_Click(object sender, EventArgs e)
	{
		// Neste notat
		try
		{
			String myconnectionstring = "Server=x;Port=3306;Database=x;Uid=x;password=x;";
			MySqlConnection dbconn = new MySqlConnection(myconnectionstring);
			dbconn.Open();
			int teller = int.Parse(textBox10.Text);
			int nup = 0;
			nup = teller += 1;
			textBox10.Text = nup.ToString();
			String sql = "select * from Notatbok WHERE Notatid LIKE '" + textBox10.Text + "%'";

			MySqlCommand dbcmd = new MySqlCommand(sql, dbconn);
			MySqlDataReader dbdr = dbcmd.ExecuteReader();
			while (dbdr.Read())
			{
				string rtb;
				rtb = (dbdr["Notat"] + " ");
				richTextBox4.Text = rtb;
				Console.Write(dbdr[1]);
				Console.WriteLine("\r\n");
			}
			Console.ReadLine();
			dbconn.Close();
		}
		catch
		{
			Console.WriteLine("test");
			String myconnectionstring = "Server=x;Port=3306;Database=x;Uid=x;password=x;";
			MySqlConnection dbconn = new MySqlConnection(myconnectionstring);
			String sql = "SELECT * FROM Notatbok WHERE Notatid LIKE '" + textBox10.Text + "%'";
			MySqlCommand dbcmd = new MySqlCommand(sql, dbconn);

		}
	}

 

 

 

 

EDIT 2:

Byttet følgende:

String sql = "select * from Notatbok WHERE Notatid LIKE '" + textBox10.Text + "%'";

 

Til følgende:

String sql = "select * from Notatbok where Notatid > '" + textBox10.Text + "%' ORDER BY Notatid LIMIT 1";

 

Virker som at jeg er inne på noe, men må nok knote litt til.

Endret av Niggorex
Lenke til kommentar
Videoannonse
Annonse

Hei og takk for svar Torbjørn!

 

Jeg fant faktisk løsningen rett før jeg sjekket forumet her igjen.

 

Løste problemet mitt ved å gjøre følgende:

 

Legge inn:

String sql = "select * from Notatbok where Notatid > '" + textBox10.Text + "%' ORDER BY Notatid LIMIT 1";

 

Og en string i while-setningen:

			    string nid;
			    nid = (dbdr["Notatid"] + " ");
			    textBox10.Text = nid;

 

Dette gjorde at ved "Neste side"-trykk, skrev den automatisk neste ID-verdi inn i textBox10, slik at når man SÅ trykker igjen tar knappen utgangspungt i nåværende verdi istedenfor at textBox10 øker automatisk med 1 hver gang. Dette forårsaker jo et indirekte "gap" da den vil sjekke ugyldige tall uansett.

 

Takk igjen! :)

Lenke til kommentar

Opprett en konto eller logg inn for å kommentere

Du må være et medlem for å kunne skrive en kommentar

Opprett konto

Det er enkelt å melde seg inn for å starte en ny konto!

Start en konto

Logg inn

Har du allerede en konto? Logg inn her.

Logg inn nå
  • Hvem er aktive   0 medlemmer

    • Ingen innloggede medlemmer aktive
×
×
  • Opprett ny...