当前位置: 首页 > news >正文

使用Geotools中的原始方法来操作PostGIS空间数据库

目录

前言

一、原生PostGIS连接介绍

1、连接参数说明

2、创建DataStore

二、工程实战

1、Maven Pom.xml定义

2、空间数据库表

3、读取空间表的数据

三、总结


前言

        在当今数字化与信息化飞速发展的时代,空间数据的处理与分析已成为众多领域不可或缺的一环。从城市规划到环境监测,从物流配送到灾害预警,空间数据的应用场景无处不在。PostGIS 作为一款功能强大的开源空间数据库扩展,为存储、管理和分析地理空间数据提供了坚实的基础设施。而 Geotools 作为 Java 领域中广泛使用的地理信息工具库,为开发者搭建了一座连接空间数据与应用程序的桥梁。本文将深入探讨如何使用 Geotools 中的原始方法来操作 PostGIS 空间数据库,旨在为地理信息开发者提供一套系统、全面且实用的技术指南。

        随着地理信息系统(GIS)技术的普及,越来越多的行业开始依赖空间数据来驱动决策。PostGIS 以其对 OpenGIS 标准的全面支持和强大的空间数据处理能力,成为了许多 GIS 应用的首选数据库。它不仅能够存储复杂的几何和地理数据类型,还能执行高效的空间查询与分析操作。然而,要充分发挥 PostGIS 的潜力,开发者需要一种高效、灵活且易于集成的工具来与之交互。Geotools 正是这样一款工具,它提供了丰富的 API 和功能模块,使得开发者能够以面向对象的方式操作空间数据。

        在Geotools的官方方法中提供了直接调用 PostGIS 的底层功能。通过Geotools 提供的原始方法接口,允许开发者深入到 PostGIS 的核心操作层面。通过这些方法,开发者可以精确地控制数据的读取、写入、查询和更新过程,从而实现高度定制化的空间数据处理流程。例如在复杂的空间分析任务中,原始方法可以更灵活地组合多种空间操作。

        掌握 Geotools 中的原始方法来操作 PostGIS,不仅能够提升开发效率,还能拓展应用程序的功能边界。对于地理信息开发者而言,这是一种不可或缺的技能。本文将从 PostGIS 和 Geotools 的基础概念入手,逐步深入到原始方法的具体实现与应用案例。通过详细的代码示例和操作流程,读者将能够全面了解如何利用 Geotools 与 PostGIS 进行高效的空间数据交互,为构建复杂的空间数据应用奠定坚实的基础。无论是在科研项目中探索空间数据的深度分析,还是在商业应用中实现地理信息的高效管理,本文所提供的技术方法都将具有重要的参考价值。

一、原生PostGIS连接介绍

        为了方便第一次查阅本文的朋友对Geotools中对PostGIS进行原生处理进行介绍。首先还是对原生PostGIS的连接进行介绍,首先对连接参数进行说明,其次提供一个根据连接参数创建爱DataStore的示例,让大家对数据的处理有所了解。

1、连接参数说明

        Geotools中直连PostGIS的连接参数如下:

参数描述
dbtype必须是字符串 postgis
host要连接的机器名或 IP 地址
port要连接的端口号,默认为 5432
schema要访问的数据库模式
database要连接的数据库
user用户名
passwd密码
preparedStatements使用预编译语句
encode functions编码函数

        除了上面的标准配置参数意外,Geotools还提供了其它的高级参数,参数列表如下:

参数描述
loose bbox控制宽松 bbox 比较的标志,默认为 true
preparedStatements控制是否使用预编译语句,默认为 false
encode functions控制是否可以将一些常见函数编码为它们的 SQL 等价物

        默认情况下,JsonArrayContains 函数将委托给 @> 操作符。但对于 PostgreSQL 版本 >= 12,它将委托给 jsonPathExists 函数。jsonPathExists 能够在根级别数组中搜索值。大家可以根据自己的需要来添加这些参数到参数Map中,

params.put(PostgisNGDataStoreFactory.LOOSEBBOX, true );
params.put(PostgisNGDataStoreFactory.PREPARED_STATEMENTS, true );

2、创建DataStore

        上面介绍了使用原生的方式来操作PostGIS的连接参数信息,在掌握了以上信息之后,我们基于上面的连接参数来返回DataStore,并以此来获取空间库中的物理表信息的读取方法。创建DataStore的方法代码如下所示:

Map<String, Object> params = new HashMap<>();
params.put("dbtype", "postgis");
params.put("host", "localhost");
params.put("port", 5432);
params.put("schema", "public");
params.put("database", "database");
params.put("user", "postgres");
params.put("passwd", "postgres");
params.put("preparedStatements", true);
params.put("encode functions", true);
DataStore dataStore = DataStoreFinder.getDataStore(params);

二、工程实战

        本节将重点介绍如何在工程实战中来进行读取一个PostGIS的空间表,通过空间表的属性字段来进行过滤,返回我们预期的空间数据,通过这个例子大家可以掌握如何使用Geotools对PostGIS的原生操作方法。本节将从以下三个方面进行讲解,第一个方面是介绍需要引入的Maven资源库,其次是介绍一下相关的空间数据库表信息,最后提供一个实战源码,可以真实读取空间表的数据信息,包括属性信息和空间矢量信息。

1、Maven Pom.xml定义

        要想在项目工程中使用原生的方式以来操作PostGIS数据库,首先需要创建数据库的连接,与传统的数据库连接创建方式不一样,在Geotools中需要使用一个Map对象来缓存相关的连接,因此,需要引入的Pom.xml定义如下:

<dependency><groupId>org.geotools.jdbc</groupId><artifactId>gt-jdbc-postgis</artifactId><version>${geotools.version}</version>
</dependency>

        博客中使用的版本是:28.2。大家可以根据自己的实际情况进行选择对应的版本。 

2、空间数据库表

        作为示例,我们在一个数据库名称为:earthqadmin_dev,有一张省级行政区的空间表,表名叫做:biz_province。我们就以读取这张表的数据为例,讲述如何创建DataStore对象。空间表的数据如下:

        在java中连接PostGIS的参数代码如下:

/**
* -准备postGIS连接参数
* @return
*/
public static Map<String, Object> initPostGISMap () {Map<String, Object> params = new HashMap<>();params.put("dbtype", "postgis");params.put("host", "127.0.0.1");params.put("port", 5432);params.put("database", "earthqadmin_dev");params.put("schema", "public");params.put("user", "xxx");params.put("passwd", "xxx");return params;
}

        接下来就是从上面的map中获取DataStore对象,方法如下:

// step2、获取数据源
DataStore dataStore = DataStoreFinder.getDataStore(params);

         我们先来看一下,通过datastore可以获取哪些信息,查找所有使用服务机制注册的 DataStoreFactory 实现,并且这些实现的相应库在类路径上。所有已发现的数据存储,这些数据存储已注册工厂,并且其 available 方法返回 true。 方法如下:

/*** Finds all implemtaions of DataStoreFactory which have registered using the services* mechanism, and that have the appropriate libraries on the classpath.** @return An iterator over all discovered datastores which have registered factories, and whose*     available method returns true.*/public static synchronized Iterator<DataStoreFactorySpi> getAvailableDataStores() {FactoryRegistry serviceRegistry = getServiceRegistry();Set<DataStoreFactorySpi> availableDS =DataAccessFinder.getAvailableDataStores(serviceRegistry, DataStoreFactorySpi.class);return availableDS.iterator();
}

        可以在控制台看一下可用的实现信息:

ESRI(tm) Shapefiles (*.shp)
PostGIS Database (JNDI)
Takes a directory of shapefiles and exposes it as a data store
PostGIS Database

        到这里我们就成功的创建了DataStore对象,为接下来的空间数据读取打下了坚实的基础。

3、读取空间表的数据

        本小节将详细的讲述如何使用Geotools来进行空间属性的过滤,以及在控制台中输出我们的目标数据,关于如何使用Geotools来进行空间属性的过滤,方法多。这里介绍一种CQL的查询语言。这里的查询场景为,假设需要查询所有省份类型是“直辖市”的省份,可以实现的方法如下:

// step3、指定空间表名
String typeName = "biz_province";
//step4、 创建查询
Query query = new Query(typeName);
FeatureSource<SimpleFeatureType, SimpleFeature> featureSource = dataStore.getFeatureSource(typeName);
//step5、使用CQL(Common Query Language)表达式来定义过滤条件
Filter filter = CQL.toFilter(" type = '直辖市'");
query.setFilter(filter);

        最后执行查询和打印相关的属性信息及空间字段信息,关键代码如下:

// step6、执行查询
FeatureIterator<SimpleFeature> features = featureSource.getFeatures(query).features();         
CoordinateReferenceSystem crs = featureSource.getSchema().getCoordinateReferenceSystem();
System.out.println(crs);
System.out.println("**********************************************************");
while (features.hasNext()) {SimpleFeature feature = features.next();System.out.println("Feature: " + feature.getID());System.out.println("Geometry: " + feature.getDefaultGeometry());System.out.println("Attributes: " + feature.getAttributes());
}
features.close();
dataStore.dispose();

         一定记得打印完成后需要手动释放资源,以免造成不必要的损害。在IDE中运行以上的代码之后可以在控制台中看到如下输出:

        可以直观的发现,通过原生的PostGIS支持我们实现了对空间数据库中相关表的读取和展示。 

三、总结

        以上就是本文的主要内容,本文将深入探讨如何使用 Geotools 中的原始方法来操作 PostGIS 空间数据库,旨在为地理信息开发者提供一套系统、全面且实用的技术指南。通过Geotools 提供的原始方法接口,允许开发者深入到 PostGIS 的核心操作层面。通过这些方法,开发者可以精确地控制数据的读取、写入、查询和更新过程,从而实现高度定制化的空间数据处理流程。例如在复杂的空间分析任务中,原始方法可以更灵活地组合多种空间操作。行文仓促,难免有许多不足之处,如有不足,在此恳请各位专家博主在评论区不吝留言指出,不胜感激。

        参考资料:

        1、PostGIS操作指南。

相关文章:

使用Geotools中的原始方法来操作PostGIS空间数据库

目录 前言 一、原生PostGIS连接介绍 1、连接参数说明 2、创建DataStore 二、工程实战 1、Maven Pom.xml定义 2、空间数据库表 3、读取空间表的数据 三、总结 前言 在当今数字化与信息化飞速发展的时代&#xff0c;空间数据的处理与分析已成为众多领域不可或缺的一环。从…...

C-S模式之实现一对一聊天

天天开心&#xff01;&#xff01;&#xff01; 文章目录 一、如何实现一对一聊天&#xff1f;1. 服务器设计2. 客户端设计3. 服务端代码实现4. 客户端代码实现5. 实现说明6.实验结果 二、改进常见的服务器高并发方案1. 多线程/多进程模型2. I/O多路复用3. 异步I/O&#xff08;…...

Kafka Consumer Group

Kafka 消费者组&#xff08;Consumer Group&#xff09; 是 Kafka 的核心机制之一&#xff01;理解它对你掌握 Kafka 的高可用、高吞吐、负载均衡等能力非常关键。下面我来给你完整讲一讲&#x1f447; &#x1f9e0; 什么是 Kafka 消费者组&#xff08;Consumer Group&#x…...

LangChain vs LlamaIndex:大模型应用开发框架深度对比与实战指南

一、引言:大模型时代的应用开发挑战 随着ChatGPT、LLaMA等大语言模型的爆发式发展,如何高效构建「大模型+垂直领域」的智能应用成为新课题。传统开发模式面临三大痛点: 数据交互复杂:大模型与本地数据的融合缺乏标准化接口功能扩展困难:链式调用、工具集成需要重复造轮子…...

第二章:访问远程服务_《凤凰架构:构建可靠的大型分布式系统》

第二章 访问远程服务 2.1 远程服务调用&#xff08;RPC&#xff09; 2.1.1 进程间通信机制 核心方式&#xff1a; 管道&#xff08;Pipe&#xff09;&#xff1a;单向通信&#xff0c;用于父子进程信号&#xff08;Signal&#xff09;&#xff1a;异步事件通知&#xff0c;不…...

一键自动备份:数据安全的双重保障

随着数字化时代的到来&#xff0c;数据已成为企业和个人不可或缺的核心资产。在享受数据带来的便捷与高效的同时&#xff0c;数据丢失的风险也随之增加。因此&#xff0c;备份文件的重要性不言而喻。本文将深入探讨备份文件的重要性&#xff0c;并介绍两种实用的自动备份方法&a…...

C++11之std::is_convertible

目录 1.简介 2.实现原理 3.使用场景 4.总结 1.简介 std::is_convertible 是 C 标准库 <type_traits> 头文件中的一个类型特性&#xff08;type trait&#xff09;&#xff0c;它用于在编译时检查一个类型是否可以隐式转换为另一个类型。下面的原型&#xff1a; temp…...

从零开始:在Qt中使用OpenGL绘制指南

从零开始&#xff1a;在Qt中使用OpenGL绘制指南 本文只介绍基本的 QOpenGLWidget 和 QOpenGLFunctions 的使用&#xff0c;想要学习 OpenGL 的朋友&#xff0c;建议访问经典 OpenGL 学习网站&#xff1a;LearnOpenGL CN 本篇文章&#xff0c;我们将以绘制一个经典的三角形为例&…...

我的购物车设计思考:从个人项目到生产实战思考的蜕变

一、代码初体验&#xff1a;我踩过的那些坑 还记得大二做课程设计时&#xff0c;我写的购物车直接用ArrayList存商品&#xff0c;结果改数量时遍历半天找商品。现在看你这个HashMap实现&#xff0c;确实清爽很多&#xff0c;但有几点让我想起当年惨痛经历&#xff1a; 1. 线程…...

【算法实践】算法面试常见问题——数组的波浪排序

问题描述 给定一个无序整数数组&#xff0c;将其排列成波浪形数组。若数组 arr[0..n-1] 满足以下条件&#xff0c;则称为波浪形&#xff1a; arr[0] > arr[1] < arr[2] > arr[3] < arr[4] > ... 或 arr[0] < arr[1] > arr[2] < arr[3] > arr[4] &l…...

【大模型深度学习】如何估算大模型需要的显存

一、模型参数量 参数量的单位 参数量指的是模型中所有权重和偏置的数量总和。在大模型中&#xff0c;参数量的单位通常以“百万”&#xff08;M&#xff09;或“亿”&#xff08;B&#xff0c;也常说十亿&#xff09;来表示。 百万&#xff08;M&#xff09;&#xff1a;表示…...

[论文阅读]PMC-LLaMA: Towards Building Open-source Language Models for Medicine

PMC-LLaMA&#xff1a;构建医学开源语言模型 摘要 最近&#xff0c;大语言模型在自然语言理解方面展现了非凡的能力。尽管在日常交流和问答场景下表现很好&#xff0c;但是由于缺乏特定领域的知识&#xff0c;这些模型在需要精确度的领域经常表现不佳&#xff0c;例如医学应用…...

`use_tempaddr` 和 `temp_valid_lft ` 和 `temp_prefered_lft ` 笔记250405

use_tempaddr 和 temp_valid_lft 和 temp_prefered_lft 笔记250405 以下是 Linux 系统中与 IPv6 临时隐私地址相关的三个关键参数 use_tempaddr、temp_valid_lft 和 temp_prefered_lft 的详细说明及协作关系&#xff1a; &#x1f4dc; 参数定义与功能 参数作用默认值依赖关…...

如何设置 JVM 内存参数(-Xms、-Xmx、-Xss 等)?

JVM 内存参数用于控制 Java 虚拟机使用的内存大小和行为。以下是一些常用的 JVM 内存参数及其设置方法&#xff1a; 1. 堆内存 (Heap Memory): -Xms<size>: 设置 JVM 初始堆大小 (initial heap size)。 例如&#xff1a;-Xms2g (初始堆大小为 2GB)默认值&#xff1a;物…...

【MATLAB TCP/IP客户端与NetAssist上位机双向通信实战指南】

MATLAB TCP/IP客户端与NetAssist上位机双向通信实战指南 一、前言 在工业控制和数据采集领域&#xff0c;TCP/IP通信是最常用的网络通信协议之一。MATLAB作为强大的科学计算软件&#xff0c;与各种上位机软件(如NetAssist)进行通信可以实现数据采集、设备控制和实时监控等功能…...

联合、枚举、类型别名

数据类型&#xff1a; 已学--整数、实数、字符、字符串、数组、指针、结构待学--向量&#xff08;vector&#xff09;类型&#xff1a;优于数组非主流的类型--联合&#xff08;union&#xff09;、枚举&#xff08;enum&#xff09; 一、联合 联合类似于结构&#xff0c;可以容…...

Array 和 ArrayList 有何区别?什么时候更适合用 Array?

面试官提问&#xff1a; 你能简要说明 Array 和 ArrayList 之间的主要区别吗&#xff1f;在什么场景下更适合使用 Array&#xff1f; 标准回答&#xff1a; 在 Java 中&#xff0c;Array&#xff08;数组&#xff09;和 ArrayList&#xff08;动态数组&#xff09;都可以用于存…...

对状态模式的理解

对状态模式的理解 一、场景二、不采用状态模式1、代码2、缺点 三、采用状态模式1、代码1.1 状态类1.2 上下文&#xff08;这里指&#xff1a;媒体播放器&#xff09;1.3 客户端 2、优点 一、场景 同一个东西&#xff08;例如&#xff1a;媒体播放器&#xff09;&#xff0c;有一…...

【学Rust写CAD】31 muldiv255函数(muldiv255.rs)

源码 // Calculates floor(a*b/255 0.5) #[inline] pub fn muldiv255(a: u32, b: u32) -> u32 {// The deriviation for this formula can be// found in "Three Wrongs Make a Right" by Jim Blinn.let tmp a * b 128;(tmp (tmp >> 8)) >> 8 }代…...

使用VSCode编写C#程序

目录 一、环境搭建&#xff1a;构建高效开发基础1. 安装VSCode2. 配置.NET SDK3. 安装核心扩展 二、项目开发全流程1. 创建项目2. 代码编辑技巧3. 调试配置4. 高级调试技巧5. 编译与运行 三、常见问题解决指南1. 项目加载失败2. IntelliSense失效3. 代码格式化4. 典型编译错误&…...

chromadb

chromadb是一个轻量化的向量数据库&#xff0c;可以和llama-index等RAG框架使用。底层基于sqllite。 Getting Started - Chroma Docs 1、安装 $pip install chromadb pip install chromadb-client --在CS模式下&#xff0c;如果机器A上只需要安装客户端 2、可以使用客户端…...

第十章: 可观测性_《凤凰架构:构建可靠的大型分布式系统》

第十章: 可观测性 可观测性是现代分布式系统监控和故障排查的核心能力。本章从事件日志、链路追踪、聚合度量三个维度构建完整的可观测性体系&#xff0c;以下是各部分的重点解析与实践要点&#xff1a; 一、事件日志&#xff08;Event Logging&#xff09; 1. 核心目标 全链…...

vscode和cursor对ubuntu22.04的remote ssh和X-Windows的无密码登录

这里写自定义目录标题 写在前面需求的描述问题的引出 昨天已使能自动登录上午我的改变UBUNTU 22.04关闭密码规则一&#xff1a;修改 /etc/pam.d/common-password 文件二&#xff1a;修改 /etc/security/pwquality.conf 文件方法三&#xff1a;禁用 pam_pwquality.so 模块 vscod…...

Mlivus Cloud SDK v2的革新:性能优化与实战解析

作为大禹智库的向量数据库高级研究员王帅旭,我在过去30多年的AI应用实战中见证了向量数据库技术的演进历程。今天,我将从专业角度深入剖析Mlivus Cloud SDK v2的架构革新,特别是针对性能瓶颈问题的突破性解决方案。本文不仅会详细解析技术原理,还将提供可操作的优化建议,帮…...

stl_list的模拟实现

文章目录 stl_list的模拟实现迭代器的介绍以及分类stl_list的基本接口介绍stl_list的模拟实现结点类迭代器类基本迭代器操作 链表类链表基本操作 结语 我们今天又见面啦&#xff0c;给生活加点impetus&#xff01;&#xff01;开启今天的编程之路 作者&#xff1a;٩( ‘ω’ …...

【蓝桥杯】十五届省赛B组c++

目录 前言 握手问题 分析 排列组合写法 枚举 小球反弹 分析 代码 好数 分析 代码 R 格式 分析 代码 宝石组合 分析 代码 数字接龙 分析 代码 拔河 分析 代码 总结 前言 主播这两天做了一套蓝桥杯的省赛题目&#xff08;切实感受到了自己有多菜&#x…...

变分自编码器(VAE)概念解析与用法实例:根据原图像生成新图像

目录 1. 前言 2. VAE原理 2.1 什么是VAE&#xff1f; 2.2 编码器&#xff08;Encoder&#xff09; 2.3 重参数化技巧&#xff08;Reparameterization Trick&#xff09; 2.4 解码器&#xff08;Decoder&#xff09; 2.5 损失函数 3. Pytorch实现&#xff1a;根据原图像…...

AI随身翻译设备:从翻译工具到智能生活伴侣

文章目录 AI随身翻译设备的核心功能1. 实时翻译2. 翻译策略3. 翻译流程4. 输出格式 二、AI随身翻译设备的扩展功能1. 语言学习助手2. 旅行助手3. 商务助手4. 教育助手5. 健康助手6. 社交助手7. 技术助手8. 生活助手9. 娱乐助手10. 应急助手 三、总结四、未来发展趋势&#xff0…...

基于大模型的重症肌无力的全周期手术管理技术方案

目录 技术方案文档1. 数据预处理模块2. 多任务预测模型架构3. 动态风险预测引擎4. 手术方案优化系统5. 技术验证模块6. 系统集成架构7. 核心算法清单8. 关键流程图详述实施路线图技术方案文档 1. 数据预处理模块 流程图 [输入原始数据] → [联邦学习节点数据对齐] → [多模态特…...

Linux常用命令详解:从基础到进阶

目录 一、引言 二、文件处理相关命令 &#xff08;一&#xff09;grep指令 &#xff08;二&#xff09;zip/unzip指令 ​编辑 &#xff08;三&#xff09;tar指令 &#xff08;四&#xff09;find指令 三、系统管理相关命令 &#xff08;一&#xff09;shutdown指…...

【全球首发】DeepSeek谷歌版1.1.5 - 免费GPT-4级别AI工具

【全球首发】DeepSeek谷歌版1.1.5 - 免费GPT-4级别AI工具 资源简介 DeepSeek谷歌版1.1.5是目前全球领先的免费AI助手&#xff0c;性能超越国内主流AI产品&#xff0c;提供类似GPT-4的智能体验。 版本信息 最新版本&#xff1a;1.1.5&#xff08;2024最新版&#xff09;应用…...

JWT认证服务

JSON Web Token&#xff08;JWT&#xff09;是一种用于在网络应用间安全地传递信息的紧凑、自包含的方式。以下是关于 JWT 认证服务器更详细的介绍&#xff0c;包括其意义、作用、工作原理、组成部分、时效性相关内容、搭建条件以及代码案例。 JWT 的意义与作用 意义&#xf…...

Raft算法

Raft算法用于保证分布式环境下多节点数据的一致性。 原理 Raft算法的主要思想是一个 选主(leader selection) 的算法思想&#xff0c;集群种每个节点都有可能成为三种角色。 三种角色 leader 对客户端通信的入口&#xff0c;对内数据同步的发起者&#xff0c;一个集群通常只…...

Kotlin 类委托深入解析:以 MMKV 为例看委托机制在 Android 中的巧妙应用

Kotlin 中的类委托&#xff08;class delegation&#xff09;是一个非常实用的特性&#xff0c;它允许我们将接口的实现交给另一个对象&#xff0c;从而简化代码&#xff0c;提升复用性和灵活性。本文将通过简单的 Demo 介绍类委托的基本用法&#xff0c;并以 Android 中的 MMK…...

2025年渗透测试面试题总结-某一线实验室实习扩展(题目+回答)

网络安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 某一线实验室实习扩展 一、流量分析深度实践 1. FTP反弹定时确认包流量检测 1.1 攻击原理与特征 1.…...

2025大唐杯仿真3——移动性管理

仅仅是1-2之间的信息交互...

云原生与微服务的关系

云原生&#xff08;Cloud Native&#xff09;和微服务&#xff08;Microservices&#xff09;是现代软件开发和部署中密切相关的两个概念&#xff0c;它们共同推动了应用程序的架构设计、开发模式和运维方式的变革。以下是两者的关系及核心要点&#xff1a; 定义与核心概念 云原…...

【百日精通JAVA | SQL篇 | 第三篇】 MYSQL增删改查

SQL得最核心就是增删改查 一个后端开发&#xff0c;在工作中&#xff0c;最常见的场景就是CRUD。 插入数据 insert into student values (1,zhangsan); 指定列插入数据 同时多个列明之间使用逗号&#xff0c;来分割 insert into student (name) values (zhaoliu); 这个黑框…...

【leetcode】记录与查找:哈希表的题型分析

前言 &#x1f31f;&#x1f31f;本期讲解关于力扣的几篇题解的详细介绍~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &#x1f386;那么废话不…...

如何在 Windows 10 上安装 PyGame

PyGame 是 Python 编程语言中的一组跨平台模块&#xff0c;这意味着您可以在任何操作系统上安装它&#xff0c;这篇文章告诉您如何在 Windows 10 上安装 PyGame。 如何在 Windows 10 上安装 PyGame&#xff1f; PyGame 依赖于 Python&#xff0c;这意味着您必须在安装 PyGame …...

LVGL修改标签文本,GUI Guider的ui不生效

一.问题背景 笔者最近在学习LVGL框架&#xff0c;同时准备使用该框架作为课程设计的一部分&#xff0c;于是需要从静态显示进阶到动态显示以及事件交互。一方面由于笔者是初次接触LVGL&#xff0c;对它并不熟悉&#xff0c;另一方面由于其网络上的针对性具体资料太少&a…...

制造装备物联及生产管理ERP系统设计与实现(代码+数据库+LW)

摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装制造装备物联及生产管理ERP系统软件来发挥其高效地信息处理…...

PowerPhotos:拯救你的Mac照片库,告别苹果原生应用的局限

如果你用Mac管理照片&#xff0c;大概率被苹果原生「照片」应用折磨过——无法真正并行操作多个图库。每次切换图库都要关闭重启&#xff0c;想合并照片得手动导出导入&#xff0c;重复文件更是无处可逃…… 直到我发现了 PowerPhotos&#xff0c;这款专为Mac设计的照片库管理…...

软件工程面试题(三十)

将ISO8859-1字符串转成GB2312编码&#xff0c;语句为&#xff1f; String snew String(text.getBytes(“iso8859-1”),”gb2312”). 说出你用过的J2EE标准的WEB框架和他们之间的比较&#xff1f; 答&#xff1a;用过的J2EE标准主要有&#xff1a;JSP&Servlet、JDBC、JNDI…...

Java面试黄金宝典35

1. A 和 B 两个表做等值连接 (Inner join) 怎么优化 索引优化&#xff1a;在连接字段上创建索引&#xff0c;让数据库在进行等值连接时&#xff0c;能够快速定位匹配的记录&#xff0c;减少全表扫描的开销。例如&#xff0c;若 A 表和 B 表通过 id 字段进行连接&#xff0c;可在…...

openssl-1.0.1e.tar.gz编译安装步骤

下载与验证 openssl-1.0.1e.tar.gz下载链接&#xff1a;https://pan.quark.cn/s/d682551565e8 校验文件完整性&#xff08;示例&#xff09;&#xff1a; # 检查 SHA256 哈希值 sha256sum openssl-1.0.1e.tar.gz # 对比官方发布的哈希值&#xff08;需从 OpenSSL 官网获取&a…...

供应链业务-供应链全局观(二)

概述 我们在供应链业务知识分享的第一篇供应链业务-供应链全局观&#xff08;一&#xff09;中大致聊了以下三点&#xff1a; 1、供应链的本质&#xff1a;环环相扣的增值网络。供应链是从供应商的供应商到客户的客户之间&#xff0c;通过采购、生产、运输、仓储、销售等环节…...

在 Flutter 中Navigator.push 用于实现页面之间的导航

在 Flutter 中&#xff0c;Navigator.push 是一个非常重要的方法&#xff0c;用于实现页面之间的导航。通过 Navigator.push&#xff0c;你可以将一个新的页面&#xff08;路由&#xff09;推送到导航栈中&#xff0c;从而显示新的内容。 以下是一个详细的教程&#xff0c;帮助…...

安永启用AI驱动SAP云ERP系统

安永&#xff08;EY&#xff09;宣布与 SAP 和微软展开战略合作&#xff0c;正式启动将其内部业务系统升级为基于 SAP S/4HANA Cloud 私有版的现代化 ERP 系统&#xff0c;并部署在 Microsoft Azure 云平台上。此次转型不仅涉及系统更新&#xff0c;还将通过引入人工智能&#…...

Augment Code:下一代AI编程助手,能否超越GitHub Copilot?

1. 背景介绍 近日&#xff0c;AI编程助手公司 Augment Code 宣布完成 2.27亿美元B轮融资&#xff0c;估值接近 9.77亿美元&#xff0c;距离独角兽企业仅一步之遥。本轮融资由 Sutter Hill Ventures、Index Ventures、Innovation Endeavors、Lightspeed Venture Partners 和 Me…...