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

Oracle常见语法

一、求交集

SELECT column1, column2
FROM table1
INTERSECT
SELECT column1, column2
FROM table2;

INTERSECT 操作符是 Oracle 和一些其他数据库(如 PostgreSQLSQL Server)特有的集合操作符,在 MySQL 中并不直接支持。MYSQL同效果代码:

SELECT t1.column1, t1.column2
FROM table1 t1
INNER JOIN table2 t2ON t1.column1 = t2.column1AND t1.column2 = t2.column2;

二、求差集

        用于返回 第一个查询结果 中存在,但在 第二个查询结果 中不存在的行,即从第一个查询中减去第二个查询中的内容。

SELECT column1, column2
FROM table1
MINUS
SELECT column1, column2
FROM table2;

结果:

MINUS 会返回 table1 中有,但 table2 中没有的行。

特点:

  • 默认去重:返回的结果不会包含重复的行。
  • 结果是基于整个行的比较,而不仅仅是单个列。
  • MINUS 在 Oracle 和一些数据库中是原生支持的,但在 MySQL 中不支持。

MySQL 中的替代方法

SELECT t1.column1, t1.column2
FROM table1 t1
LEFT JOIN table2 t2ON t1.column1 = t2.column1AND t1.column2 = t2.column2
WHERE t2.column1 IS NULL;

三、左外连接

左外连接返回左表(即 LEFT JOIN 左侧的表)中的所有行,即使右表没有匹配的行。如果右表没有匹配的行,结果中该部分的列会显示为 NULL

第一种语法: 

SELECT e.emp_name, d.dept_name
FROM employees e
LEFT JOIN departments d ON e.dept_id = d.dept_id;

第二种语法:

SELECT e.emp_name, d.dept_name
FROM employees e, departments d
WHERE e.dept_id = d.dept_id(+);

        这种写法是 Oracle 特有的表示 外连接 的语法,使用 (+) 来表示右表(或左表)是外部表,确保即使另一张表没有匹配的记录,外部表的记录仍然会显示在结果中 

四、右外连接

        右外连接返回右表(即 RIGHT JOIN 右侧的表)中的所有行,即使左表没有匹配的行。如果左表没有匹配的行,结果中该部分的列会显示为 NULL

语法一:

SELECT columns
FROM table1
RIGHT JOIN table2 ON table1.column = table2.column;

语法二:

select 列名 from 表名,表名2 where 表1.name(+)=表2.name

五、交叉连接

交叉连接(或笛卡尔积)返回左表和右表的所有行的 组合,即 每一行左表 会与 每一行右表 进行匹配,结果集的行数等于两个表的行数的乘积。

SELECT columns
FROM table1
CROSS JOIN table2;

SELECT s.student_name, c.course_name
FROM students s
CROSS JOIN courses c;

  • 每个学生(students 表)会与每个课程(courses 表)进行组合,返回所有可能的行(笛卡尔积)。因此,结果有 2(学生) * 2(课程) = 4 行。

六、按查询顺序分配行号 ROWNUM

SELECT emp_name, salary, ROWNUM 
FROM employees;

ROWNUM 可以作为筛选条件获取前 N 行数据

获取前两行的数据

SELECT emp_name, salary
FROM employees
WHERE ROWNUM <= 2;

常见问题:无法跳过前几行

假设你想获取 第 2 到第 4 行的数据,可能会写:

SELECT emp_name, salary 
FROM employees 
WHERE ROWNUM > 1 AND ROWNUM <= 4; 

但这样是错误的! ROWNUM逐行分配的,一旦 ROWNUM = 1 这行被过滤掉,后面的行就永远不会得到 ROWNUM = 2,查询会返回 空结果

正确的做法:使用子查询

SELECT * FROM (SELECT emp_name, salary, ROWNUM AS rn FROM employees
) WHERE rn BETWEEN 2 AND 4;

七、按特定排序分配行号 ROW_NUMBER()

7.1排序分配行号

   ROW_NUMBER() 是 Oracle 11g 及以上 版本引入的 窗口函数(Window Function),用于为查询结果中的每一行分配唯一的行号。

SELECT emp_name, salary, ROW_NUMBER() OVER (ORDER BY salary DESC) AS rn
FROM employees;

ROW_NUMBER() 是窗口函数,必须与 OVER() 一起使用。每一行的 ROW_NUMBER() 值都是唯一的,即使数据相同。

7.2 先分组再排序编号

如果我想先分组再排序编号,就需要下面这样:

SELECT emp_name, salary, dept_id,ROW_NUMBER() OVER (PARTITION BY dept_id ORDER BY salary DESC) AS rn
FROM employees;

PARTITION BY dept_id:按照 dept_id(部门)进行分组,每个部门的编号 从 1 开始 重新计算

7.3 分页查询

SELECT * FROM (SELECT emp_name, salary, ROW_NUMBER() OVER (ORDER BY salary DESC) AS rnFROM employees
) WHERE rn BETWEEN 3 AND 4;

在外层查询 WHERE rn BETWEEN 3 AND 4 只取 第 3 ~ 4 行(相当于 OFFSET 2 LIMIT 2

八、RANK( )和 DENSE_RANK()

8.1直接排名

SELECT emp_name, salary,RANK() OVER (ORDER BY salary DESC) AS rank_num,DENSE_RANK() OVER (ORDER BY salary DESC) AS dense_rank_num
FROM employees;

8.2 先分组后排名

SELECT emp_name, salary, dept_id,RANK() OVER (PARTITION BY dept_id ORDER BY salary DESC) AS rank_num,DENSE_RANK() OVER (PARTITION BY dept_id ORDER BY salary DESC) AS dense_rank_num
FROM employees;

九、企业代码a解析

select '$code' 采购方代码,'$name' 采购方名称,w.goods 产品代码,w.name 产品名称,w.spec 产品规格,h.lotno 批号,w.producer 生产厂家,to_char(l.enddate, 'yyyy/mm/dd') 有效期,'' 进货类型,nvl(w.ratifier, w.register) as 批准文号FROM st_pur h, t_clients c, t_waredict w, scm_lot_list@cmsjs lWHERE h.compid = 1and h.cstid = c.cstidand h.goodid = w.goodidand h.goodid = l.goodidand h.lotno = l.lotnoand w.goodid in (select goodidfrom v_tz_zl_waredict@zdwhere ori_ownerid = '27'and cstname = '厂商名')

9.1字符串常量 

在 SQL 语句中,'$code''$name' 只是普通的字符串常量,也就是固定的值。 

在 SQL 中,单引号用于表示字符串常量。即使字符串为空,单引号也可以表示一个空字符串(即长度为 0 的字符串)。 

 '' 进货类型,

9.2 日期类型转换格式 

上述代码中  to_char(l.enddate, 'yyyy/mm/dd')  用于将日期类型的数据转换为指定格式的字符串。它通常用于将日期格式化为我们需要的输出样式。

l.enddate(可能是一个 DATETIMESTAMP 类型的字段)格式化为一个字符串,格式为 'yyyy/mm/dd’

9.3 NVL()

NVL() 是 Oracle SQL 中的一个函数,用于处理空值(NULL),如果指定的表达式为 NULL,则返回一个替代值。

NVL(expression1, expression2)

expression1: 需要检查的值。如果这个值为 NULL,则返回 expression2

NVL(w.ratifier, w.register)

在上述的 SQL 中,NVL(w.ratifier, w.register) 表示:

  • 首先检查 w.ratifier 的值
    • 如果 w.ratifier 不为 NULL,则返回 w.ratifier 的值。
    • 如果 w.ratifierNULL,则返回 w.register 的值。

也就是说,NVL(w.ratifier, w.register) 用来选择 w.ratifier(批准人)的值,如果它为空,则选择 w.register(注册人)的值。

9.4 数据库连接

代码中where里有这么一个表,它涉及到数据库连接

scm_lot_list@cmsjs l

数据库连接(Database Link)是什么?

想象一下,你有两台电脑:

  • 电脑A(你的本地数据库)
  • 电脑B(远程数据库,存放着你需要的数据)

如果你想要访问 电脑B 上的文件,最简单的方法是什么?
远程桌面(Remote Desktop)
网络共享(Network Share)

你可以用 远程桌面 直接操作 电脑B,或者用 网络共享电脑A 直接访问 电脑B 的文件,就像访问本地文件一样。

数据库连接(Database Link) 就像这个 网络共享,它让一个数据库(A)能够访问另一个远程数据库(B)中的数据,就像它是本地数据一样。

SELECT * FROM scm_lot_list@cmsjs;

这个 @cmsjs 就是数据库的“网络共享路径”。它告诉数据库: “我要访问 cmsjs 这个远程数据库中的 scm_lot_list 表。”

如果没有 @cmsjs,那么 scm_lot_list 就是你本地数据库的表;
加上 @cmsjs,表示去 远程数据库 里找 scm_lot_list 这个表。

如何创建数据库连接

CREATE DATABASE LINK 连接名
CONNECT TO 远程用户名 IDENTIFIED BY '远程用户密码'
USING '远程数据库地址';

示例: 假设你本地的数据库需要访问远程数据库 cmsjs,远程数据库的用户是 remote_user,密码是 password,远程数据库的地址是 remote_db,可以这样创建连接:

CREATE DATABASE LINK cmsjs
CONNECT TO remote_user IDENTIFIED BY 'password'
USING 'remote_db';
  • CREATE DATABASE LINK cmsjs

    • 这里的 cmsjs 是数据库连接的名称,你可以随便取,但必须保证唯一。
    • 以后你查询远程数据库的数据时,都会用 @cmsjs
  • CONNECT TO remote_user IDENTIFIED BY 'password'

    • 这里的 remote_user 是远程数据库的用户名,需要有查询权限。
    • 'password' 是远程数据库用户的密码。
  • USING 'remote_db'

    • 这里的 'remote_db' 代表 远程数据库的连接信息,可以是:
      • TNS(透明网络子系统)别名,如果已经在 tnsnames.ora 里配置了远程数据库。
      • 完整的连接字符串,直接指定远程数据库的主机、端口、SID 或服务名。
USING '(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.100)(PORT=1521)))(CONNECT_DATA=(SID=orcl)))'
  • HOST=192.168.1.100 远程数据库的 IP 地址
  • PORT=1521 远程数据库的端口(Oracle 默认 1521)
  • SID=orcl 远程数据库的 SID

十、企业代码b解析

SELECT trunc(h.makedate) 日期,'$code' 销售方代码,'$name' 销售方名称,w.producer 生产厂家,to_date(substr( h.bthdesc, instr( h.bthdesc, '效期:', 1, 1 ) + 3, 10 ), 'yyyy/mm/dd')  有效期,'' 销售类型,h.addressname as 收货地址,nvl(w.ratifier, w.register) as 批准文号FROM st_flow h, t_waredict w, t_clients cWHERE h.compid = c.compidAND h.goodid = w.goodidAND h.cstid = c.cstidand w.goodid in (select goodidfrom v_tz_zl_waredict@zdwhere ori_ownerid = '27'and cstname = '厂商名字')

10.1 日期截断 trunc()

TRUNC() 是 Oracle SQL 中的一个日期处理函数,主要用于截断日期,它可以去除日期中的时间部分(小时、分钟、秒等),只保留日期部分(年、月、日)。例如,如果 h.makedate 的值是 2025-02-10 15:30:45,使用 TRUNC(h.makedate) 后会变成 2025-02-10,即时间部分被去掉。

10.2 instr()

 to_date(substr( h.bthdesc, instr( h.bthdesc, '效期:', 1, 1 ) + 3, 10 ), 'yyyy/mm/dd')  有效期,

  INSTR 是 Oracle SQL 中的一个字符串函数,用于查找一个子字符串在另一个字符串中出现的位置。它返回子字符串在目标字符串中首次出现的位置(索引),如果没有找到子字符串,则返回 0

INSTR(string, substring [, start_position [, match_occurance [, return_option [, scan_direction [, match_character]]]]])
  • string:目标字符串,也就是我们要搜索的字符串。
  • substring:要查找的子字符串。
  • start_position:可选参数,指定从目标字符串的哪个位置开始查找。默认为 1,表示从第一个字符开始查找。
  • match_occurance:可选参数,指定查找的子字符串出现的第几次。默认为 1,表示查找第一次出现的子字符串。
  • return_option:可选参数,决定返回值的类型:
    • 0 或省略:返回子字符串的起始位置。
    • 1:返回子字符串的结束位置。
  • scan_direction:可选参数,指定查找方向:
    • 1:从左到右(默认)。
    • -1:从右到左(即反向查找)。
  • match_character:可选参数,指定大小写敏感的字符集或字符集标志。

 假设你有以下字符串:'Hello, world!',你想查找 'world' 在字符串中的位置:

SELECT INSTR('Hello, world!', 'world') AS position FROM dual;

返回结果: 

POSITION
--------8

h.bthdesc 是表 st_flow 中的一个列,可能包含一些描述信息。假设它是一个文本字段,里面存储了类似这样的字符串:

"生产批号: ABC123 效期: 2025/02/10"

instr(h.bthdesc, '效期:', 1, 1)

  • INSTR 是 Oracle SQL 中的一个字符串函数,用于返回子字符串在目标字符串中的位置。
  • h.bthdesc 是目标字符串,'效期:' 是我们要查找的子字符串,1 表示从目标字符串的第一个字符开始查找,最后一个 1 表示只查找第一个出现的位置。
  • 假设 h.bthdesc 的值是 "生产批号: ABC123 效期: 2025/02/10",那么 INSTR(h.bthdesc, '效期:', 1, 1) 的结果会是 10,表示 '效期:' 在字符串中的起始位置是第10个字符。

10.3 将字符串转换为日期类型 TO_DATE

TO_DATE(string, format_mask)

将给定的字符串 string 按照指定的 format_mask 格式解析,转换为一个日期类型。这个日期类型是 Oracle 数据库内部用于存储日期的格式,支持进行日期运算和比较。

1. 将字符串 '2025/02/10' 转换为日期类型:

TO_DATE('2025/02/10', 'yyyy/mm/dd')

        这个查询将把 '2025/02/10' 这个字符串按照 年-月-日yyyy/mm/dd)的格式转换为 Oracle 的日期类型。转换后的结果会是 2025年2月10日,而且可以进行日期运算(例如:加减天数、月数等)。

2. 将字符串 '10-FEB-2025' 转换为日期类型:

TO_DATE('10-FEB-2025', 'dd-mon-yyyy')

        这个查询将把 '10-FEB-2025' 字符串按照 日-月-年dd-mon-yyyy)的格式转换为日期类型。这个格式中的 mon 是指月份的简写(如 JANFEBMAR,等等)

使用 TO_DATE 时要注意的几点:

  1. 日期格式与实际字符串的格式必须匹配

    • 格式模板(format_mask)必须与输入的日期字符串格式完全一致。否则,Oracle 会抛出错误。
  2. 默认日期格式

    • 如果没有显式指定格式,Oracle 会使用默认的日期格式(通常是 DD-MON-YY,即 10-FEB-25)。如果不清楚输入日期的格式,建议始终明确指定格式。
  3. 日期类型和字符串类型的区别

    • TO_DATE 函数将返回一个 日期类型,而不是字符串。Oracle 会按照其内部的日期格式存储和处理这些数据。
  4. 时间部分的处理

    • 如果 string 中包含时间信息,TO_DATE 会将时间部分一起解析。如果没有时间信息,时间部分默认为 00:00:00(即午夜)。
  5. 不同的数据库可能有不同的默认日期格式

    • 不同数据库管理系统(DBMS)可能有不同的默认日期格式。在 Oracle 中,通常是 DD-MON-YY,而在其他 DBMS 中可能是 YYYY-MM-DD,因此在跨数据库开发时,需要特别注意日期格式的处理。

相关文章:

Oracle常见语法

一、求交集 SELECT column1, column2 FROM table1 INTERSECT SELECT column1, column2 FROM table2;INTERSECT 操作符是 Oracle 和一些其他数据库&#xff08;如 PostgreSQL 和 SQL Server&#xff09;特有的集合操作符&#xff0c;在 MySQL 中并不直接支持。MYSQL同效果代码&a…...

[2025年最新]2024.3版本idea无法安装插件问题解决

背景 随着大模型的持续发展&#xff0c;特别年前年后deepseek的优异表现&#xff0c;编程过程中&#xff0c;需要解决ai来辅助编程&#xff0c;因此需要安装一些大模型插件 问题描述 在线安装插件的时候会遇到以下问题&#xff1a; 1.数据一直在加载&#xff0c;加载的很满 2.点…...

说一下 jvm 有哪些垃圾回收器?

JVM 垃圾回收器对比表 垃圾回收器类型工作方式回收方式停顿时间适用场景优点缺点常见问题常见配置Serial GC串行单线程&#xff0c;STW年轻代&#xff1a;复制算法 老年代&#xff1a;标记-整理长小内存、单核CPU&#xff0c;如桌面应用或嵌入式设备简单高效&#xff0c;适用于…...

【Linux】--- 进程间的通信

【Linux】--- 进程间的通信 一、进程间通信的介绍1、进程间通信的概念2、进程间通信的目的3、 进程间通信的本质/前提4、进程间通信的分类 二、管道1、什么是管道2、匿名管道&#xff08;1&#xff09;匿名管道的原理&#xff08;2&#xff09;pipe函数&#xff08;3&#xff0…...

GlusterFS 深度洞察:从架构原理到案例实践的全面解读(上)

文章目录 一.GlusterFS简介二.GlusterFS原理架构三.适用场景四.Glusterfs与其他存储产品对比五.部署GlusterFS集群六. 使用heketi将glusterfs接入k8s作为后端存储 一.GlusterFS简介 GlusterFS是一个免费的开源分布式文件系统&#xff0c;具有无中心节点、堆栈式设计、全局统一…...

实现限制同一个账号最多只能在3个客户端(有电脑、手机等)登录(附关键源码)

如上图&#xff0c;我的百度网盘已登录设备列表&#xff0c;有一个手机&#xff0c;2个windows客户端。手机设备有型号、最后登录时间、IP等。windows客户端信息有最后登录时间、操作系统类型、IP地址等。这些具体是如何实现的&#xff1f;下面分别给出android APP中采集手机信…...

C#综合知识点面试集锦

在.NET Core 框架的面试中,可能会涉及基础概念、核心组件、依赖注入、性能优化等多方面的知识点,以下为你详细介绍: 基础概念 .NET Core 概述 定义与特点:解释 .NET Core 是一个跨平台、开源、模块化且高性能的通用开发框架,能在 Windows、Linux、macOS 等操作系统上运行…...

宝珀(Blancpain):机械制表的三项重大创新(中英双语)

宝珀&#xff08;Blancpain&#xff09;&#xff1a;机械制表的创新先驱 本文灵感来源&#xff1a; 瑞士钟表业决定逆流而上&#xff0c;杀出一条生路&#xff0c;宝珀更是坚定地宣称“我们永远只做机械表”&#xff0c;它拒绝了石英技术。制表师们在提高腕表的技艺和品质、实…...

稠密架构和稀疏架构

稠密架构和稀疏架构 flyfish 稠密架构 参数使用方面&#xff1a;稠密架构中的大部分参数在每次计算时都会被使用。也就是说&#xff0c;对于输入的每一个样本&#xff0c;模型的所有或大部分参数都会参与到计算过程中。计算特点&#xff1a;计算密集&#xff0c;需要对大量的…...

SpringCloud - Gateway 网关

前言 该博客为Sentinel学习笔记&#xff0c;主要目的是为了帮助后期快速复习使用 学习视频&#xff1a;7小快速通关SpringCloud 辅助文档&#xff1a;SpringCloud快速通关 源码地址&#xff1a;cloud-demo 一、简介 官网&#xff1a;https://spring.io/projects/spring-clou…...

【如何掌握CSP-J 信奥赛中的排序算法】

要掌握CSP-J信奥赛中的排序算法&#xff0c;需要系统学习基础排序算法的原理、实现和应用场景。以下是分阶段的学习路径和建议&#xff1a; 一、必掌握的排序算法清单 CSP-J阶段需重点掌握以下算法&#xff08;按考察频率排序&#xff09;&#xff1a; 冒泡排序&#xff08;B…...

3. CSS中@scope

说说你对 CSS 中scope 的了解 <style>/* scope规则 */scope (#app) {.box {width: 100px;height: 100px;background-color: red;}} </style> <div id"app"><div class"box"></div> </div>CSS 中的scope 是一个相对较新…...

基于雷达和摄像头的无人机轨迹识别与激光照射控制研究

标题:基于雷达和摄像头的无人机轨迹识别与激光照射控制研究 内容:1.摘要 摘要&#xff1a;本文研究了基于雷达和摄像头的无人机轨迹识别与激光照射控制。通过对雷达和摄像头数据的融合处理&#xff0c;实现了对无人机轨迹的精确识别。同时&#xff0c;利用激光照射技术对无人机…...

Response 和 Request 介绍

怀旧网个人博客网站地址&#xff1a;怀旧网&#xff0c;博客详情&#xff1a;Response 和 Request 介绍 1、HttpServletResponse 1、简单分类 2、文件下载 通过Response下载文件数据 放一个文件到resources目录 编写下载文件Servlet文件 public class FileDownServlet exten…...

读 DeepSeek-R1 论文笔记

DeepSeek-R1&#xff1a;通过强化学习激发大语言模型的推理能力 DeepSeek-AI 摘要 我们推出第一代推理模型DeepSeek-R1-Zero和DeepSeek-R1。DeepSeek-R1-Zero作为无需监督微调(SFT)预训练阶段、直接通过大规模强化学习(RL)训练的基础模型&#xff0c;展现出卓越的推理能力。…...

【算法-动态规划】、魔法卷轴: 两次清零机会整个数组最大累加和

【算法-动态规划】、魔法卷轴: 两次清零机会整个数组最大累加和 文章目录 一、dp1.1 题意理解1.2 整体思路1.3 具体思路1.4 代码 二、多语言解法 一、dp 1.1 题意理解 nums 数组, 有正负0, 使用最多两次魔法卷轴, 希望使数组整体的累加和尽可能大. 求尽可能大的累加和 其实就…...

蓝桥杯C语言组:分治问题研究

蓝桥杯C语言组分治问题研究 摘要 本文针对蓝桥杯C语言组中的分治问题展开深入研究&#xff0c;详细介绍了分治算法的原理、实现方法及其在解决复杂问题中的应用。通过对经典例题的分析与代码实现&#xff0c;展示了分治算法在提高编程效率和解决实际问题中的重要作用&#xff…...

npm介绍(Node Package Manager)(JavaScript生态中最流行的包管理工具,主要用于Node.js项目的依赖管理)

文章目录 **核心功能****常用命令****关键文件****npm vs 其他工具****最佳实践**官方资源 npm&#xff08;Node Package Manager&#xff09;是 JavaScript 生态中最流行的包管理工具&#xff0c;主要用于 Node.js 项目的依赖管理。以下是核心要点&#xff1a; 核心功能 依赖管…...

小白零基础如何搭建CNN

1.卷积层 在PyTorch中针对卷积操作的对象和使用的场景不同&#xff0c;如有1维卷积、2维卷积、 3维卷积与转置卷积&#xff08;可以简单理解为卷积操作的逆操作&#xff09;&#xff0c;但它们的使用方法比较相似&#xff0c;都可以从torch.nn模块中调用&#xff0c;需要调用的…...

【分布式架构理论3】分布式调用(1):负载均衡

文章目录 零、三种不同的负载均衡一、常见行业负载均衡方案1. 电商与互联网服务2. 金融与支付系统3. 云计算与分布式存储 二、负载均衡策略概述1. 无状态负载均衡&#xff08;强调公平性&#xff09;2. 有状态的负载均衡&#xff08;强调正确性&#xff09; 三、 总结 零、三种…...

QT 5.15.2 开发地图ArcGIS 100.15.6(ArcGIS Runtime SDK for Qt)

QT 5.15.2ArcGIS下载 Downloads | ArcGIS Runtime API for Qt | Esri Developer ArcGIS安装&#xff08;略&#xff09;参考 Display a map | ArcGIS Maps SDK for Qt | Esri Developer QT新建工程 步骤1 步骤2 步骤3 步骤4&#xff08;选择Topographic不需要KEY) 步骤5&a…...

细读 React | React Router 路由切换原理

2022 北京冬奥会开幕式 此前一直在疑惑&#xff0c;明明 pushState()、replaceState() 不触发 popstate 事件&#xff0c;可为什么 React Router 还能挂载对应路由的组件呢&#xff1f; 翻了一下 history.js 源码&#xff0c;终于知道原因了。 源码 假设项目路由设计如下&#…...

kubernetes学习-Helm 包管理器(十二)

一、Helm解释 Helm&#xff1a;Kubernetes 的软件包管理器 Helm 被誉为查找、分享及使用 Kubernetes 软件组件的最佳途径。作为 Kubernetes 包的管理工具&#xff0c;Helm 专注于管理名为 chart 的软件包。以下是 Helm 所具备的核心功能&#xff1a; 创建新 chart&#xff1…...

PbootCMS最新代码注入漏洞(CNVD-2025-01710、CVE-2024-12789)

PbootCMS是一套高效、简洁、 强悍的可免费商用的CMS源码&#xff0c;使用PHPMySQL开发&#xff0c;能够满足各类企业网站开发建设的需要。 国家信息安全漏洞共享平台于2025-01-14公布该程序存在代码注入漏洞。 漏洞编号&#xff1a;CNVD-2025-01710、CVE-2024-12789 影响产品…...

网络安全与AI:数字经济发展双引擎

在2025年年初&#xff0c;一场科技攻防战引发了全球关注。国产人工智能DeepSeek的爆火&#xff0c;伴随着大规模的网络攻击事件&#xff0c;将网络安全的重要性推上了风口浪尖。 在此背景下&#xff0c;我们计划探讨网络安全与人工智能如何为数字经济发展提供强大动力。网络安…...

【DeepSeek × Postman】请求回复

新建一个集合 在 Postman 中创建一个测试集合 DeepSeek API Test&#xff0c;并创建一个关联的测试环境 DeepSeek API Env&#xff0c;同时定义两个变量 base_url 和 api_key 的步骤如下&#xff1a; 1. 创建测试集合 DeepSeek API Test 打开 Postman。点击左侧导航栏中的 Co…...

如何将网站提交百度收录完整SEO教程

百度收录是中文网站获取流量的重要渠道。本文以我的网站&#xff0c;www.mnxz.fun&#xff08;当然现在没啥流量&#xff09; 为例&#xff0c;详细讲解从提交收录到自动化维护的全流程。 一、百度收录提交方法 1. 验证网站所有权 1、登录百度搜索资源平台 2、选择「用户中心…...

【unity实战】实现摄像机跟随效果

考虑到每个人基础可能不一样,且并不是所有人都有同时做2D、3D开发的需求,所以我把 【零基础入门unity游戏开发】 分为成了C#篇、unity通用篇、unity3D篇、unity2D篇。 【C#篇】:主要讲解C#的基础语法,包括变量、数据类型、运算符、流程控制、面向对象等,适合没有编程基础的…...

使用Hexo部署NexT主体网站

一.使用git提交文件 参考&#xff1a; 从零开始搭建个人博客&#xff08;超详细&#xff09; - 知乎 致谢&#xff01; 第一种&#xff1a;本地没有 git 仓库 直接将远程仓库 clone 到本地&#xff1b;将文件添加并 commit 到本地仓库&#xff1b;将本地仓库的内容push到远程仓…...

使用 AlexNet 实现图片分类 | PyTorch 深度学习实战

前一篇文章&#xff0c;CNN 卷积神经网络处理图片任务 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于 强化学习必修课&#xff1a;引领人工智能新时代【梗直哥瞿炜】 使用 AlexNet 实现图片分类…...

ES6 Proxy 用法总结以及 Object.defineProperty用法区别

Proxy 是 ES6 引入的一种强大的拦截机制&#xff0c;用于定义对象的基本操作&#xff08;如读取、赋值、删除等&#xff09;的自定义行为。相较于 Object.defineProperty&#xff0c;Proxy 提供了更灵活、全面的拦截能力。 1. Proxy 语法 const proxy new Proxy(target, hand…...

初次体验Tauri和Sycamore (2)

原创作者&#xff1a;庄晓立&#xff08;LIIGO&#xff09; 原创时间&#xff1a;2025年2月8日&#xff08;首次发布时间&#xff09; 原创链接&#xff1a;https://blog.csdn.net/liigo/article/details/145520637 版权所有&#xff0c;转载请注明出处。 关键词&#xff1a;Sy…...

Qt - 地图相关 —— 2、Qt调用百度在线地图功能示例全集,包含线路规划、地铁线路查询等(附源码)

效果:由于录制软件导致exe显示不正常,实际运行没有任何问题。 作者其他相关文章链接:           Qt - 地图相关 —— 1、加载百度在线地图(附源码)...

ffmpeg基本用法

一、用法 ffmpeg [options] [[infile options] -i infile]... {[outfile options] outfile}... 说明&#xff1a; global options&#xff1a;全局选项&#xff0c;应用于整个 FFmpeg 进程&#xff0c;它们通常不受输入或输出部分的限制。 infile options&#xff1a;输入选…...

redis底层数据结构——链表

文章目录 定义内部实现总结 定义 链表提供了高效的节点重排能力&#xff0c;以及顺序性的节点访间方式&#xff0c;并且可以通过增删节点来灵活地调整链表的长度。 作为一种常用数据结构&#xff0c;链表内置在很多高级的编程语言里面&#xff0c;因为Redis使用的C语言并没有…...

Repo命令使用

repo 命令与 git 类似&#xff0c;但它主要用于管理多个 Git 仓库的操作。以下是等效的 repo 命令&#xff1a; 1. 获取新仓库代码 克隆仓库 repo init -u <manifest_url> -b <branch_name> repo sync repo init&#xff1a;初始化 repo&#xff0c;指定远程清单…...

React 高级教程

使用 React 高级组件(HOC)实现的完整项目示例,包含权限控制、数据加载状态处理、性能优化等常见高级功能。创建一个简单的博客系统: // 项目结构: src/ |-- components/ | |-- ArticleList.jsx | |-- Article.jsx | |-- Header.jsx | |-- LoginForm.jsx | |-- U…...

Linux: ASoC 声卡硬件参数的设置过程简析

文章目录 1. 前言2. ASoC 声卡设备硬件参数2.1 将 DAI、Machine 平台的硬件参数添加到声卡2.2 打开 PCM 流时将声卡硬件参数配置到 PCM 流2.3 应用程序对 PCM 流参数进行修改调整 1. 前言 限于作者能力水平&#xff0c;本文可能存在谬误&#xff0c;因此而给读者带来的损失&am…...

网络基础知识与配置

目录 网络基础知识 &#xff08;一&#xff09;网络的概念 &#xff08;二&#xff09;网络协议 &#xff08;三&#xff09;网络拓扑结构 &#xff08;四&#xff09;IP地址和子网掩码 显示和配置网络接口 &#xff08;一&#xff09;在Windows系统中 &#xff08;二&a…...

【STM32】ADC|多通道ADC采集

本次实现的是ADC实现数字信号与模拟信号的转化&#xff0c;数字信号时不连续的&#xff0c;模拟信号是连续的。 1.ADC转化的原理 模拟-数字转换技术使用的是逐次逼近法&#xff0c;使用二分比较的方法来确定电压值 当单片机对应的参考电压为3.3v时&#xff0c;0~ 3.3v(模拟信…...

centos 7 关于引用stdatomic.h的问题

问题&#xff1a;/tmp/tmp4usxmdso/main.c:6:23: fatal error: stdatomic.h: No such file or directory #include <stdatomic.h> 解决步骤&#xff1a; 1.这个错误是因为缺少C编译器的标准原子操作头文件 stdatomic.h。在Linux系统中&#xff0c;我们需要安装开发工具…...

用语言模型探索语音风格空间:无需情感标签的情 感TTS

用语言模型探索语音风格空间&#xff1a;无需情感标签的情感TTS 原文&#xff1a;Exploring speech style spaces with language models: Emotional TTS without emotion labels 今天我们要说的是 一种无需情感标签的情感TTS。提出了一个基于FastSpeech2的E-TTS框架&#xff0…...

将Excel中的图片保存下载并导出

目录 效果演示 注意事项 核心代码 有需要将excel中的图片解析出来保存到本地的小伙子们看过来&#xff01;&#xff01;&#xff01; 效果演示 注意事项 仅支持xlsx格式&#xff1a;此方法适用于Office 2007及以上版本的.xlsx文件&#xff0c;旧版.xls格式无法使用。 图片名…...

2.11日学习总结

题目一 &#xff1a; AC代码 #include <stdio.h> #include <stdlib.h>// 定义长整型 typedef long long ll;// 定义求最大值和最小值的宏函数 #define MAX(a, b) ((a) > (b) ? (a) : (b)) #define MIN(a, b) ((a) < (b) ? (a) : (b))// 定义数组和变量 ll…...

安川伺服控制器MP系列优势特点及行业应用

在工业自动化领域&#xff0c;运动控制器的性能直接决定了设备的精度、效率和可靠性。作为全球领先的运动控制品牌&#xff0c;安川电机伺服控制器凭借其卓越的技术优势和广泛的应用场景&#xff0c;正在为智能制造注入强劲动力&#xff01; MP3100&#xff1a;主板型运动控制…...

【腾讯地图】录入经纬度功能 - 支持地图选点

目录 效果展示代码引入地图服务地址弹框中输入框 - 支持手动输入经纬度/地图选点按钮地图选点弹框组件 当前文章 - 地图功能与 https://blog.csdn.net/m0_53562074/article/details/143677335 功能类似 效果展示 代码 引入地图服务地址 public/index.html <!-- 互联网地图…...

Mybatis快速入门与核心知识总结

Mybatis 1. 实体类&#xff08;Entity Class&#xff09;1.1 实体类的定义1.2 简化编写1.2.1 Data1.2.2 AllArgsConstructor1.2.3 NoArgsConstructor 2. 创建 Mapper 接口2.1 Param2.2 #{} 占位符2.3 SQL 预编译 3. 配置 MyBatis XML 映射文件&#xff08;可选&#xff09;3.1 …...

RK3568平台开发系列讲解(调试篇)网卡队列均衡负载

🚀返回专栏总目录 文章目录 一、RPS 的介绍1. RPS 的工作原理2. RPS 配置3. 启用和调优 RPS4. RPS 优势二、下行测试iperf测试沉淀、分享、成长,让自己和他人都能有所收获!😄 RPS(Receive Packet Steering) 是一种用于提高网络接收性能的技术,通常用于多核处理器系统中…...

Matlab机械手碰撞检测应用

本文包含三个部分&#xff1a; Matlab碰撞检测的实现URDF文件的制作机械手STL文件添加夹爪 一.Matlab碰撞检测的实现 首先上代码 %% 检测在结构环境中机器人是否与物体之间发生碰撞情况&#xff0c;如何避免&#xff1f; % https://www.mathworks.com/help/robotics/ug/che…...

【前端】几种常见的跨域解决方案代理的概念

几种常见的跨域解决方案&代理的概念 一、常见的跨域解决方案1. 服务端配置CORS&#xff08;Cross-Origin Resource Sharing&#xff09;&#xff1a;2. Nginx代理3. Vue CLI配置代理&#xff1a;4 .uni-app在manifest.json中配置代理来解决&#xff1a;5. 使用WebSocket通讯…...