STM32多功能交通灯系统:从原理到实现

一、功能说明

本交通灯系统采用先进的stm32f103c8t6微处理器为核心控制单元。系统设置东南西北四个方向各配置两位数码管,用以精准展示5至99秒的时间范围,并且允许用户根据实际需求进行灵活调整。

在信号灯配置方面,每个方向均配备左转、直行、黄灯和红灯共计四个灯,以确保交通信号的有效传递。同时,南北方向和东西方向均安装红外对管装置,分别用于实时监测车流量,为交通管理提供重要数据支持。

此外,本系统还设置紧急按钮功能。一旦触发紧急按钮,系统将立即响应,将行车方向的所有信号灯切换为红灯状态,同时人行道方向信号灯全部转为绿灯状态,以确保紧急情况下的交通安全。紧急模式可通过再次按下紧急按钮解除。

在时间调整方面,本系统具备智能化管理能力,能够根据实时监测到的车流量数据,进行动态调整,以实现交通流的高效管理和优化。

综上所述,本交通灯系统通过严谨、稳重的设计,以及理性的管理策略,为提升道路交通安全性与通行效率提供了有力保障。

二、硬件设计

2.1 原理框图

2.2 各功能框图说明

2.2.1 MCU最小系统

1、该MCU采用了ST的STM32F103C8T6 LQFP48封装,以下是其主要特点:

核心:采用ARM® Cortex®-M3 32位RISC核心,最高频率可达72MHz。

存储器:提供64K字节的Flash存储器和20K字节的SRAM。

电源管理:支持2.0至3.6V的应用供电和I/Os,具有POR、PDR和可编程电压检测器(PVD)。

低功耗模式:包括睡眠、停止和待机模式,适合设计低功耗应用。

丰富的外设:提供两个12位ADC,三个通用16位定时器加一个PWM定时器,以及标准和高级通信接口:最多两个I2C和SPIs,三个USARTs,一个USB和一个CAN。

2、在单片机每个电源输入部分增加一个100nF的旁路电容,其主要功能包括:

a) 滤除电源上的高频噪声。

b) 储能,当负载需要瞬时电流时,电容率先为其提供电流,减小电源产生的波动。

c) 给高频信号提供最近的低阻抗回流路径,减少对其他芯片电源的干扰。

3、BOOT0和BOOT1的作用:

这两个引脚在芯片复位时的电平状态决定了芯片复位后从哪个区域开始执行程序。

用户可以通过设置BOOT1和BOOT0引脚的状态来选择在复位后的启动模式。

三种启动模式:

Flash memory启动方式(BOOT0 = 0):默认情况下,芯片从内置Flash启动。这是最常用的模式,我们通常使用JTAG或SWD模式下载程序到Flash中,重启后直接从Flash启动。

System memory启动方式(BOOT0 = 1,BOOT1 = 0):从系统存储器启动,这种模式的功能由厂家设置。系统存储器是芯片内部的特定区域,出厂时预置了一个BootLoader,用于串口下载程序到Flash中。这种模式用得较少。

SRAM启动方式(BOOT0 = 1,BOOT1 = 1):从内置SRAM启动,用于程序调试。在这种模式下,代码存储在SRAM中,适用于快速的程序调试。

4、晶振电路

晶体采用8MHz,并联22pf电容,电容与晶振一起形成一个振荡回路,其值需要与晶振的指定负载电容相匹配,以确保晶振在正确的频率下稳定工作。

1M电阻的作用

提供启动振荡:1MΩ电阻有助于晶体振荡器在上电时能够迅速启动振荡。它通过提供一个初始的反馈路径来实现这一点,尤其是在环境温度较低时,晶体振荡器可能更难启动。

增加负性阻抗:并联的1MΩ电阻可以增加电路中的负性阻抗(-R),这有助于提高电路的增益。在没有足够增益的条件下,晶体振荡器可能不会启动。

抑制噪声:这个电阻还可以起到抑制共模噪声的作用,提高系统的抗干扰能力。它有助于减少由于电源线或其他干扰源引入的噪声,从而使晶体振荡器的输出更加稳定。

减少谐波振荡:1MΩ电阻有助于消除晶体振荡器件的谐波振荡,使晶体的输出信号更加纯净和稳定。

5、复位电路

当系统上电时,电容会从0V开始充电,这会导致复位引脚短暂地处于低电平状态,从而触发复位。电容充电后,复位引脚电平逐渐上升到高电平,结束复位过程,允许微控制器开始正常工作。

2.2.2 电源电路 

 电源电路采用LDO AMS1117-3.3将+5V直流电转+3.3V直流电。该LDO具有低纹波噪声功能,确保系统的稳定性和可靠性。电路图描述如下:

USB1 - USB +5V供电接口

SW1 - 电源开关

D1 - 通过利用该器件的非线性特性,将过电压钳制到一个较低的电压值,实现对后级电路的保护。

U1 - LDO,将+5V转为+3.3V

C1/C2/C3/C4 - 主要用于滤除由电源输出的直流电压中所含的杂波和噪声,并将其平滑处理为一个稳定的直流电压输出

R1 - 限流电阻

LED1 - 电源指示灯

2.2.3 按键电路

按键电路采用点触按键,当用户按下按键时,电路会检测到按键的接触,并产生低电平信号,从而触发相应的操作。电路图描述如下:

SW2/SW3/SW4/SW5 - 点触按键,点触按键的工作原理:按钮与触点机械作用,按下按钮,弹簧收缩,触点接触导电条,电路接通;松开按钮,弹簧恢复原状,触点离开导电条,电路断开。 

2.2.4 红外对管检测电路 

红外发射二极管(LED)不断发射红外光束,红外检测二极管(PD)接收来自LED的红外光束,当LED发出的红外光束命中目标物体时,部分红外光束会被物体反射回给PD。不同的反射强度输出的电压大小不同。

LM339 是一个内部集成了四路比较器的集成电路。比较器有两个输入端和一个输出端。其中,一个输入端称为同输入端(用“+”号表示),另一个称为反相输入端(用“-”表示)。当“+”端电压高于“-”端电压时,输出正电源电压;反之,输出负电源电压。

单片机通过监测OUT1和OUT2输出的电平信号,以精确判断是否有车辆通行。在车辆经过时,红外光线被有效反射,导致OUT输出低电平状态。此外,红外检测的灵敏度可经由调整R29和R30之间的分压比例来进行精确控制。

2.2.5 交通灯电路 

 交通灯电路采用普通的5mm发光二极管加上限流电阻组成。

2.2.6 OLED显示电路

采用0.96寸OLED显示屏以展示交通灯车流量信息,同时,在设置交通灯时间的过程中,也运用OLED实现人机交互功能。

2.2.7 数码管显示电路

数码管的驱动方式采用了GN1640T驱动芯片,而东南西北四个方向则均选用了0.36英寸共阴双八红色数码管,以实现倒计时时间的精准显示。

 三、软件设计

在主函数中,首先进行外设的初始化操作。随后,在while循环中,app_handle()函数负责处理交通灯和车流量的相关工作。同时,key_handle()函数则专注于处理与按键相关的操作。另外,oled_handle()函数则负责处理人机界面的交互功能。

 3.1 app_handle()

app_handle()函数进行交通灯信号的处理和数码管的显示,交通信号灯一个循环结束后会进行车流量的比较计算,然后重新更新东西和南北的交通灯通行时间。

traffic_light_handle()主要对交通灯的状态进行处理。

void traffic_light_handle(void)
{switch(step){case 0: //东西直行EW_STRAIGHT_RED_LED      	= LOW;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= HIGH;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= LOW;	//东西直行黄灯EW_LEFT_GREEN_LED			= LOW;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= LOW;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= HIGH;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= HIGH;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= LOW;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= LOW;	//南北直行黄灯NS_LEFT_GREEN_LED			= LOW;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= HIGH;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= LOW;	//南北人行道红灯break;case 1://东西黄灯 EW_STRAIGHT_RED_LED      	= LOW;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= LOW;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= HIGH;	//东西直行黄灯EW_LEFT_GREEN_LED			= LOW;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= LOW;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= HIGH;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= HIGH;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= LOW;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= LOW;	//南北直行黄灯NS_LEFT_GREEN_LED			= LOW;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= HIGH;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= LOW;	//南北人行道红灯	break;case 2://东西左转 EW_STRAIGHT_RED_LED      	= LOW;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= LOW;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= LOW;	//东西直行黄灯EW_LEFT_GREEN_LED			= HIGH;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= LOW;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= HIGH;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= HIGH;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= LOW;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= LOW;	//南北直行黄灯NS_LEFT_GREEN_LED			= LOW;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= HIGH;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= LOW;	//南北人行道红灯	break;case 3://南北直行EW_STRAIGHT_RED_LED      	= HIGH;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= LOW;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= LOW;	//东西直行黄灯EW_LEFT_GREEN_LED			= LOW;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= HIGH;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= LOW;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= LOW;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= HIGH;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= LOW;	//南北直行黄灯NS_LEFT_GREEN_LED			= LOW;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= LOW;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= HIGH;	//南北人行道红灯break;case 4://南北黄灯EW_STRAIGHT_RED_LED      	= HIGH;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= LOW;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= LOW;	//东西直行黄灯EW_LEFT_GREEN_LED			= LOW;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= HIGH;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= LOW;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= LOW;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= LOW;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= HIGH;	//南北直行黄灯NS_LEFT_GREEN_LED			= LOW;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= LOW;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= HIGH;	//南北人行道红灯break;case 5://南北左转EW_STRAIGHT_RED_LED      	= HIGH;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= LOW;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= LOW;	//东西直行黄灯EW_LEFT_GREEN_LED			= LOW;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= HIGH;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= LOW;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= LOW;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= LOW;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= LOW;	//南北直行黄灯NS_LEFT_GREEN_LED			= HIGH;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= LOW;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= HIGH;	//南北人行道红灯break;default: break;}			
}

3.2 key_handle() 

key_handle() 主要对交通灯通行时间进行调整。

void key_handle(void)
{if(flag_get(&key_flag,KEY4_PRESS_FLAG)){flag_clr(&key_flag,KEY4_PRESS_FLAG);set_num++;if(set_num > 2) set_num = 1;TIM_Cmd(TIM3, DISABLE);  //失能TIM3if(set_num == 1){inverse_oled_show_string(0,0,"SET EW:",8);oled_show_num(80,0,ew_time,2,8);}else{oled_show_string(0,0,"SET EW:",8);oled_show_num(80,0,ew_time,2,8);}if(set_num == 2){inverse_oled_show_string(1,2,"SET NS:",8);oled_show_num(80,2,ns_time,2,8);}else{oled_show_string(1,2,"SET NS:",8);oled_show_num(80,2,ns_time,2,8);}		}	else if(flag_get(&key_flag,KEY5_PRESS_FLAG)){flag_clr(&key_flag,KEY5_PRESS_FLAG);if(set_num == 1) {if(ew_time < MAX_TIME) ew_time++;}else if(set_num == 2) {if(ns_time < MAX_TIME) ns_time++;}oled_show_num(80,0,ew_time,2,8);oled_show_num(80,2,ns_time,2,8);}		else if(flag_get(&key_flag,KEY3_PRESS_FLAG)){flag_clr(&key_flag,KEY3_PRESS_FLAG);if(set_num == 1) {if(ew_time > MIN_TIME) ew_time--;}else if(set_num == 2) {if(ns_time > MIN_TIME) ns_time--;}oled_show_num(80,0,ew_time,2,8);oled_show_num(80,2,ns_time,2,8);}		else if(flag_get(&key_flag,KEY2_PRESS_FLAG)){flag_clr(&key_flag,KEY2_PRESS_FLAG);set_num = 0;step = 0;current_ew_time = ew_time;current_ns_time = ew_time + STRAIGHT_YELLOW_TIME_NUM + LEFT_GREEN_TIME_NUM;;oled_clear();TIM_Cmd(TIM3, ENABLE);  //使能TIM3}	if(flag_get(&key_flag,KEY1_PRESS_FLAG)){flag_clr(&key_flag,KEY1_PRESS_FLAG);if(stop_flag){stop_flag = 0;TIM_Cmd(TIM3, ENABLE);  //失能TIM3}else{stop_flag = 1;EW_STRAIGHT_RED_LED      	= HIGH;	//东西直行红灯EW_STRAIGHT_GREEN_LED   	= LOW;	//东西直行绿灯EW_STRAIGHT_YELLOW_LED   	= LOW;	//东西直行黄灯EW_LEFT_GREEN_LED			= LOW;	//东西左转绿灯EW_SIDEWALK_GREEN_LED      	= LOW;	//东西人行道绿灯EW_SIDEWALK_RED_LED      	= HIGH;	//东西人行道红灯NS_STRAIGHT_RED_LED      	= HIGH;	//南北直行红灯NS_STRAIGHT_GREEN_LED   	= LOW;	//南北直行绿灯NS_STRAIGHT_YELLOW_LED   	= LOW;	//南北直行黄灯NS_LEFT_GREEN_LED			= LOW;	//南北左转绿灯NS_SIDEWALK_GREEN_LED      	= LOW;	//南北人行道绿灯NS_SIDEWALK_RED_LED      	= HIGH;	//南北人行道红灯TIM_Cmd(TIM3, DISABLE);  //失能TIM3}}	
}

 3.3 oled_handle() 

OLED主要显示车流量信息和设置交通灯通行时间时进行人机信息交互。

四、实物演示

交通灯通行时间演示

交通灯通行时间演示

车流量检测演示

车流量检测演示

倒计时时间设置演示

倒计时时间设置演示

五、技术交流

如果您有更好的建议或者在阅读过程中遇到任何问题或疑虑,欢迎加我QQ ,一起探讨技术问题,我的QQ号是986571840,加的时候请注明CSDN。

感谢各位用户点赞、分享、在看,这些行为让知识得以更加广泛地传播,从而让更多人受益。

请在转载作品时注明出处,严禁抄袭行为。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SYD881X读取GATT VALUE的长度

SYD881X读取GATT VALUE的长度 现在具体遇到这样一个需要&#xff0c;机器生产后要更新profile&#xff0c;这个只能够通过升级4K来做&#xff0c;但是需要知道profile是否改变了&#xff0c;这个就要知道profile是否改变来决定是否要升级&#xff0c;这里的做法是增加一个函数&…

肩背筋膜炎怎么治疗最有效

肩背筋膜炎是一种常见的肌肉骨骼疾病&#xff0c;其症状主要包括&#xff1a;肩背区域疼痛&#xff1a;由于筋膜组织受到损伤&#xff0c;肩背部位会出现明显的疼痛&#xff0c;疼痛可能会放射到周围的其他部位&#xff0c;严重时会影响睡眠和休息。肌肉紧张和僵硬&#xff1a;…

嵌入式数据库_2.嵌入式数据库的一般架构

嵌入式数据库的架构与应用对象紧密相关&#xff0c;其架构是以内存、文件和网络等三种方式为主。 1.基于内存的数据库系统 基于内存的数据库系统中比较典型的产品是每个McObject公司的eXtremeDB嵌入式数据库&#xff0c;2013年3月推出5.0版&#xff0c;它采用内存数据结构&…

智能座舱中的HUD介绍

HUD&#xff08;Head Up Display&#xff0c;抬头显示系统&#xff09;是将车速、油耗、胎压等行车重要信息投影到前方挡风玻璃上的一套显示系统。HUD 最早应用在战斗机上&#xff0c;旨在降低飞行员低头查看仪表的频率&#xff0c;使得飞行员能在保证正常驾驶的同时&#xff0…

2002-2022年各省人口总抚养比数据(人口抽样调查)

2002-2022年各省人口总抚养比数据&#xff08;人口抽样调查&#xff09; 1、时间&#xff1a;2002-2022年 2、指标&#xff1a;总抚养比 3、来源&#xff1a;国家统计局、统计年鉴 4、范围&#xff1a;31省&#xff0c; 5、缺失情况&#xff1a;无缺失&#xff0c;其中201…

Git 和 TortoiseGit 安装和配置(图文详解)

使用git&#xff0c;需要在Windows上需要安装两个软件&#xff1a;1&#xff09;Git 2&#xff09;TortoiseGit 注意&#xff1a;tortoiseGit是在安装了Git的基础上运行的&#xff0c;所以需要先安装Git&#xff0c;后安装运行tortoiseGit。 因为&#xff0c;运行TortoiseGi…

Web3新视野:Lumoz节点的潜力与收益解读

摘要&#xff1a;低估值、高回报、无条件退款80%...... Lumoz正通过其 zkVerifier 节点销售活动&#xff0c;引领一场ZK计算革命。 长期以来&#xff0c;加密市场以其独特的波动性和增长潜力&#xff0c;持续吸引着全球投资者的目光。而历史数据表明&#xff0c;市场往往在一年…

六西格玛目标设定的时候需要考虑哪些因素?

在追求企业卓越绩效的道路上&#xff0c;六西格玛管理方法论以其严谨的数据驱动和持续改进的理念&#xff0c;成为众多企业的首选工具。然而&#xff0c;要想真正发挥六西格玛的潜力&#xff0c;合理而精准的目标设定至关重要。那么&#xff0c;六西格玛目标设定的时候需要考虑…

电商API接口详述:涵盖订单、库存等多功能接口介绍

电商商家自研管理系统&#xff0c;线下ERP系统或WMS系统想要接入电商平台订单打单发货&#xff0c;通过点三电商API可以一键对接多个电商平台&#xff0c;帮助商家、ERP/WMS服务商快速开发电商模块&#xff0c;实现电商业务管理功能&#xff0c;那么点三电商API接口有哪些可用接…

Stranger Lands - StampIT

作为StampIT!Collection的一部分,Stranger Lands包含30个高质量纹理,具有惊人的4K分辨率。这些高度图纹理可以用作Unity地形工具的画笔,以便在Unity地形上绘制特征。或者您可以在Atlas、Gaia、Map Magic 2、Vista等其他资源中使用这些高度图纹理。 该资源包含高度图和笔刷预…

Java多线程+线程池图文实例操作(源码自取)

目录 线程相关概念 并发 并行 继承Thread类 实现Runnable接口 实现Callable接口 使用ExecutorService 和线程池 多线程卖手机 非同步 同步机制卖手机 锁方法 锁代码块 ​编辑锁静态方法 锁静态代码块 线程常用方法 用户线程和守护线程 线程状态 线程池 自定…

视频监控管理平台的日志功能的重要性

日志功能的重要性 视频监控平台在日常工作生活中越来越重要&#xff0c;具有完备的平台日志&#xff0c;不仅可以增强视频监控系统的自身安全性&#xff0c;还能在更大程度上保障社会的安全与稳定。 &#xff08;一&#xff09;安全保障 视频监控平台作为安全防护…

第三十三章 添加和使用自定义标题元素

文章目录 第三十三章 添加和使用自定义标题元素SOAP 标头元素简介如何表示 SOAP 标头 第三十三章 添加和使用自定义标题元素 本主题介绍如何添加和使用自定义 SOAP 标头元素。 有关发生故障时添加标头元素的信息&#xff0c;请参阅 SOAP 故障处理。 WS-Addressing 标头元素在…

机器学习课程复习——集成学习

1. 基本概念 1.1. 定义 通过构建并结合多个个体学习器来完成学习任务,获得比单一学习器显著优越的泛化性能。 1.2. 分类 名称个体学习器例子同质集成基学习器Boosting、Bagging异质集成组件学习器Stacking1.3. 研究的核心 个体学习器的“准确性”和“多样性”本身就存在冲…

悬浮翻译app免费怎么操作?看完这篇文章就知道了

#高考结束该出发看世界了# 高考的钟声已落&#xff0c;是时候开启探索世界的旅程了。无论是踏上旅途&#xff0c;观看视频&#xff0c;阅读书籍&#xff0c;还是浏览网页资料&#xff0c;我们都有机会拓宽视野。 然而&#xff0c;语言常常成为我们与世界沟通的障碍。好在&…

设计模式学习之——单例模式

文章目录 单例模式什么叫做单例模式单例模式的动机 简单单例模式思考 饿汉式单例和懒汉式单例饿汉式单例懒汉式单例 单例模式总结1&#xff0e;主要优点2&#xff0e;主要缺点3&#xff0e;适用场景 单例模式 什么叫做单例模式 顾名思义&#xff0c;简单来说&#xff0c;单例…

Python语言修改控制台输出文字的颜色和背景颜色

Python语言修改控制台输出文字的颜色和背景颜色 格式显示模式字体颜色背景颜色文字加效果显示类 格式 \033[显示模式;字体颜色;背景颜色m 显示模式 显示模式格式将文本颜色和背景颜色重置为默认值&#xff0c;取消所有其他文本属性\033[0m高亮&#xff08;加粗&#xff09;\03…

Study--Oracle-04-SQL练习

一、SQL语句思维导图 二、SQL练习 -- 以employee_id 为排序&#xff0c;列出前5个人 -- FETCH select employee_id,first_name from employees order by employee_id FETCH FIRST 5 rows only; -- 以employee_id 为排序&#xff0c;从第6个人开始 到第10个人 -- offset …

【Java】已解决java.sql.SQLException异常

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决java.sql.SQLException异常 在Java中&#xff0c;java.sql.SQLException是一个通用的异常类&#xff0c;用于表示在数据库操作中发生的错误。无论是类型错误、数据类型不匹配…

ArcGIS图斑分区(组)排序—从上到下从左到右

​​ 点击下方全系列课程学习 点击学习—>ArcGIS全系列实战视频教程——9个单一课程组合系列直播回放 ArcGIS图斑分区&#xff08;组&#xff09;从上到下从左到右排序 是之前的内容的升级 GIS技巧100例——12ArcGIS图斑空间排序 关于今天的内容 我们在19年已经和大家分…