基于STM32的智能工厂环境监测系统

目录

  1. 引言
  2. 环境准备
  3. 智能工厂环境监测系统基础
  4. 代码实现:实现智能工厂环境监测系统
    • 4.1 数据采集模块
    • 4.2 数据处理
    • 4.3 控制系统实现
    • 4.4 用户界面与数据可视化
  5. 应用场景:智能工厂管理与优化
  6. 问题解决方案与优化
  7. 收尾与总结

1. 引言

智能工厂环境监测系统通过使用STM32嵌入式系统,结合多种传感器和控制设备,实现对工厂环境的实时监测和自动化控制。本文将详细介绍如何在STM32系统中实现一个智能工厂环境监测系统,包括环境准备、系统架构、代码实现、应用场景及问题解决方案和优化方法。

2. 环境准备

硬件准备

  • 开发板:STM32F407 Discovery Kit
  • 调试器:ST-LINK V2或板载调试器
  • 温湿度传感器:如DHT22
  • 气体传感器:如MQ-135
  • 噪音传感器:如LM393
  • PM2.5传感器:如SDS011
  • 显示屏:如OLED显示屏
  • 通风和排气控制模块:用于控制通风和排气
  • 按键或旋钮:用于用户输入和设置
  • 电源:12V或24V电源适配器

软件准备

  • 集成开发环境(IDE):STM32CubeIDE或Keil MDK
  • 调试工具:STM32 ST-LINK Utility或GDB
  • 库和中间件:STM32 HAL库

安装步骤

  1. 下载并安装 STM32CubeMX
  2. 下载并安装 STM32CubeIDE
  3. 配置STM32CubeMX项目并生成STM32CubeIDE项目
  4. 安装必要的库和驱动程序

3. 智能工厂环境监测系统基础

控制系统架构

智能工厂环境监测系统由以下部分组成:

  • 数据采集模块:用于采集温湿度、气体浓度、噪音和PM2.5数据
  • 数据处理模块:对采集的数据进行处理和分析
  • 控制系统:根据处理结果控制通风和排气设备
  • 显示系统:用于显示环境状态和系统信息
  • 用户输入系统:通过按键或旋钮进行设置和调整

功能描述

通过温湿度传感器、气体传感器、噪音传感器和PM2.5传感器采集工厂环境数据,并实时显示在OLED显示屏上。系统根据设定的阈值自动控制通风和排气设备,实现工厂环境的自动化管理。用户可以通过按键或旋钮进行设置,并通过显示屏查看当前状态。

4. 代码实现:实现智能工厂环境监测系统

4.1 数据采集模块

配置DHT22温湿度传感器
使用STM32CubeMX配置GPIO接口:

  1. 打开STM32CubeMX,选择您的STM32开发板型号。
  2. 在图形化界面中,找到需要配置的GPIO引脚,设置为输入模式。
  3. 生成代码并导入到STM32CubeIDE中。

代码实现:

初始化DHT22传感器并读取数据:

#include "stm32f4xx_hal.h"
#include "dht22.h"

#define DHT22_PIN GPIO_PIN_0
#define GPIO_PORT GPIOA

void GPIO_Init(void) {
    __HAL_RCC_GPIOA_CLK_ENABLE();

    GPIO_InitTypeDef GPIO_InitStruct = {0};
    GPIO_InitStruct.Pin = DHT22_PIN;
    GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    HAL_GPIO_Init(GPIO_PORT, &GPIO_InitStruct);
}

void DHT22_Init(void) {
    DHT22_Init(DHT22_PIN, GPIO_PORT);
}

void Read_Temperature_Humidity(float* temperature, float* humidity) {
    DHT22_ReadData(temperature, humidity);
}

int main(void) {
    HAL_Init();
    SystemClock_Config();
    GPIO_Init();
    DHT22_Init();

    float temperature, humidity;

    while (1) {
        Read_Temperature_Humidity(&temperature, &humidity);
        HAL_Delay(1000);
    }
}

配置MQ-135气体传感器
使用STM32CubeMX配置ADC接口:

  1. 打开STM32CubeMX,选择您的STM32开发板型号。
  2. 在图形化界面中,找到需要配置的ADC引脚,设置为输入模式。
  3. 生成代码并导入到STM32CubeIDE中。

代码实现:

初始化MQ-135传感器并读取数据:

#include "stm32f4xx_hal.h"

ADC_HandleTypeDef hadc1;

void ADC_Init(void) {
    __HAL_RCC_ADC1_CLK_ENABLE();

    ADC_ChannelConfTypeDef sConfig = {0};

    hadc1.Instance = ADC1;
    hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4;
    hadc1.Init.Resolution = ADC_RESOLUTION_12B;
    hadc1.Init.ScanConvMode = DISABLE;
    hadc1.Init.ContinuousConvMode = ENABLE;
    hadc1.Init.DiscontinuousConvMode = DISABLE;
    hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
    hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
    hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
    hadc1.Init.NbrOfConversion = 1;
    hadc1.Init.DMAContinuousRequests = DISABLE;
    hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
    HAL_ADC_Init(&hadc1);

    sConfig.Channel = ADC_CHANNEL_1;
    sConfig.Rank = 1;
    sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES;
    HAL_ADC_ConfigChannel(&hadc1, &sConfig);
}

uint32_t Read_Gas_Concentration(void) {
    HAL_ADC_Start(&hadc1);
    HAL_ADC_PollForConversion(&hadc1, HAL_MAX_DELAY);
    return HAL_ADC_GetValue(&hadc1);
}

int main(void) {
    HAL_Init();
    SystemClock_Config();
    ADC_Init();

    uint32_t gas_concentration;

    while (1) {
        gas_concentration = Read_Gas_Concentration();
        HAL_Delay(1000);
    }
}

配置LM393噪音传感器
使用STM32CubeMX配置ADC接口:

  1. 打开STM32CubeMX,选择您的STM32开发板型号。
  2. 在图形化界面中,找到需要配置的ADC引脚,设置为输入模式。
  3. 生成代码并导入到STM32CubeIDE中。

代码实现:

初始化LM393传感器并读取数据:

#include "stm32f4xx_hal.h"

ADC_HandleTypeDef hadc2;

void ADC2_Init(void) {
    __HAL_RCC_ADC2_CLK_ENABLE();

    ADC_ChannelConfTypeDef sConfig = {0};

    hadc2.Instance = ADC2;
    hadc2.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4;
    hadc2.Init.Resolution = ADC_RESOLUTION_12B;
    hadc2.Init.ScanConvMode = DISABLE;
    hadc2.Init.ContinuousConvMode = ENABLE;
    hadc2.Init.DiscontinuousConvMode = DISABLE;
    hadc2.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
    hadc2.Init.ExternalTrigConv = ADC_SOFTWARE_START;
    hadc2.Init.DataAlign = ADC_DATAALIGN_RIGHT;
    hadc2.Init.NbrOfConversion = 1;
    hadc2.Init.DMAContinuousRequests = DISABLE;
    hadc2.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
    HAL_ADC_Init(&hadc2);

    sConfig.Channel = ADC_CHANNEL_2;
    sConfig.Rank = 1;
    sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES;
    HAL_ADC_ConfigChannel(&hadc2, &sConfig);
}

uint32_t Read_Noise_Level(void) {
    HAL_ADC_Start(&hadc2);
    HAL_ADC_PollForConversion(&hadc2, HAL_MAX_DELAY);
    return HAL_ADC_GetValue(&hadc2);
}

int main(void) {
    HAL_Init();
    SystemClock_Config();
    ADC2_Init();

    uint32_t noise_level;

    while (1) {
        noise_level = Read_Noise_Level();
        HAL_Delay(1000);
    }
}

配置SDS011 PM2.5传感器
使用STM32CubeMX配置UART接口:

  1. 打开STM32CubeMX,选择您的STM32开发板型号。
  2. 在图形化界面中,找到需要配置的UART引```c
  3. 找到需要配置的UART引脚,设置为UART模式。
  4. 生成代码并导入到STM32CubeIDE中。

代码实现:

初始化SDS011传感器并读取数据:

#include "stm32f4xx_hal.h"
#include "sds011.h"

UART_HandleTypeDef huart1;

void UART_Init(void) {
    __HAL_RCC_USART1_CLK_ENABLE();

    huart1.Instance = USART1;
    huart1.Init.BaudRate = 9600;
    huart1.Init.WordLength = UART_WORDLENGTH_8B;
    huart1.Init.StopBits = UART_STOPBITS_1;
    huart1.Init.Parity = UART_PARITY_NONE;
    huart1.Init.Mode = UART_MODE_TX_RX;
    huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
    huart1.Init.OverSampling = UART_OVERSAMPLING_16;
    HAL_UART_Init(&huart1);
}

void SDS011_Init(void) {
    SDS011_Init(&huart1);
}

void Read_PM25(float* pm25, float* pm10) {
    SDS011_Read(&huart1, pm25, pm10);
}

int main(void) {
    HAL_Init();
    SystemClock_Config();
    UART_Init();
    SDS011_Init();

    float pm25, pm10;

    while (1) {
        Read_PM25(&pm25, &pm10);
        HAL_Delay(1000);
    }
}

4.2 数据处理

数据处理模块将传感器数据转换为可用于控制系统的数据,并进行必要的计算和分析。此处示例简单的处理和分析功能。

void Process_Sensor_Data(float temperature, float humidity, uint32_t gas_concentration, uint32_t noise_level, float pm25, float pm10) {
    // 数据处理和分析逻辑
    // 例如:计算空气质量指数、判断环境状态等
}

4.3 控制系统实现

配置GPIO控制通风和排气设备
使用STM32CubeMX配置GPIO:

  1. 打开STM32CubeMX,选择您的STM32开发板型号。
  2. 在图形化界面中,找到需要配置的GPIO引脚,设置为输出模式。
  3. 生成代码并导入到STM32CubeIDE中。

代码实现:

初始化通风和排气设备控制引脚:

#include "stm32f4xx_hal.h"

#define VENT_PIN GPIO_PIN_0
#define EXHAUST_PIN GPIO_PIN_1
#define GPIO_PORT GPIOB

void GPIO_Init(void) {
    __HAL_RCC_GPIOB_CLK_ENABLE();

    GPIO_InitTypeDef GPIO_InitStruct = {0};
    GPIO_InitStruct.Pin = VENT_PIN | EXHAUST_PIN;
    GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
    HAL_GPIO_Init(GPIO_PORT, &GPIO_InitStruct);
}

void Control_Vent(uint8_t state) {
    HAL_GPIO_WritePin(GPIO_PORT, VENT_PIN, state ? GPIO_PIN_SET : GPIO_PIN_RESET);
}

void Control_Exhaust(uint8_t state) {
    HAL_GPIO_WritePin(GPIO_PORT, EXHAUST_PIN, state ? GPIO_PIN_SET : GPIO_PIN_RESET);
}

int main(void) {
    HAL_Init();
    SystemClock_Config();
    GPIO_Init();
    DHT22_Init();
    ADC_Init();
    ADC2_Init();
    UART_Init();
    SDS011_Init();

    float temperature, humidity;
    uint32_t gas_concentration, noise_level;
    float pm25, pm10;

    while (1) {
        // 读取传感器数据
        Read_Temperature_Humidity(&temperature, &humidity);
        gas_concentration = Read_Gas_Concentration();
        noise_level = Read_Noise_Level();
        Read_PM25(&pm25, &pm10);

        // 数据处理
        Process_Sensor_Data(temperature, humidity, gas_concentration, noise_level, pm25, pm10);

        // 根据处理结果控制通风和排气设备
        if (temperature > 30.0) {
            Control_Vent(1);  // 打开通风设备
        } else {
            Control_Vent(0);  // 关闭通风设备
        }

        if (gas_concentration > 100 || pm25 > 75.0) {
            Control_Exhaust(1);  // 打开排气设备
        } else {
            Control_Exhaust(0);  // 关闭排气设备
        }

        HAL_Delay(1000);
    }
}

4.4 用户界面与数据可视化

配置OLED显示屏
使用STM32CubeMX配置I2C接口:

  1. 打开STM32CubeMX,选择您的STM32开发板型号。
  2. 在图形化界面中,找到需要配置的I2C引脚,设置为I2C模式。
  3. 生成代码并导入到STM32CubeIDE中。

代码实现:

首先,初始化OLED显示屏:

#include "stm32f4xx_hal.h"
#include "i2c.h"
#include "oled.h"

void Display_Init(void) {
    OLED_Init();
}

然后实现数据展示函数,将工厂环境数据展示在OLED屏幕上:

void Display_Factory_Data(float temperature, float humidity, uint32_t gas_concentration, uint32_t noise_level, float pm25, float pm10) {
    char buffer[32];
    sprintf(buffer, "Temp: %.2f C", temperature);
    OLED_ShowString(0, 0, buffer);
    sprintf(buffer, "Humidity: %.2f %%", humidity);
    OLED_ShowString(0, 1, buffer);
    sprintf(buffer, "Gas: %d ppm", gas_concentration);
    OLED_ShowString(0, 2, buffer);
    sprintf(buffer, "Noise: %d dB", noise_level);
    OLED_ShowString(0, 3, buffer);
    sprintf(buffer, "PM2.5: %.2f", pm25);
    OLED_ShowString(0, 4, buffer);
    sprintf(buffer, "PM10: %.2f", pm10);
    OLED_ShowString(0, 5, buffer);
}

在主函数中,初始化系统并开始显示数据:

int main(void) {
    HAL_Init();
    SystemClock_Config();
    GPIO_Init();
    DHT22_Init();
    ADC_Init();
    ADC2_Init();
    UART_Init();
    SDS011_Init();
    Display_Init();

    float temperature, humidity;
    uint32_t gas_concentration, noise_level;
    float pm25, pm10;

    while (1) {
        // 读取传感器数据
        Read_Temperature_Humidity(&temperature, &humidity);
        gas_concentration = Read_Gas_Concentration();
        noise_level = Read_Noise_Level();
        Read_PM25(&pm25, &pm10);

        // 显示工厂环境数据
        Display_Factory_Data(temperature, humidity, gas_concentration, noise_level, pm25, pm10);

        // 根据传感器数据控制通风和排气设备
        if (temperature > 30.0) {
            Control_Vent(1);  // 打开通风设备
        } else {
            Control_Vent(0);  // 关闭通风设备
        }

        if (gas_concentration > 100 || pm25 > 75.0) {
            Control_Exhaust(1);  // 打开排气设备
        } else {
            Control_Exhaust(0);  // 关闭排气设备
        }

        HAL_Delay(1000);
    }
}

5. 应用场景:智能工厂管理与优化

工厂环境监测

智能工厂环境监测系统可以应用于工厂,通过实时监测温度、湿度、气体浓度、噪音和PM2.5浓度,确保工厂环境的安全和舒适。

工业安全管理

在工业安全管理中,智能工厂环境监测系统可以帮助监测有害气体浓度,及时预警和采取措施,保障工人安全。

环境质量控制

智能工厂环境监测系统可以用于环境质量控制,通过实时监测和数据分析,优化通风和排气系统,提高环境质量。

数据记录与分析

在工厂管理中,智能工厂环境监测系统可以记录环境数据,进行长期数据分析,为环境改进和管理决策提供支持。

⬇帮大家整理了单片机的资料

包括stm32的项目合集【源码+开发文档】

点击下方蓝字即可领取,感谢支持!⬇

点击领取更多嵌入式详细资料

问题讨论,stm32的资料领取可以私信!

 

6. 问题解决方案与优化

常见问题及解决方案

  1. 传感器数据不准确:确保传感器与STM32的连接稳定,定期校准传感器以获取准确数据。

    • 解决方案:检查传感器与STM32之间的连接是否牢固,必要时重新焊接或更换连接线。同时,定期对传感器进行校准,确保数据准确。
  2. 设备响应延迟:优化控制逻辑和硬件配置,减少设备响应时间,提高系统反应速度。

    • 解决方案:优化传感器数据采集和处理流程,减少不必要的延迟。使用DMA(直接存储器访问)来提高数据传输效率,减少CPU负担。选择速度更快的处理器和传感器,提升整体系统性能。
  3. 显示屏显示异常:检查I2C通信线路,确保显示屏与MCU之间的通信正常,避免由于线路问题导致的显示异常。

    • 解决方案:检查I2C引脚的连接是否正确,确保电源供电稳定。使用示波器检测I2C总线信号,确认通信是否正常。如有必要,更换显示屏或MCU。
  4. 传感器读数波动大:增加数据滤波算法,平滑传感器读数,减少瞬间波动带来的影响。

    • 解决方案:在数据处理模块中增加简单的平均滤波或中值滤波算法,对传感器读数进行平滑处理,减少数据波动。
  5. 电池续航时间短:优化系统功耗设计,提高电池续航时间。

    • 解决方案:使用低功耗模式(如STM32的STOP模式)降低系统功耗。选择容量更大的电池,并优化电源管理策略,减少不必要的电源消耗。

优化建议

  1. 数据集成与分析:集成更多类型的传感器数据,使用大数据分析技术进行工厂环境状态的预测和优化。

    • 建议:增加更多环境传感器,如CO2传感器、VOCs传感器等。使用云端平台进行数据分析和存储,提供更全面的环境监测和管理服务。
  2. 用户交互优化:改进用户界面设计,提供更直观的数据展示和更简洁的操作界面,增强用户体验。

    • 建议:使用高分辨率彩色显示屏,提供更丰富的视觉体验。设计简洁易懂的用户界面,让用户更容易操作。提供图形化的数据展示,如实时图表、环境地图等。
  3. 智能化控制提升:增加智能决策支持系统,根据历史数据和实时数据自动调整工厂环境管理策略,实现更高效的环境控制。

    • 建议:使用数据分析技术分析环境数据,提供个性化的控制建议。结合历史数据,预测可能的环境变化和风险,提前调整管理策略。

7. 收尾与总结

本教程详细介绍了如何在STM32嵌入式系统中实现智能工厂环境监测系统,从硬件选择、软件实现到系统配置和应用场景都进行了全面的阐述。通过合理的技术选择和系统设计,可以构建一个高效且功能强大的智能工厂环境监测系统。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/733943.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AI语言文字工具类API实现自动化的写作

热门实用的AI语言文字工具类API是当今开发者们追逐的宝藏。这些API利用先进的人工智能和自然语言处理技术,为开发者提供了一系列实用而强大的语言文字处理能力。这些API包括了文本翻译、情感分析、智能写作、关键词提取、语言检测等功能,使得开发者能够轻…

Vue82-组件内路由守卫

一、组件内路由守卫的定义 在一个组件里面去写路由守卫&#xff0c;而不是在路由配置文件index.js中去写。 此时&#xff0c;该路由守卫是改组件所独有的&#xff01; 只有通过路由规则进入的方式&#xff0c;才会调这两个函数&#xff0c;否则&#xff0c;若是只是用<Ab…

C# 实现去除多行文本框光标闪烁,并设置行距

一、前言 本篇主要通过继承RichTextBox 的方式实现去除多行文本框的光标闪烁&#xff0c;以及能够设置行距大小&#xff0c;这是因为C#提供的TextBox 和 RichTextBox 本身无这样的功能 二、代码 封装 RichTextBox 为CustomTextBox using System; using System.Collections.Ge…

MinIO 网络与覆盖网络

云计算和容器化技术的发展改变了应用程序的开发、部署和管理方式。这种转变给网络环境带来了重大变化&#xff0c;为DevOps和SRE工程师带来了新的挑战和机遇。然而&#xff0c;在这种转变中&#xff0c;出现了明显的知识差距&#xff0c;特别是在理解物理网络和硬件背景下网络的…

【免费】中国电子学会2024年03月份青少年软件编程Python等级考试试卷一级真题(含答案)

2024-03 Python一级真题 分数&#xff1a;100 题数&#xff1a;37 测试时长&#xff1a;60min 一、单选题(共25题&#xff0c;共50分) 1. 下列哪个命令&#xff0c;可以将2024转换成2024 呢&#xff1f;&#xff08; A&#xff09;(2分) A.str(2024) B.int(2024) C.fl…

教育培训机构寒暑假班学校公众号小程序

&#x1f4da;教育培训学校公众号版本&#xff1a;开启学习新纪元&#x1f680; 一、引言&#xff1a;为何教育培训学校需要公众号版本&#xff1f; 随着数字化时代的来临&#xff0c;传统教育培训行业也在不断探索新的服务模式。公众号作为新媒体平台的一种&#xff0c;具有信…

CentOS 7 安装部署Cassandra4.1.5

一、Cassandra的介绍 Cassandra是一套开源分布式NoSQL数据库系统。它最初由Facebook开发&#xff0c;用于储存收件箱等简单格式数据&#xff0c;集GoogleBigTable的数据模型与Amazon Dynamo的完全分布式的架构于一身Facebook于2008将 Cassandra 开源&#xff0c;此后&#xff0…

如何解决压缩软件无法打开文件的常见问题

压缩软件是我们日常生活和工作中常用的工具&#xff0c;无论是传输文件、节省存储空间还是组织数据&#xff0c;它们都能发挥重要作用。然而&#xff0c;偶尔也会遇到压缩软件无法打开文件的情况&#xff0c;这可能令人困惑和沮丧。本文将探讨几种常见原因&#xff0c;并提供解…

计算机网络(物理层)

物理层 物理层最核心的工作内容就是解决比特流在线路上传输的问题 基本概念 何为物理层&#xff1f;笼统的讲&#xff0c;就是传输比特流的。 可以着重看一下物理层主要任务的特性 传输媒体 传输媒体举例&#xff1a; 引导型传输媒体 引导型传输媒体指的是信号通过某种…

数字营销新玩法:拓新与裂变的完美结合

在当今这个飞速发展的数字化时代&#xff0c;数字营销已经成为了企业发展中至关重要的一环。拓新&#xff0c;简单来说就是不断去开拓新的客户群体&#xff0c;让更多的人了解并接触到我们的产品或服务。要做到这一点&#xff0c;那可得充分利用各种线上渠道。像热闹非凡的社交…

Intel太无耻,跟着玩数字游戏还揭台积电的老底,工艺都是假的

在台积电的3纳米逐渐获得芯片企业认可的情况下&#xff0c;近日Intel却再次指出台积电的3纳米工艺并非真正的3纳米&#xff0c;与Intel的7纳米工艺差不多&#xff0c;这显示出Intel在芯片工艺研发方面日益落后的情况下确实有点慌了。 Intel指出它的7纳米工艺的晶体管密度达到1.…

通用大模型的低代码平台——3分钟内快速搭建一个邮件提醒工具

文章目录 ⭐前言⭐node-koa开发一个发送邮件的api⭐百度智能云控制面板&#x1f496; 发送邮件的组件配置&#x1f496; 配置应用发布 ⭐总结⭐结束 ⭐前言 大家好&#xff0c;我是yma16&#xff0c;通用大模型的低代码平台——3分钟内快速搭建一个智能股票分析邮件提醒工具。…

步步精:连接器领域的卓越品牌

自1987年成立以来&#xff0c;步步精坐落于美丽的旅游城市——温州市乐清虹桥镇&#xff0c;被誉为“国家电子主体生产基地”、“国家精密模具制造基地”。公司拥有7大厂区、9大事业部&#xff0c;800名专职员工&#xff0c;致力于提供高品质的连接器解决方案。注册商标“BBJCO…

力扣SQL50 查询结果的质量和占比 AVG(条件)

Problem: 1211. 查询结果的质量和占比 &#x1f468;‍&#x1f3eb; 参考题解 Code select query_name,round(avg(rating/position),2) as quality,round(100 * avg(rating < 3), 2) as poor_query_percentage from Queries group by query_name -- 到此结束过不了最后一…

【索引】数据库索引之顺序索引概述

目录 1、索引的基本概念 2、顺序索引 3、稠密索引和稀疏索引 3.1 什么是稠密索引&#xff1f; 3.2 什么是稀疏索引&#xff1f; 4、索引的更新 4.1 索引的插入操作 4.1 索引的删除操作 5、辅助索引 1、索引的基本概念 数据库中的索引与图书馆中书的索引作用相同&#xf…

echarts Y轴展示时间片段,series data数据 也是时间片段,鼠标放上去 提示框显示对应的时间片段

功能要求 1、折线图&#xff0c;展示每天对应的一个时间片段 2、echarts Y轴展示时间片段&#xff0c;如&#xff1a;[00:00,03:00,05:15] 3、X轴展示日期&#xff0c;如&#xff1a;[xx年xx月xx日] 后端返回的数据结构&#xff0c;如 [{xAdate:"2024-06-15",data:…

汽车OTA--Flash RWW属性为什么这么重要

目录 1. OTA与RWW 1.1 FOTA需求解读 1.2 什么是RWW 2.主流OTA方案 2.1 单Bank升级 2.2 基于硬件A\B SWAP的FOTA方案 2.3 基于软件实现的FOTA方案 3.小结 1. OTA与RWW 1.1 FOTA需求解读 CP AUTOSAR R19-11首次提出了FOTA的概念&#xff0c;针对FOTA Target ECU提出了多…

《计算机英语》 Unit 3 Software Engineering 软件工程

Section A Software Engineering Methodologies 软件工程方法论 Software development is an engineering process. 软件开发是一个工程过程。 The goal of researchers in software engineering is to find principles that guide the software development process and lea…

2024年全国青少信息素养大赛python编程复赛集训第九天编程题分享

整理资料解析答案非常不容易,感谢各位大佬给个点赞和分享吧,谢谢 今天题目较简单:适合小学组 大家如果不想阅读前边的比赛内容介绍,可以直接跳过:拉到底部看集训题目 (一)比赛内容: 【小学组】 1.了解输入与输出的概念,掌握使用基本输入输出和简单运算 为主的标准…

集合注意事项

目录 我们为什么要用到集合中的迭代器 List实现类的循环遍历 Set集合 HashSet TreeSet Map Hashmap Treemap Hashtable map的遍历方式 Collections的一些静态方法 我们为什么要用到集合中的迭代器 List实现类的循环遍历 如图我们对arraylist中加入了三个相同的“a”…