在Windows11的环境中,使用8.0版本的MySQL,怎样通过idea将串口传输过来的温湿度数据传输到MySQL中,arduino的代码为:/***************************************************** 湖南创乐博智能科技有限公司 name:Humiture Detection function:you can see the current value of humidity and temperature displayed on the I2C LCD1602. ******************************************************/ //include the libraries #include <dht.h> #include <LiquidCrystal_I2C.h> #include <Wire.h> LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 and 0x3F for a 16 chars and 2 line display dht DHT;//create a variable type of dht const int DHT11_PIN= A0;//Humiture sensor attach to pin7 void setup() { Serial.begin(9600);//initialize the serial lcd.init(); //initialize the lcd lcd.backlight(); //open the backlight } void loop() { //READ DATA Serial.println("DHT11:"); D: int chk = DHT.read11(DHT11_PIN);//read the value returned from sensor switch (chk) { case DHTLIB_OK: Serial.println("OK!"); break; case DHTLIB_ERROR_CHECKSUM: //goto D; Serial.print("Checksum error,\t"); break; case DHTLIB_ERROR_TIMEOUT: goto D; Serial.print("Time out error,\t"); break; default: // goto D; Serial.print("Unknown error,\t"); break; } // DISPLAY DATA lcd.setCursor(0, 0); lcd.print("Tem:"); Serial.print("Tem:"); lcd.print(DHT.temperature,1); //print the temperature on lcd Serial.print(DHT.temperature,1); lcd.print(char(223));//print the unit" ℃ " lcd.print("C"); Serial.println(" C"); lcd.setCursor(0, 1); lcd.print("Hum:"); Serial.print("Hum:"); lcd.print(DHT.humidity,1); //print the humidity on lcd Serial.print(DHT.humidity,1); lcd.print(" %"); Serial.println(" %"); delay(200); //wait a while } 请详细描述操作过程,包括如何导入库,导入什么库,并将完整代码写出。
时间: 2023-07-24 18:14:24 浏览: 117
python 中Arduino串口传输数据到电脑并保存至excel表格
要将串口传输的温湿度数据传输到 MySQL 数据库中,你需要按照以下步骤进行操作:
1. 首先,在 IntelliJ IDEA 中创建一个新的 Java 项目。
2. 在项目中添加必要的库文件:MySQL Connector/J 和 RXTXcomm。你可以在 Maven 或 Gradle 的配置文件中添加这些依赖,或者手动将这些库文件导入到项目中。
3. 创建一个新的 Java 类,命名为 `HumitureDataTransfer`(或者你喜欢的其他名称),并在该类中编写代码。
4. 在 `HumitureDataTransfer` 类中导入需要使用的库:
```java
import gnu.io.CommPortIdentifier;
import gnu.io.SerialPort;
import gnu.io.SerialPortEvent;
import gnu.io.SerialPortEventListener;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
```
5. 在 `HumitureDataTransfer` 类中定义一些全局变量,用于串口通信和数据库连接:
```java
private static final String PORT_NAME = "COM1"; // 替换为你的串口号
private static final int TIMEOUT = 2000; // 超时时间(毫秒)
private static final int BAUD_RATE = 9600; // 波特率
private static final String DB_URL = "jdbc:mysql://localhost:3306/your_database"; // 替换为你的数据库连接地址
private static final String DB_USERNAME = "your_username"; // 替换为你的数据库用户名
private static final String DB_PASSWORD = "your_password"; // 替换为你的数据库密码
```
6. 在 `HumitureDataTransfer` 类中创建一个内部类 `SerialListener`,用于监听串口数据的到达:
```java
private class SerialListener implements SerialPortEventListener {
private StringBuilder buffer = new StringBuilder();
@Override
public void serialEvent(SerialPortEvent event) {
if (event.getEventType() == SerialPortEvent.DATA_AVAILABLE) {
try {
byte[] data = new byte[serialPort.getInputStream().available()];
int bytesRead = serialPort.getInputStream().read(data);
for (int i = 0; i < bytesRead; i++) {
if (data[i] == '\n') {
String message = buffer.toString().trim();
saveDataToDatabase(message);
buffer.setLength(0);
} else {
buffer.append((char) data[i]);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
```
7. 在 `HumitureDataTransfer` 类中添加一些辅助方法,用于保存数据到 MySQL 数据库:
```java
private void saveDataToDatabase(String message) {
// 解析温湿度数据
String[] parts = message.split(":");
double temperature = Double.parseDouble(parts[1].trim());
double humidity = Double.parseDouble(parts[3].trim());
try {
// 连接数据库
Connection connection = DriverManager.getConnection(DB_URL, DB_USERNAME, DB_PASSWORD);
// 准备 SQL 语句
String sql = "INSERT INTO humiture_data (temperature, humidity) VALUES (?, ?)";
PreparedStatement statement = connection.prepareStatement(sql);
// 设置参数
statement.setDouble(1, temperature);
statement.setDouble(2, humidity);
// 执行 SQL 语句
statement.executeUpdate();
// 关闭连接和语句
statement.close();
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
```
8. 在 `HumitureDataTransfer` 类中添加主方法,用于启动串口监听和数据库连接:
```java
public static void main(String[] args) {
try {
// 获取串口标识符
CommPortIdentifier portIdentifier = CommPortIdentifier.getPortIdentifier(PORT_NAME);
// 打开串口
SerialPort serialPort = (SerialPort) portIdentifier.open("HumitureDataTransfer", TIMEOUT);
// 配置串口
serialPort.setSerialPortParams(BAUD_RATE, SerialPort.DATABITS_8, SerialPort.STOPBITS_1, SerialPort.PARITY_NONE);
// 创建串口监听器
SerialListener listener = new SerialListener();
serialPort.addEventListener(listener);
serialPort.notifyOnDataAvailable(true);
} catch (Exception e) {
e.printStackTrace();
}
}
```
9. 替换代码中的数据库连接信息,确保与你的 MySQL 数据库设置相匹配。
10. 运行 `HumitureDataTransfer` 类,开始监听串口数据,并将温湿度数据保存到 MySQL 数据库中。
请注意,以上代码仅提供了一个基本的实现示例,你可能需要根据你的具体需求进行进一步的修改和优化。还要确保你已经安装并配置了 RXTXcomm 库,并且你的串口号正确匹配。
阅读全文