IDEA启动报错【java.sql.SQLException: Unknown error 1045】

IDEA启动报错SQLException 1045:
在这里插入图片描述
原因:application.properties
在这里插入图片描述
检查配置文件里面连接数据库的URL,用户名和密码是否正确!!!
在这里插入图片描述
确保是连接的用户名和密码正确且数据库名称正确即可解决此问题。

在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 } 请详细描述操作过程,包括如何导入库,导入什么库,并将完整代码写出。
07-20
要将串口传输的温湿度数据传输到 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 库,并且你的串口号正确匹配。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值