20.Oracle11g中的触发器

oracle11g中的触发器

  • 一、触发器的概述
    • 1、什么是触发器
    • 2、触发器的类型
    • 3、触发器的组成
    • 4、触发器的作用
  • 二、触发器的创建语法
    • 1、创建语法
    • 2、数据库启动触发器
    • 3、 用户登录触发器:
  • 三、对触发器的基本操作
  • 点击此处跳转下一节:21.Oracle的程序包(Package)

一、触发器的概述

1、什么是触发器

触发器是一种特殊的存储过程,它是一段PL/SQL代码,可以在特定的数据库操作(如INSERT、UPDATE、DELETE)发生时自动执行。触发器可以用来实现数据约束、数据审计、数据复制等功能。

  • 触发器是当特定事件出现时自动执行的存储过程
    • 提供审计和日志记录
    • 启用复杂的业务逻辑
  • 特定事件可以是执行更新的DML语句和DDL语句
    • 自动生成数据
    • 自定义复杂的安全权限
  • 触发器不能被显式调用

2、触发器的类型

在这里插入图片描述

Oracle11g中的DML触发器分为三种类型:

  • 行级触发器:对于每一行数据的操作都会触发该触发器。
  • 语句级触发器:对于每一条SQL语句的操作都会触发该触发器。
  • 复合触发器:既可以作为行级触发器,也可以作为语句级触发器。

3、触发器的组成

  1. 常见触发器由以下三部分组成

    • 触发器语句(事件)
      • 定义激活触发器的 DML 事件和 DDL 事件
    • 触发器限制
      • 执行触发器的条件,该条件必须为真才能激活触发器
    • 触发器操作(主体)
      • 包含一些 SQL 语句和代码,它们在发出了触发器语句且触发限制的值为真时运行
  2. 在Oracle 11g中,触发器由以下几个主要组成部分构成

    • 触发器名称(Trigger Name)
      • 触发器的名称是唯一的,用于标识触发器。在创建触发器时,需要为触发器指定一个名称,并且在数据库中触发器的名称是唯一的。
    • 触发时机(Triggering Event)
      • 触发器可以在不同的操作时机被触发,包括BEFOREAFTERINSTEAD OFBEFORE表示在操作执行之前触发,AFTER表示在操作执行之后触发,INSTEAD OF用于视图触发器。
    • 触发的操作类型(Triggering Action)
      • 触发器可以响应不同类型的数据库操作,包括INSERTUPDATEDELETE等。此外,还可以使用组合形式,比如INSERT OR UPDATEUPDATE OR DELETE等。
    • 触发的表(Triggering Table)
      • 触发器可以绑定到特定的数据库表上,当表上的操作符合触发条件时,触发器会被激活。
    • 触发器逻辑(Trigger Logic)
      • 触发器逻辑定义了触发器被激活时所执行的操作。这部分通常包含在BEGINEND之间,可以包括各种PL/SQL语句和逻辑。
    • 引用新旧值(Referencing New/Old Values)
      • 在行级触发器中,可以使用NEWOLD关键字来引用被操作的行的新旧值。这样可以在触发器逻辑中对新旧值进行比较和操作。
    • 触发条件(Trigger Condition)
      • 在行级触发器中,可以使用WHEN关键字来指定触发条件,只有当条件满足时触发器才会被激活。
    • 触发器类型(Trigger Type)
      • 触发器可以是行级触发器(FOR EACH ROW)或者语句级触发器(FOR EACH STATEMENT)。行级触发器会在每行被操作时触发,而语句级触发器会在每个SQL语句执行时触发。

    以上是Oracle 11g触发器的主要组成部分,了解这些组成部分可以帮助我们更好地理解和设计触发器,以满足特定的业务需求。

4、触发器的作用

  1. 实现数据约束:通过触发器可以对特定的数据库操作进行限制,从而保证数据的完整性和一致性。

    当使用触发器实现数据约束时,可以在触发器中编写逻辑来检查插入、更新或删除的数据是否符合特定的约束条件。以下是一个简单的示例,演示了如何使用触发器实现数据约束:

    假设我们有一个名为employee的表,包含以下字段:employee_id, employee_name, salary。我们希望在每次更新员工的薪水时,自动检查薪水是否在有效范围内(例如,不能低于最低工资,不能高于最高工资)。

    首先,我们创建一个触发器,当有员工的薪水被更新时,自动检查薪水是否在有效范围内。

    CREATE OR REPLACE TRIGGER check_salary_range_trigger
    BEFORE UPDATE OF salary ON employee
    FOR EACH ROW
    BEGIN
        IF :NEW.salary < 1000 THEN
            RAISE_APPLICATION_ERROR(-20001, 'Salary cannot be less than 1000');
        ELSIF :NEW.salary > 100000 THEN
            RAISE_APPLICATION_ERROR(-20002, 'Salary cannot exceed 100000');
        END IF;
    END;
    /
    

    在上面的代码中,我们创建了一个名为check_salary_range_trigger的触发器。它是一个行级触发器(FOR EACH ROW),当员工的薪水被更新前(BEFORE UPDATE OF salary ON employee)触发器会检查薪水是否在有效范围内。如果薪水不在有效范围内,触发器会抛出一个自定义的应用程序错误,从而阻止薪水更新操作。

    现在,当我们尝试更新员工的薪水时,触发器会自动检查薪水是否在有效范围内,如果不符合约束条件,更新操作将被阻止并抛出相应的错误信息。

    这就是一个简单的触发器示例,说明了触发器在实现数据约束功能时的作用。其他的数据约束也可以通过类似的方式在触发器中实现。


  2. 实现数据审计:通过触发器可以记录特定的数据库操作,从而实现数据审计的功能。

    假设我们有一个名为employee的表,包含以下字段:employee_id, employee_name, salary。我们希望在每次有新员工加入时,自动记录员工加入的时间。

    首先,我们创建一个新的表employee_audit,用于记录员工加入的时间。表的结构如下:

    CREATE TABLE employee_audit (
        employee_id NUMBER,
        join_date DATE
    );
    

    接下来,我们创建一个触发器,当有新员工加入时,自动将员工的ID和加入时间插入到employee_audit表中。

    CREATE OR REPLACE TRIGGER employee_join_trigger
    AFTER INSERT ON employee
    FOR EACH ROW
    BEGIN
        INSERT INTO employee_audit (employee_id, join_date)
        VALUES (:NEW.employee_id, SYSDATE);
    END;
    /
    

    在上面的代码中,我们创建了一个名为employee_join_trigger的触发器。它是一个行级触发器(FOR EACH ROW),当有新的员工被插入(AFTER INSERT ON employee)时,触发器会将员工的ID和加入时间插入到employee_audit表中。

    现在,当我们向employee表中插入新的员工记录时,触发器会自动将员工的ID和加入时间记录到employee_audit表中,从而实现了数据审计的功能。

    这就是一个简单的触发器示例,说明了触发器在实现数据审计功能时的作用。其他的触发器功能也可以通过类似的方式实现。


  3. 实现数据复制:通过触发器可以在不同的数据库之间实现数据的复制。

    当使用触发器实现数据复制时,可以在触发器中编写逻辑来将插入、更新或删除的数据复制到另一个表中。以下是一个简单的示例,演示了如何使用触发器实现数据复制:

    假设我们有一个名为employee的表,包含以下字段:employee_id, employee_name, salary。我们希望在每次有新员工加入时,自动将员工的信息复制到另一个表employee_copy中。

    首先,我们创建一个新的表employee_copy,用于存储复制的员工信息。表的结构与employee表相同。

    CREATE TABLE employee_copy (
        employee_id NUMBER,
        employee_name VARCHAR2(100),
        salary NUMBER
    );
    

    接下来,我们创建一个触发器,当有新员工加入时,自动将员工的信息复制到employee_copy表中。

    CREATE OR REPLACE TRIGGER employee_copy_trigger
    AFTER INSERT ON employee
    FOR EACH ROW
    BEGIN
        INSERT INTO employee_copy (employee_id, employee_name, salary)
        VALUES (:NEW.employee_id, :NEW.employee_name, :NEW.salary);
    END;
    /
    

    在上面的代码中,我们创建了一个名为employee_copy_trigger的触发器。它是一个行级触发器(FOR EACH ROW),当有新的员工被插入(AFTER INSERT ON employee)时,触发器会将员工的ID、姓名和薪水插入到employee_copy表中。

    现在,当我们向employee表中插入新的员工记录时,触发器会自动将员工的信息复制到employee_copy表中,从而实现了数据复制的功能。

    这就是一个简单的触发器示例,说明了触发器在实现数据复制功能时的作用。其他的数据复制也可以通过类似的方式在触发器中实现。


  4. 实现业务逻辑:通过触发器可以实现特定的业务逻辑,从而简化应用程序的开发和维护。

    假设我们有一个名为orders的表,包含以下字段:order_id, order_date, total_amount。我们希望在每次有新订单插入时,自动更新客户的最近订单日期。

    以下是一个示例代码,演示了如何使用触发器实现这个业务逻辑:

    首先,我们创建一个名为customer的表,包含以下字段:customer_id, customer_name, last_order_datelast_order_date字段用于存储客户的最近订单日期。

    CREATE TABLE customer (
        customer_id NUMBER,
        customer_name VARCHAR2(100),
        last_order_date DATE
    );
    

    接下来,我们创建一个触发器,当有新订单插入时,自动更新客户的最近订单日期。

    CREATE OR REPLACE TRIGGER update_last_order_date_trigger
    AFTER INSERT ON orders
    FOR EACH ROW
    BEGIN
        UPDATE customer
        SET last_order_date = :NEW.order_date
        WHERE customer_id = :NEW.customer_id;
    END;
    /
    

    在上面的代码中,我们创建了一个名为update_last_order_date_trigger的触发器。它是一个行级触发器(FOR EACH ROW),当有新的订单被插入(AFTER INSERT ON orders)时,触发器会自动更新对应客户的最近订单日期。

    现在,当我们向orders表中插入新的订单记录时,触发器会自动更新对应客户的最近订单日期,从而实现了业务逻辑的功能。

    这就是一个简单的触发器示例,说明了触发器在实现业务逻辑时的作用。其他的业务逻辑也可以通过类似的方式在触发器中实现。


  5. 实现性能优化:通过触发器可以对特定的数据库操作进行优化,从而提高系统的性能。

    触发器可以用于实现性能优化,例如在数据更新时进行一些计算或者更新其他相关的数据。以下是一个示例代码,演示了如何使用触发器实现性能优化:

    假设我们有一个名为order_items的表,包含以下字段:order_id, item_id, quantity, unit_price。我们希望在每次插入或更新订单项时,自动更新订单的总金额。

    首先,我们创建一个名为orders的表,包含以下字段:order_id, order_date, total_amounttotal_amount字段用于存储订单的总金额。

    CREATE TABLE orders (
        order_id NUMBER,
        order_date DATE,
        total_amount NUMBER
    );
    

    接下来,我们创建一个触发器,当有新的订单项插入或更新时,自动更新订单的总金额。

    CREATE OR REPLACE TRIGGER update_order_total_amount_trigger
    AFTER INSERT OR UPDATE ON order_items
    FOR EACH ROW
    BEGIN
        IF INSERTING THEN
            UPDATE orders
            SET total_amount = total_amount + (:NEW.quantity * :NEW.unit_price)
            WHERE order_id = :NEW.order_id;
        ELSIF UPDATING THEN
            UPDATE orders
            SET total_amount = total_amount - (:OLD.quantity * :OLD.unit_price) + (:NEW.quantity * :NEW.unit_price)
            WHERE order_id = :NEW.order_id;
        END IF;
    END;
    /
    

    在上面的代码中,我们创建了一个名为update_order_total_amount_trigger的触发器。它是一个行级触发器(FOR EACH ROW),当有新的订单项被插入或更新(AFTER INSERT OR UPDATE ON order_items)时,触发器会自动更新对应订单的总金额。

    在触发器中,我们使用了条件语句来区分插入和更新操作,以便在每种情况下都能正确更新订单的总金额。

    现在,当我们向order_items表中插入或更新订单项时,触发器会自动更新对应订单的总金额,从而实现了性能优化的功能。

    这就是一个简单的触发器示例,说明了触发器在实现性能优化时的作用。其他的性能优化也可以通过类似的方式在触发器中实现。


总之,触发器是Oracle数据库中非常重要的一个功能,它可以帮助我们实现很多有用的功能,并且可以提高系统的性能和可维护性。在使用触发器时,需要注意避免过度使用,以免对系统性能产生负面影响。


二、触发器的创建语法

1、创建语法

在Oracle 11g中,可以使用以下语法来创建触发器:

CREATE [OR REPLACE] TRIGGER trigger_name
{BEFORE | AFTER | INSTEAD OF} {INSERT | UPDATE | DELETE | {INSERT OR UPDATE} | {UPDATE OR DELETE} | {INSERT OR DELETE} | {INSERT OR UPDATE OR DELETE}}
ON table_name
[REFERENCING {NEW AS new | OLD AS old | NEW AS new OLD AS old}]
[FOR EACH ROW | FOR EACH STATEMENT]
[WHEN (condition)]
BEGIN
    -- 触发器逻辑
END;
/

下面是对上述语法中各个部分的详细介绍:

  1. CREATE [OR REPLACE] TRIGGER trigger_name:用于创建一个新的触发器。OR REPLACE关键字表示如果同名的触发器已经存在,则替换掉原有的触发器。

  2. {BEFORE | AFTER | INSTEAD OF}:指定触发器的触发时机,BEFORE表示在操作执行前触发,AFTER表示在操作执行后触发,INSTEAD OF用于视图触发器。

  3. {INSERT | UPDATE | DELETE | {INSERT OR UPDATE} | {UPDATE OR DELETE} | {INSERT OR DELETE} | {INSERT OR UPDATE OR DELETE}}:指定触发器要响应的操作类型。可以是单个操作类型,也可以是多个操作类型的组合。

  4. ON table_name:指定触发器要绑定的表名。

  5. [REFERENCING {NEW AS new | OLD AS old | NEW AS new OLD AS old}]:用于在触发器逻辑中引用新旧值。NEW表示新值,OLD表示旧值。

  6. [FOR EACH ROW | FOR EACH STATEMENT]:指定触发器是行级触发器还是语句级触发器。FOR EACH ROW表示行级触发器,FOR EACH STATEMENT表示语句级触发器。

  7. [WHEN (condition)]:可选项,用于在行级触发器中指定触发条件。

  8. BEGIN ... END;:在BEGINEND之间包含了触发器的逻辑代码。

  9. 触发器逻辑:在BEGINEND之间的部分是触发器的逻辑代码,用于定义触发器要执行的操作。

  10. /:表示SQL语句的结束。

通过以上语法,可以在Oracle 11g中创建各种类型的触发器,用于实现特定的业务逻辑或性能优化。

2、数据库启动触发器

数据库启动触发器是在数据库启动时自动执行的触发器,它可以用于执行一些初始化操作。在Oracle数据库中,可以使用AFTER STARTUP触发器来实现数据库启动触发器。以下是一个简单的示例:

CREATE OR REPLACE TRIGGER startup_trigger
AFTER STARTUP
ON DATABASE
BEGIN
  -- 在数据库启动时执行的操作
  DBMS_OUTPUT.PUT_LINE('Database has been started');
  -- 可以在这里添加其他需要执行的初始化操作
END;
/

在上面的示例中,我们创建了一个名为startup_trigger的触发器,它在数据库启动后执行。在触发器的BEGINEND之间可以编写需要在数据库启动时执行的操作。

示例如下:
这段SQL包含了两部分操作:

CREATE TABLE event_table (event varchar2(30), 
                          time  date);

这部分SQL用来创建一个名为event_table的表,表中包含了事件(event)和时间(time)两个字段。这个表似乎是用来记录不同事件和它们发生的时间。

CREATE OR REPLACE TRIGGER tr_startup
  AFTER startup ON DATABASE
BEGIN
  INSERT INTO event_table VALUES (ora_sysevent, SYSDATE);
END;

这部分SQL用来创建一个名为tr_startup的触发器,它是一个“after startup”类型的触发器,意味着它会在数据库启动后触发。当数据库启动时,触发器会将当前系统事件(ora_sysevent)和当前时间(sysdate)插入到event_table表中。

这样,当数据库启动时,触发器会自动将相关信息记录到event_table表中,从而实现了记录数据库启动事件的功能。

3、 用户登录触发器:

用户登录触发器是在用户登录到数据库时自动执行的触发器,它可以用于记录用户登录信息、执行安全检查等操作。在Oracle数据库中,可以使用AFTER LOGON触发器来实现用户登录触发器。以下是一个简单的示例:

CREATE OR REPLACE TRIGGER login_trigger
AFTER LOGON
ON DATABASE
BEGIN
  -- 在用户登录时执行的操作
  DBMS_OUTPUT.PUT_LINE('User ' || USER || ' has logged in');
  -- 可以在这里添加其他与用户登录相关的操作
END;
/

在上面的示例中,我们创建了一个名为login_trigger的触发器,它在用户登录后执行。在触发器的BEGINEND之间可以编写需要在用户登录时执行的操作,例如记录用户登录信息、执行权限检查等。
示例如下:

CREATE TABLE log_table(username  varchar2(20), 
                       logon_time  date, 
                       logoff_time  date, 
                       address varchar2(20));

这部分SQL用来创建一个名为log_table的表,表中包含了用户名(username)、登录时间(logon_time)、登出时间(logoff_time)和地址(address)等字段。

CREATE OR REPLACE TRIGGER tr_logon
  AFTER logon ON DATABASE
BEGIN
  INSERT INTO log_table
    (username, logon_time, address)
  VALUES
    (ora_login_user, SYSDATE, ora_client_ip_address);
END;

这部分SQL用来创建一个名为tr_logon的触发器,它是一个“after logon”类型的触发器,意味着它会在用户登录后触发。当用户登录时,触发器会将当前登录用户(ora_login_user)、登录时间(sysdate)和客户端IP地址(ora_client_ip_address)插入到log_table表中。

oracle常用系统变量
	- Ora_client_ip_address 返回客户端的ip地址
	- Ora_database_name 返回当前数据库名
	- Ora_login_user 返回登录用户名
	- Ora_dict_obj_name 返回ddl操作所对应的数据库对象名 
	- Ora_dict_obj_type 返回ddl操作所对应的数据库对象的类型  

oracle常用系统变量

这样,当用户登录数据库时,触发器会自动将相关信息记录到log_table表中,从而实现了用户登录日志的记录功能。


通过使用数据库启动触发器和用户登录触发器,可以在数据库启动和用户登录时执行一些必要的操作,从而提高数据库的安全性和可靠性。

三、对触发器的基本操作

在Oracle 11g中,可以通过以下方式对触发器进行基本操作:启用、禁用、删除、查看触发器的基本信息。

  1. 启用触发器:

    ALTER TRIGGER trigger_name ENABLE;
    
  2. 禁用触发器:

    ALTER TRIGGER trigger_name DISABLE;
    
  3. 删除触发器:

    DROP TRIGGER trigger_name;
    
  4. 查看触发器的基本信息:

    SELECT trigger_name, table_name, triggering_event
    FROM user_triggers;
    

    这条查询语句将返回当前用户拥有的所有触发器的名称(trigger_name)、所属表名(table_name)和触发事件(triggering_event)的信息。

通过以上操作,可以对Oracle 11g中的触发器进行启用、禁用、删除以及查看基本信息的操作。

点击此处跳转下一节:21.Oracle的程序包(Package)

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

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

相关文章

Opencv框选黑色字体进行替换(涉及知识点:selectROI,在控制台输入字体大小,颜色,内容替换所选择的区域)

import cv2 from PIL import Image,ImageDraw,ImageFont import numpy as npimg_path ../img/ img_clean_path ../img_clean/ name xiao_ben suf .pngimg cv2.imread(img_pathnamesuf) cv2.imshow(original, img)# 选择ROI roi cv2.selectROI(windowName"original&q…

面试题:项目中如何解决跨域问题(HttpClient、注解、网关)

文章目录 为什么会有跨域问题常见的跨域解决方式网关整合项目中使用Httpclient 为什么会有跨域问题 因为浏览器的同源政策&#xff0c;就会产生跨域。比如说发送的异步请求是不同的两个源&#xff0c;就比如是不同的的两个端口或者不同的两个协议或者不同的域名。由于浏览器为…

Java毕业设计 SSM SpringBoot vue 夜市摊位管理系统

Java毕业设计 SSM SpringBoot vue 夜市摊位管理系统 SSM SpringBoot vue 夜市摊位管理系统 功能介绍 首页 图片轮播 通知公告 留言反馈 摊位信息 摊位详情 收藏 评论 赞 踩 登录注册 个人中心 更新信息 我的收藏 大数据夜市摊位统计 系统介绍 后台管理 登录 轮博图管理 通知…

【STM32】STM32学习笔记-课程简介(01)

00. 目录 文章目录 00. 目录01. 课程简介02. 硬件设备03. 软件工具04. 硬件套件4.1 面包板和跳线/飞线4.2 杜邦线和STM32最小系统板4.3 STLINK和OLED显示屏4.4 LED和按键4.5 电位器和蜂鸣器4.6 传感器和旋转编码器4.7 USB转串口和MPU60504.8 Flash闪存和电机模块4.9 SG90舵机 0…

geemap学习笔记015:下载哨兵2号(Sentinel-2)数据

前言 使用GEE下载数据应该是最常见的功能了&#xff0c;今天就介绍一下如何使用geemap下载哨兵2号(Sentinel-2)数据&#xff0c;分别包括自己画感兴趣&#xff0c;以及利用Assets中的shp文件进行下载。 1 自己画感兴趣下载哨兵2号影像 import geemap import eeMap geemap.M…

c++--类型行为控制

1.c的类 1.1.c的类关键点 c类型的关键点在于类存在继承。在此基础上&#xff0c;类存在构造&#xff0c;赋值&#xff0c;析构三类通用的关键行为。 类型提供了构造函数&#xff0c;赋值运算符&#xff0c;析构函数来让我们控制三类通用行为的具体表现。 为了清楚的说明类的构…

百度智能云推出“千帆AI原生应用开发工作台” 助力开发者创新

在这个智能互联的世界&#xff0c;每一次技术的飞跃都预示着无限可能。你是否曾梦想&#xff0c;一款产品能够打破创新的边界&#xff0c;让开发不再是高门槛的技术挑战&#xff1f;12月20日&#xff0c;百度云智大会智算大会将为你揭开这幕神秘面纱——“千帆AI原生应用开发工…

Python中的并发编程

目录 一、引言 二、Python中的线程 1、线程的概念 2、创建线程 3、线程同步和锁 4、线程池 三、Python中的进程 1、进程的概念 2、创建进程 四、Python中的异步IO 1、异步IO的概念 2、异步IO的实现 3、异步IO的并发执行 五、总结 一、引言 并发编程是一种计算机…

消息中间件——RabbitMQ(七)高级特性 2

前言 上一篇消息中间件——RabbitMQ&#xff08;七&#xff09;高级特性 1中我们介绍了消息如何保障100%的投递成功&#xff1f;,幂等性概念详解,在海量订单产生的业务高峰期&#xff0c;如何避免消息的重复消费的问题&#xff1f;,Confirm确认消息、Return返回消息。这篇我们…

LLM推理部署(四):一个用于训练、部署和评估基于大型语言模型的聊天机器人的开放平台FastChat

FastChat是用于对话机器人模型训练、部署、评估的开放平台。体验地址为&#xff1a;https://chat.lmsys.org/&#xff0c;该体验平台主要是为了收集人类的真实反馈&#xff0c;目前已经支持30多种大模型&#xff0c;已经收到500万的请求&#xff0c;收集了10万调人类对比大模型…

6-69.鸭子也是鸟

按要求完成下面的程序&#xff1a; 1、定义一个Bird类&#xff0c;包含一个void类型的无参的speak方法&#xff0c;输出“Jiu-Jiu-Jiu”。 2、定义一个Duck类&#xff0c;公有继承自Bird类&#xff0c;其成员包括&#xff1a; &#xff08;1&#xff09;私有string类型的成员na…

4个解决特定的任务的Pandas高效代码

在本文中&#xff0c;我将分享4个在一行代码中完成的Pandas操作。这些操作可以有效地解决特定的任务&#xff0c;并以一种好的方式给出结果。 从列表中创建字典 我有一份商品清单&#xff0c;我想看看它们的分布情况。更具体地说&#xff1a;希望得到唯一值以及它们在列表中出…

【高效开发工具系列】jackson入门使用

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

指针的综合运用第二期

1.指针数组 char *arr[5];//字符指针数组 int *arr[5];//整型指针数组 int ADD(int x,int y) { return xy; } int LOSE(int a,int b) { return a-b; } int *pa(int,int)ADD; int *pb(int,int)LOSE;//函数指针 int (*pc[2])(int,int){ADD,LOSE};//函数指针数组 //调用直接按数组…

VisionPro---PatMaxTool工具使用

CogPMAlignTool PatMax是一种图案位置搜索技术&#xff08;识别定位&#xff09;&#xff0c;PatMax图案不依赖于像素格栅&#xff0c;是基于边缘特征的模板匹配而不是基于像素的模板匹配&#xff0c;支持图像中特征的旋转与缩放&#xff0c;边缘特征表示图像中不同区域间界限…

数据链路层之广域网、PPP协议、HDLC协议

学习的最大理由是想摆脱平庸&#xff0c;早一天就多一份人生的精彩&#xff1b;迟一天就多一天平庸的困扰。各位小伙伴&#xff0c;如果您&#xff1a; 想系统/深入学习某技术知识点… 一个人摸索学习很难坚持&#xff0c;想组团高效学习… 想写博客但无从下手&#xff0c;急需…

内部培训平台的系统 PlayEdu搭建私有化内部培训平台

PlayEdu是由白书科技团队多年经营的线上教育系统&#xff0c;专为企业提供的全新企业培训方案 我们的目标是为更多的企业机构搭建私有化内部培训平台&#xff0c;以满足不断增长的培训需求 通过PlayEdu&#xff0c;企业可以有效地组织和管理培训资源&#xff0c;提供高质量的…

Leetcode—1423.可获得的最大点数【中等】

2023每日刷题&#xff08;四十八&#xff09; Leetcode—1423.可获得的最大点数 思路&#xff1a;逆向求长为 n−k 的连续子数组和的最小值 参考灵茶山艾府题解 实现代码 class Solution { public:int maxScore(vector<int>& cardPoints, int k) {int mins 0, …

nodejs基于vue的社区物业缴费报修管理系统7vwc6

运行软件:vscode 前端nodejsvueElementUi 语言 node.js 框架&#xff1a;Express/koa 前端:Vue.js 数据库&#xff1a;mysql 开发软件&#xff1a;VScode/webstorm/hbuiderx均可 数据库用MySQL,后台用vue框架 基本要求&#xff1a; 1. 对项目进行详细实际的需求分析。 2. 在网…

Java项目调用C/C++ SDK的方案汇总

Java项目调用C/C SDK的方案汇总 背景调研JNIJNativeJNAJavaCPP 背景 Java项目中需要调用到一个C项目&#xff0c;于是对目前通用的解决方案做了一些调研&#xff0c;这里做一个汇总。 调研 JNI JNI&#xff1a;Java Native Interface&#xff0c;JNI是一套编程接口&#xf…