影刀RPA实战:操作Mysql数据库

1.摘要

影刀RPA(Robotic Process Automation)是一种软件自动化工具,它可以模拟人类用户执行各种重复性任务,其中包括对数据库的操作。

我们可以使用软件自动化指令,通过获取数据库窗口对象来操作数据库,也可以使用内置的操作指令来操作,相比较而言,后者更方便,相当于一个简化的数据库管理软件,依旧可以实现增删改查功能。

影刀RPA支持的数据库:

2.实战目标

本次实战的目标,就是用影刀RPA来操作数据库,实现数据增删改查,以及事务操作指令。

需要大家有一定的sql语法基础,会编写数据查询语句,数据插入,更新,删除语句,了解数据库事务

我们在数据中新建demo数据库,新建user表。我们使用这张表演示数据处理。

CREATE TABLE `wk_user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(30) DEFAULT NULL,
  `age` int(10) DEFAULT NULL,
  `job` varchar(60) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COMMENT='用户表';

3.实战代码

3.1 数据库链接指令

功能:链接数据库,获取到一个数据库管理对象,用于后续的数据处理操作。

常规设置:

  • 数据库地址: 填入数据库连接地址,如IP形式 127.0.0.1 或域名形式 mysql.yd
  • 账号:该项为Mysql用于登录的用户名
  • 密码:该项为Mysql用于登录的密码
  • 数据库名:填入需要操作的数据库名称
  • 是否开启日志:勾选后开启日志

高级设置:

  • 最大连接数:数据库池的最大连接数
  • 端口:数据连接端口
  • 是否开启事务:勾选后初始化生成一个事务对象,用于数据库事务管理
  • 字符集选择下拉框

影刀代码:

3.2 数据新增

功能:向数据库中插入一条数据,数据的格式是字典

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • 数据字典:将所需要插入的数据记录以键值对的字典类型传入

影刀代码:

演示:

批量插入数据

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • 字段列表:传入所需插入数据的字段名称 如:['col_name1','col_name2']
  • 数据字典:将所需要插入的数据以键值对的字典类型传入 如:[[val1,val2],[val3,val4]]

3.3 查询数据

功能:使用查询语句从数据库中获取数据

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • where条件:无需填入where关键字,为where关键字后语句,如果查询字符串的话,格式需要为name = '测试'
  • 字段列表:传入所需用到的字段列表 [col_name1,colname2], 为空则为全表查询

影刀代码:

运行后,我们使用打印日志,可以查看到sql语句,与获取的数据

3.4 更新数据

通过主键条件,修改数据中的数据内容

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • 数据字典:将所需要更新插入的数据记录以键值对的字典类型传入 如:{'col_name1':val1,'col_name2':val2}

影刀代码:

演示:

通过where条件,修改数据中的数据内容

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • 数据字典:将所需要更新的数据库记录以键值对的字典类型传入 如:{'col_name1':val1,'col_name2':val2}
  • where条件:无需填入where关键字,为where关键字后语句,例如 name = '测试'

影刀指令

演示:

依据主键条件,批量更新插入数据

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • 字段列表:传入所需插入数据记录的字段名称 如:['col_name1','col_name2']
  • 数据字典:将所需要插入的数据以键值对的字典类型传入 如:[[val1,val2],[val3,val4]]

3.5 删除数据

功能:从数据库中删除数据,可以设置删除条件

  • 数据库池对象:传入初始化创建的数据库池对象
  • 事务管理器:传入当前的事务管理器 (开启事务后传入)
  • 表名:传入需要插入数据的表名称
  • where条件:无需填入where关键字,为where关键字后语句

影刀代码:

演示:

3.6 事务操作

数据库事务是数据库管理系统中用于处理数据操作的一个单位,它包含了一系列操作,这些操作要么全部成功,要么全部失败。事务的目的是确保数据库的完整性和一致性,即使在系统故障或并发操作的情况下也能保持数据的正确性

数据库事务通常具有以下四个关键特性,即ACID属性:

  • 原子性(Atomicity):事务中的所有操作要么全部完成,要么全部不完成。如果事务中的某个操作失败,整个事务将回滚到操作前的状态。

  • 一致性(Consistency):事务必须确保数据库从一个一致性状态转换到另一个一致性状态。这意味着事务执行过程中和执行结束后,数据库都必须处于一致性状态。

  • 隔离性(Isolation):并发执行的事务之间不会相互影响。每个事务都像是在一个独立的环境中执行,对其他事务不可见,直到事务完成。

  • 持久性(Durability):一旦事务被提交,它对数据库的修改就是永久性的。即使系统发生故障,事务的结果也不会丢失。

事务的这些特性确保了即使在并发操作和系统故障的情况下,数据库也能保持数据的完整性和一致性。在数据库操作中,事务的使用是非常重要的,它帮助开发者管理复杂的数据操作,确保数据的准确性和可靠性。

数据库事务操作指令包含开启,提交和回滚事务。

如果程序没有保存,我们就提交事务,执行sql语句

如果程序报错,我们就回滚事务,将之前的数据处理恢复成原样。

在操作过程中,我们一般使用try catch指令一起使用,将执行的sql语句包起来,并开启事务,执行的过程中,有错误会走catch代码块,程序直接事务回滚,没有错误就直接提交事务,完成事务操作

3.7 数据库关闭

功能:关闭数据库,释放资源

  • 数据库池对象:数据库的连接对象
  • 强制关闭连接并回滚:有时候连接卡死了,可以选择强制关闭连接并进行事务的回滚

4.应用优势

  • 批量插入数据:影刀RPA支持将大量数据分批次插入到数据库中,支持MySQL、SQL Server和Oracle等数据库类型。用户需要提供数据库地址、用户名、密码、数据库名、SQL语句以及待插入的数据。它还允许设置单次连接插入的数量,以避免因频繁连接和断开数据库而导致的错误。

  • 数据自动化操作:影刀RPA可以自动化执行数据获取、清洗、报表生成等操作。它能够连接到不同的数据库,执行SQL查询,并将结果用于进一步的数据处理和分析。

  • 数据库连接和使用:用户可以通过影刀RPA连接到数据库,执行SQL语句,并返回结果集。支持两种连接方式:数据库连接对象和数据库连接字符串。用户可以保存查询结果至变量,以便后续流程使用。

  • **减少开发需求:**通常情况下,有些功能我们都是使用编程语言实现,比如使用java导出excel数据,但是导出的需求太多,功能代码就会增多,影刀RPA就可以解决这个难题,对于常用固定的我们写出功能,临时提出的我们使用影刀RAP从数据库提取数据,写入excel中。方便快捷。

  • **影刀支持缓存数据库redis:**操作数据库获取数据,直接写入redis,比我们之前使用代码链接数据库在写入更快,减少了代码编写,部署发布的流程,并且我们可以在影刀上实时查询,检查数据的准确性

5.最后

相关推荐
Elastic 中国社区官方博客4 分钟前
设计新的 Kibana 仪表板布局以支持可折叠部分等
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索·kibana
阿俊仔(摸鱼版)4 分钟前
Python 常用运维模块之Shutil 模块
linux·服务器·python·自动化·云服务器
深蓝海拓26 分钟前
Pyside6(PyQT5)中的QTableView与QSqlQueryModel、QSqlTableModel的联合使用
数据库·python·qt·pyqt
hhzz44 分钟前
ansible自动化运维实战--script、unarchive和shell模块(6)
运维·自动化·ansible
C嘎嘎嵌入式开发2 小时前
什么是僵尸进程
服务器·数据库·c++
Yeats_Liao4 小时前
Navicat 导出表结构后运行查询失败ERROR 1064 (42000): You have an error in your SQL syntax;
数据库·sql
明月看潮生5 小时前
青少年编程与数学 02-007 PostgreSQL数据库应用 15课题、备份与还原
数据库·青少年编程·postgresql·编程与数学
明月看潮生5 小时前
青少年编程与数学 02-007 PostgreSQL数据库应用 14课题、触发器的编写
数据库·青少年编程·postgresql·编程与数学
加酶洗衣粉9 小时前
MongoDB部署模式
数据库·mongodb
Suyuoa9 小时前
mongoDB常见指令
数据库·mongodb