Dodawanie do bazy co 30 min - piotrvb - 10-10-2021
Hej
Mam kod który dodaje dane z czujnika ds18b20 do bazy danych chciałbym aby dodawanie odbywało się co 30 min
Obecnie dodaje mi co 7 s
Kod: #include <ESP8266WiFi.h>
#include <Wire.h>
#include <OneWire.h>
#include <DallasTemperature.h>
const char *ssid = ""; //nama wifi
const char *password = ""; //password
const char *host = ""; //IP PC
//memasukkan pin
int sensorPinDS18b20 = 4;
//membuat variabel kosong
float suhuC;
OneWire ourWire(sensorPinDS18b20);
DallasTemperature sensors(&ourWire);
void setup() {
Serial.begin(115200);
delay(1000);
Serial.println();
Serial.println();
Serial.print("Connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED)
{
delay(500);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected");
Serial.println("IP address: ");
Serial.println(WiFi.localIP());
}
void loop() {
sensors.requestTemperatures();
suhuC = sensors.getTempCByIndex(0);
Serial.print("connecting to ");
Serial.println(host);
WiFiClient client;
const int httpPort = 80;
if (!client.connect(host, httpPort))
{
Serial.println("connection failed");
return;
}
// We now create a URI for the request
String url = "/nodemcu-esp8266-with-DS18B20-Sensor-MySQL-Database/add.php?";
url += "suhu_air=";
url += suhuC;
Serial.print("Requesting URL: ");
Serial.println(url);
// This will send the request to the server
client.print(String("GET ") + url + " HTTP/1.1\r\n" +
"Host: " + host + "\r\n" +
"Connection: close\r\n\r\n");
unsigned long timeout = millis();
while (client.available() == 0)
{
if (millis() - timeout > 5000)
{
Serial.println(">>> Client Timeout !");
client.stop();
return;
}
}
// Read all the lines of the reply from server and print them to Serial
while (client.available())
{
String line = client.readStringUntil('\r');
//Serial.print(line);
if (line.indexOf("sukses gaes") != -1)
{
Serial.println();
Serial.println("Yes, data masuk");
}
else if (line.indexOf("gagal gaes") != -1)
{
Serial.println();
Serial.println("Maaf, data gagal masuk");
//digitalWrite(alarmPin, HIGH);
}
}
Serial.println();
Serial.println("closing connection");
//menampilkan hasil pembacaan sensor Suhu DS18b20
Serial.print("Suhu = ");
Serial.print(suhuC);
Serial.print(" ");
Serial.println("C");
delay(1000);
}
Kod PHP: <?php include('conn.php');
$sensor = $_GET['suhu_air'];
$sql = "INSERT INTO tbl_water (suhu_air) VALUES(:suhu_air)";
$stmt = $PDO->prepare($sql);
$stmt->bindParam(':suhu_air', $sensor);
if($stmt->execute()) { echo "sukses gaes"; }else{ echo "gagal gaes"; } ?>
RE: Dodawanie do bazy co 30 min - kaczakat - 10-10-2021
Wywal delay(), naucz się używać millis(), zauważaj rozpoczęcie nowej sekundy, zliczaj sekundy, jeśli (sekundy%30==0) wyślij dane do bazy.
RE: Dodawanie do bazy co 30 min - piotrvb - 11-10-2021
I tu będzie problem dopiero zaczynam przygodę a może ma ktoś jakiś kod na wysyłkę danych z czujnika ds18b20 do bazy danych
RE: Dodawanie do bazy co 30 min - kaczakat - 11-10-2021
I nie ma sensu iść dalej dopóki nie opanujesz millis().
Różnica jest tylko taka, że zamiast zatrzymywać program w LOOP na 1000ms delay pozwalasz na wykonywaniu tej pętli jak tylko się da najszybciej, za każdym razem sprawdzając czy w tym obiegu LOOP minęła już sekunda (czy jakiś inny okres czas) i w związku z tym należy coś zrobić czy jednak jeszcze nie.
Nie ma sensu w każdej pętli pytać o temperaturę DS'a, nie ma sensu zapytać i czekać 750ms na odpowiedź, warto włączyć tryb asynchroniczny i samemu sprawdzać czy minęło odpowiednio dużo czasu od zlecenia pomiaru, np. w setup zlecić odczyt, odczekać sekundę, przejść do loop, zrobić odczyt i zlecić kolejny pomiar, gdy nastąpi nowa sekunda powtórzyć. Albo co 10s/m/h, zależy do czego to potrzebne, można co 100ms ale kosztem dokładności.
Wklejałem już taki przykład:
Kod: uint32_t czasTeraz,czasPoprzedni,tik=10; //tik musi byc mniejszy niz 1000 i dzilic 1000ms na rowne czesci
uint8_t nTik,sekundy,minuty,godziny,dni; //liczniki tikow, sekund, itd.
bool fnTik,fsekundy,fminuty,fgodziny,fdni; //flagi zdarzen nowy tik, nowa sekunda,minuta, godzina, dzien
char napis[10];
void setup() {
// put your setup code here, to run once:
Serial.begin(115200);
pinMode(LED_BUILTIN,OUTPUT);
}
void loop() {
// put your main code here, to run repeatedly:
czas();
if(fsekundy) {
sprintf(napis,"%03d:%02d:%02d",godziny,minuty,sekundy);
Serial.println(napis);
if(fminuty && minuty%30 == 0)//zrobi cos co 30min
{Serial.println("Minelo 30m");
}
}
if(fnTik&&! (nTik%20)) digitalWrite(LED_BUILTIN,! digitalRead(LED_BUILTIN));//gdy nowy tik i co 20 tikow
}
void czas()
{
czasTeraz=millis();
fnTik=fsekundy=fminuty=fgodziny=fdni=0;
if((uint32_t)(czasTeraz-czasPoprzedni)>=tik) //tan napisany warunek jest odporny na "klątwe 50 dni millis()"
{
czasPoprzedni=czasTeraz;
fnTik=1;
nTik++;
if(nTik>=(1000/tik))
{
nTik=0;
sekundy++;
fsekundy=1;
if (sekundy>=60)
{
sekundy=0;
minuty++;
fminuty=1;
if (minuty>=60)
{
minuty=0;
godziny++;
fgodziny=1;
if (godziny>=24)
{
godziny=0;
fdni=1;
dni++;
}
}
}
}
}
}
|