Получение "ОШИБКА: Тайм-аут ожидания клиента." при подключении к одной таблице в базе данных - mysql коннектор на Arduino Uno Wifi Rev2
У меня есть база данных MariaDB на локальном сервере, и я использую ее для хранения данных из различных Arduino вокруг моего магазина. В настоящее время база данных содержит 12 таблиц. У меня также есть еще один Arduino Uno Wifi Rev2, который может подключаться к двум соответствующим таблицам; он собирает информацию о заданном значении из одной таблицы и идеально вставляет данные в другую.
Arduino, с которым у меня возникли проблемы, может прекрасно вставлять данные в свою таблицу данных (veg2_data), но терпит неудачу при попытке выбрать данные из своей таблицы sp (veg2_sp). Он также может подключаться к любой другой таблице в моей базе данных, в том числе и к первой arduino. Только veg2_sp работает неправильно
Вот мой код:
#include <SPI.h>
#include <WiFiNINA.h>
#include <MySQL_Connection.h>
#include <MySQL_Cursor.h>
#include "config.h"
//Node Libraries
#include <DHT.h>
#define O_UPPER 9
#define O_LOWER 10
//Wifi
byte mac_addr[] = { 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED }; //Нужно ли мне это?
char ssid[] = CONFIG_SSID;
char pass[] = CONFIG_PASS;
int status = WL_IDLE_STATUS;
int keyIndex = 0;
WiFiClient client;
//MySQL
IPAddress server_addr(192, 168, 1, 133);
char user[] = CONFIG_MYSQL_USER;
char password[] = CONFIG_MYSQL_PASS;
char db[] = CONFIG_MYSQL_DB;
char query[128];
char DATA_QUERY[] = "INSERT INTO veg2_data VALUES (now(), %d, %d, %s, %s, %s, %s, %s, %s, %d);";
char SP_QUERY[] = "SELECT * FROM veg2_sp ORDER BY timestamp DESC LIMIT 1;";
char rawTime[30];
byte refreshRate = 1;
uint32_t dbContactTimer;
MySQL_Connection conn((Client *)&client);
MySQL_Cursor cur = MySQL_Cursor(&conn);
//Node Specific
bool o_UpperState, o_LowerState, daytime = 0;
byte dayTempSP = 25, dayHumiditySP = 30, nightTempSP = 10, nightHumiditySP = 20,
o_UpperLock = 0, o_LowerLock = 0, sunrise = 7, sunset = 19;
int soilMoisture;
float intakeTemp, intakeHum, roomTemp, roomHum, exhaustTemp, exhaustHum ;
char intakeTempArray[7], intakeHumArray[7], roomTempArray[7], roomHumArray[7],
exhaustTempArray[7], exhaustHumArray[7];
DHT exhaust(6, DHT11);
DHT intake(7, DHT11);
DHT room(8, DHT11);
void setup() {
Serial.begin(115200);
wifiInit();
exhaust.begin();
intake.begin();
room.begin();
pinMode(O_UPPER, OUTPUT);
pinMode(O_LOWER, OUTPUT);
digitalWrite(O_UPPER, LOW);
digitalWrite(O_LOWER, LOW);
//spCheck();
dbContactTimer = millis();
}
void loop() {
//Скорость рефеша по умолчанию составляет 5 секунд. Некоторые узлы должны увеличивать скорость рефеша в определенное время
if (millis() - dbContactTimer >= (refreshRate * 1000)) {
dbUpdate();
spCheck();
//Если установлено значение auto (2), то мои фары будут включаться и выключаться в зависимости от дня/ночи. В настоящее время незавершенный
if (o_UpperLock == 2) {
if (daytime) {
digitalWrite(O_UPPER, HIGH);
o_UpperState = 1;
}
else {
digitalWrite(O_UPPER, LOW);
o_UpperState = 0;
}
}
dbContactTimer = millis();
}
}
//------------------------------------MySql Функции-------------------------
void spCheck() { //Updates setpoints
if (!conn.connected()) {
conn.close();
if (!conn.connect(server_addr, port, user, password, db)) {
return 0;
}
}
row_values *row = NULL;
cur.execute(SP_QUERY);
column_names *columns = cur.get_columns();
do {
row = cur.get_next_row();
if (row != NULL) {
//Serial.println(row->values[0]);
o_UpperLock = atol(row->values[1]);
//o_LowerLock = atol(row->values[2]);
//dayTempSP = atol(row->values[3]);
//dayHumiditySP = atol(row->values[4]);
//nightTempSP = atol(row->values[5]);
//nightHumiditySP = atol(row->values[6]);
//sunrise = atol(row->values[7]);
//sunset = atol(row->values[8]);
}
} while (row != NULL);
if (o_UpperLock < 2) {
if (o_UpperLock) {
digitalWrite(O_UPPER, HIGH);
o_UpperState = 1;
}
else {
digitalWrite(O_UPPER, LOW);
o_UpperState = 0;
}
}
return 1;
}
void dbUpdate() { //Обновляет данные
if (!conn.connected()) {
conn.close();
if (!conn.connect(server_addr, port, user, password, db)) {
return 0;
}
}
intakeTemp = intake.readTemperature();
dtostrf(intakeTemp, 4, 2, intakeTempArray);
intakeHum = intake.readHumidity();
dtostrf(intakeHum, 4, 2, intakeHumArray);
roomTemp = room.readTemperature();
dtostrf(roomTemp, 4, 2, roomTempArray);
roomHum = room.readHumidity();
dtostrf(roomHum, 4, 2, roomHumArray);
exhaustTemp = exhaust.readTemperature();
dtostrf(exhaustTemp, 4, 2, exhaustTempArray);
exhaustHum = exhaust.readHumidity();
dtostrf(exhaustHum, 4, 2, exhaustHumArray);
soilMoisture = analogRead(A0);
sprintf(query, DATA_QUERY, o_UpperState, o_LowerState, intakeTempArray,
intakeHumArray, roomTempArray, roomHumArray, exhaustTempArray, exhaustHumArray, soilMoisture);
cur.execute(query);
return 1;
}
void wifiInit() {
String fv = WiFi.firmwareVersion();
if (fv < WIFI_FIRMWARE_LATEST_VERSION) {
Serial.println("Please upgrade the firmware");
}
if (WiFi.status() == WL_NO_MODULE) {
Serial.println("No wifi Module - Abort");
while (true);
}
while (status != WL_CONNECTED) {
Serial.println("Connecting to wifi");
for (byte i = 0; i < 2; i++) {
digitalWrite(LED_BUILTIN, HIGH);
delay(2000);
digitalWrite(LED_BUILTIN, LOW);
delay(1000);
}
status = WiFi.begin(ssid, pass);
}
IPAddress ip = WiFi.localIP();
long rssi = WiFi.RSSI();
Serial.print("SSID: ");
Serial.println(WiFi.SSID());
Serial.print("IP Address: ");
Serial.println(ip);
Serial.print("signal strength (RSSI):");
Serial.print(rssi);
Serial.println(" dBm");
}
Проблема заключается в SP_QUERY. Я могу изменить таблицу на любую другую в моей базе данных, и код функционирует нормально. Если я читаю из veg2_sp, я получаю ошибку.
Таблицы: Первая-та, с которой у меня возникли проблемы, вторая-та, которая в настоящее время функционирует.
Я совершенно сбит с толку.
@The Candy King, 👍2
Обсуждение0
- Ошибка при загрузке кода в esp8266 через arduino (FatalError('Failed to connect to %s: %s' % (self.CHIP_NAME, last_error)))
- TCCR1B' не был объявлен в этой области
- avrdude: usbdev_open(): невозможно открыть устройство: в доступе отказано
- Пароль MD5 в Sketch
- Строка JSON для Arduino WiFi версии 2
- Могу ли я обойти очень долгое время, чтобы настроить WIFI-соединение WPA2 Personal?
- Отправка значений из arduino uno в wemos d1 r1
- Ошибка Udp.endPacket
брандмауэр на ПК?, @Juraj
Я тоже так думал, но я все еще могу подключиться к другой таблице в базе данных. Если бы я ни к чему не мог подключиться, я бы согласился, но что мешает мне получить доступ к одной таблице??, @The Candy King