• Witaj na Forum Arduino Polska! Zapraszamy do rejestracji!
  • Znajdziesz tutaj wiele informacji na temat hardware / software.
Witaj! Logowanie Rejestracja


Ocena wątku:
  • 0 głosów - średnia: 0
  • 1
  • 2
  • 3
  • 4
  • 5
Dodawanie do bazy co 30 min
#1
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";
  }
?>
 
Odpowiedź
#2
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.
Miło być decenianym https://buycoffee.to/kaczakat
 
Odpowiedź
#3
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
 
Odpowiedź
#4
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++;
   
        }
      }
    }
  }
}
}
Miło być decenianym https://buycoffee.to/kaczakat
 
Odpowiedź
  


Skocz do:


Przeglądający: 1 gości