Diskuze: MySQL - periodické čtení z databáze
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 14 zpráv z 14.
//= 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.
Pouzij jiny timer/vlakno ktere nebezi na UI. Data pak synchronizuj pres Invoke.
Tak se mi povedlo udělat ten asynchronní timer, ale teď nevím jak dostat proměnný zpět do vlákna UI.
private static System.Threading.Timer timer;
private static void Main()
{
timer = new System.Threading.Timer(_ => OnCallBack(), null, 1000, Timeout.Infinite);
Console.ReadLine();
}
private static void OnCallBack()
{
timer.Dispose();
label7.Text = "Něco co se mění každý tick";
timer = new System.Threading.Timer(_ => OnCallBack(), null, 1000, Timeout.Infinite);
}
Mohl bys použít BackgroundWorker, tem má synchronizaci s hlavním vláknem vyřešenou. Ve chvíli kdy ti doběhne dotaz do databáze, tak jeho výsledek nastavíš jako result backgroundworkeru a v eventu který se vyhodí ve chvíli kd backgroundWorker skončí si ten result vezmeš (to už jsi v hlavním vlákně).
Nevím jestli to je úplně pěkné řešení, ale ten backgroundworker můžeš spouštět timerem z hlavního vlákna, jen předtím vždycky musíš zkontrolovat zda předchozí operace už doběhla (isRunning = False)
Tak to chápu ještě míň než ten async timer
Ahoj,
Já na to používám metodu BeginInvoke, ale funguje jenom ve WF, we WPF to píšu Dispatcher.BeginInvoke ....
Snad je to tak správně, ale určitě to funguje.
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
TimerCallback callback;
System.Threading.Timer stateTimer = null;
private void button1_Click(object sender, EventArgs e)
{
callback = new TimerCallback(Tick);
stateTimer = new System.Threading.Timer(callback, null, 0, 1000);
}
private void Tick(object state)
{
textBox1.BeginInvoke(new Action(() => { textBox1.Text += "Tick" + Environment.NewLine; }));
}
}
Tak jsem to zkusil udělat podle tvého kódu a zdá se že by to mělo fungovat. Jenom mi to z neznámého důvodu vrací, že Nemůžu začít nové připojení do databáze pokud jsem se minule neodpojil, i když jsem se nikdy předtím nepřipojil...
Chová se to velice zajímavě... udělá to první jeden nebo dva cykly a pak napíše, že připojení k MySQL už bylo vytvořeno.
No musíš tam mít někde SqlConnection.Open(), pak by si to měl vždy po vykonání příkazu zavřít pomocí Close() i když ty vlastně ani nemusíš, budeš ít jednou vytvořené připojení a potom tu tabulku každou vteřinu přečteč a porovnáš změny, to by mělo asi fungovat, i když správně by si měl dělat SqlDependency, které umí zachytávat udalost změny databaze, takže Tobě ten program zareaguje pouze když se v SQLku něco změní, ale u toho si zase nejsem vůbec jistej, jeslti to umí MySql
Open a Close tam právě mám Ale vypadá to, že než se stačí zavřít tak cyklus jede znova
Tak to bohužel nefunguje...
Zde přidávám kód, jetli by někoho napadlo co s tím může být
Jestli je ten dotaz skutečně do MySql, tak bych se ani nedivil, kdyby trval déle, než jednu sekundu, tudíž se nový dotaz spustí dříve, než se stihne uzavřít to první spojení. Myslím, že by bylo lepší použít klasickou MSSQL...
To mozna ano, ale mam v zadani pouziti MySQL.
Dotaz netrva dele. Uz jsem zkousel zvetsit periodu.
Problem bude nekde v tom, ze se zrejmne asynchronne spusti timer 2x
Tak problém vyřešen. Poradil jsem se s profesorem. Problém jsme vyřešili vytvořením jednoho připojení a jednoho odpojení. Tím pádem se už při každém query mysql nepřipojuje a neodpojuje.
vodslon vyřešil můj prvotní problém. Díky
Zobrazeno 14 zpráv z 14.