编写脚本批量插入MariaDB数据库可以使用各种脚本语言,比如Python、Shell脚本或者直接使用SQL脚本,这里结合使用Shell脚本和MySQL命令行工具(mysql)来实现。
这个Shell脚本示例展示了如何使用循环和MySQL命令行工具批量插入数据到MariaDB数据库中,其中 LOCATION 字段被视为整数类型。根据实际需求,你可以调整循环生成数据的方式和递增的逻辑。
#!/bin/bash
# 数据库连接参数
DB_USER="your_username"
DB_PASS="your_password"
DB_HOST="localhost"
DB_NAME="your_database_name"
# 定义要插入的数据行数
NUM_ROWS=10
# 开始的 task_id
START_TASK_ID=1001000000000
# 循环生成并插入数据
for (( i=0; i<$NUM_ROWS; i++ )); do
TASK_ID=$((START_TASK_ID + i))
LOCATION=$((10010001 + i)) # 假设 LOCATION 递增
TIME=$((1630451000 + i * 3600))
# 构建插入语句
INSERT_SQL="INSERT INTO tb_carrier_installed_info (task_id, location, time) VALUES ($TASK_ID, $LOCATION, $TIME);"
# 使用 MySQL 命令行工具执行插入操作
mysql -u"$DB_USER" -p"$DB_PASS" -h"$DB_HOST" "$DB_NAME" -e "$INSERT_SQL"
done
echo "批量插入完成"
Shell脚本逻辑:
使用 for 循环生成要插入的数据。在每次循环中,计算 TASK_ID、LOCATION 和 TIME。
- TASK_ID 从 START_TASK_ID 开始递增。
- LOCATION 作为整数类型,假设按某种逻辑递增。
- TIME 假设每次递增一个小时的时间戳。
- 构建插入语句: 使用变量构建每次循环的插入语句 INSERT_SQL,确保 LOCATION 是整数类型。
- 执行插入操作: 使用 mysql 命令行工具连接到数据库,并执行每次循环生成的插入语句。
- 数据库连接参数: 替换 DB_USER、DB_PASS、DB_HOST 和 DB_NAME 为你的实际数据库连接参数。
- 确认插入完成: 脚本执行完成后输出 “批量插入完成”。