Bash语言的数据库编程
Bash语言的数据库编程
引言
在现代软件开发中,数据库编程是一个不可或缺的部分。从小型项目到大型系统,数据库通常是存储和管理数据的核心。然而,许多开发者往往将焦点放在高级编程语言如Python、Java或C#上,忽视了Shell脚本语言的重要性。特别是Bash(Bourne Again SHell),作为Linux系统的默认Shell,已经成为系统管理员和DevOps工程师日常工作的基础。通过本文,我们将探索Bash语言在数据库编程中的应用。
为什么选择Bash?
在深入讨论之前,我们先来看看为什么选择Bash作为数据库编程的工具。
-
简单易用:Bash语言非常简单且直观,尤其适合那些对编程并不太熟悉的用户。
-
脚本化运维:对于系统管理员来说,Bash脚本可以自动化数据库的备份、恢复和监控等任务。
-
命令行操作:许多数据库管理系统(DBMS)都提供了命令行接口,Bash可以轻松调用这些命令进行数据库操作。
-
跨平台支持:虽然Bash主要在Unix/Linux环境中运行,但通过Windows Subsystem for Linux(WSL)等工具,Windows用户也可以使用Bash。
Bash与数据库的交互
Bash与数据库之间的互动主要通过命令行工具来实现。大多数数据库系统,如MySQL、PostgreSQL和SQLite,都提供了命令行客户端,允许用户通过命令行执行SQL查询和管理任务。
1. 基于MySQL的Bash数据库编程
MySQL是一种开源关系数据库管理系统,广泛应用于许多网络应用中。通过Bash与MySQL进行交互,我们可以完成数据库的增、删、改、查等基本操作。
1.1 连接到MySQL数据库
首先,我们需要在Bash中连接到MySQL数据库。以下是连接MySQL的基本命令:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
mysql -u $DB_USER -p$DB_PASS $DB_NAME ```
上述脚本通过mysql命令连接到指定的数据库。注意,-p后面没有空格,直接跟密码。
1.2 执行查询
连接成功后,我们可以执行SQL查询。以下是一个示例,查询表中的所有数据:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
mysql -u $DB_USER -p$DB_PASS -e "SELECT * FROM your_table;" $DB_NAME ```
1.3 插入数据
我们还可以使用Bash脚本向数据库中插入数据。下面是插入一条新记录的示例:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
mysql -u $DB_USER -p$DB_PASS -e "INSERT INTO your_table (column1, column2) VALUES ('value1', 'value2');" $DB_NAME ```
1.4 更新和删除
当然,我们也可以通过Bash来更新和删除记录。以下是更新和删除的示例代码:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
更新数据
mysql -u $DB_USER -p$DB_PASS -e "UPDATE your_table SET column1='new_value' WHERE column2='value2';" $DB_NAME
删除数据
mysql -u $DB_USER -p$DB_PASS -e "DELETE FROM your_table WHERE column1='value1';" $DB_NAME ```
2. 基于PostgreSQL的Bash数据库编程
PostgreSQL是一种功能强大的开源关系数据库,提供了丰富的功能。同样,我们可以通过Bash与PostgreSQL进行交互。
2.1 连接到PostgreSQL数据库
使用psql命令连接到PostgreSQL数据库,示例如下:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
export PGPASSWORD=$DB_PASS psql -U $DB_USER -d $DB_NAME -c "SELECT * FROM your_table;" ```
2.2 执行查询
执行查询的方式与MySQL相似,只需将SQL命令传递给psql即可。
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
export PGPASSWORD=$DB_PASS psql -U $DB_USER -d $DB_NAME -c "SELECT * FROM your_table;" ```
2.3 插入、更新和删除
插入、更新和删除数据的方式与MySQL基本相似,如下示例:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database"
export PGPASSWORD=$DB_PASS
插入数据
psql -U $DB_USER -d $DB_NAME -c "INSERT INTO your_table (column1, column2) VALUES ('value1', 'value2');"
更新数据
psql -U $DB_USER -d $DB_NAME -c "UPDATE your_table SET column1='new_value' WHERE column2='value2';"
删除数据
psql -U $DB_USER -d $DB_NAME -c "DELETE FROM your_table WHERE column1='value1';" ```
3. 基于SQLite的Bash数据库编程
SQLite是一个轻量级的文件数据库,尤其适合于小型应用。使用Bash与SQLite进行交互相对简单。
3.1 连接到SQLite数据库
连接和执行查询的方式如下:
```bash
!/bin/bash
DB_FILE="your_database.db"
sqlite3 $DB_FILE <<EOF SELECT * FROM your_table; EOF ```
3.2 插入、更新和删除
类似其他数据库,插入、更新和删除的代码如下:
```bash
!/bin/bash
DB_FILE="your_database.db"
插入数据
sqlite3 $DB_FILE <<EOF INSERT INTO your_table (column1, column2) VALUES ('value1', 'value2'); EOF
更新数据
sqlite3 $DB_FILE <<EOF UPDATE your_table SET column1='new_value' WHERE column2='value2'; EOF
删除数据
sqlite3 $DB_FILE <<EOF DELETE FROM your_table WHERE column1='value1'; EOF ```
使用Bash进行数据库备份与恢复
Bash不仅可以用于操作数据库中的数据,还可以进行备份与恢复,这是数据管理中非常重要的一部分。
1. MySQL备份
使用mysqldump命令可以轻松备份MySQL数据库,示例如下:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database" BACKUP_FILE="backup_$(date +%F).sql"
mysqldump -u $DB_USER -p$DB_PASS $DB_NAME > $BACKUP_FILE ```
2. PostgreSQL备份
PostgreSQL同样提供了备份功能,通过pg_dump命令实现:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password" DB_NAME="your_database" BACKUP_FILE="backup_$(date +%F).sql"
export PGPASSWORD=$DB_PASS pg_dump -U $DB_USER -d $DB_NAME -f $BACKUP_FILE ```
3. SQLite备份
对SQLite数据库进行备份,只需复制数据库文件:
```bash
!/bin/bash
DB_FILE="your_database.db" BACKUP_FILE="backup_$(date +%F).db"
cp $DB_FILE $BACKUP_FILE ```
数据库监控与日志
除了数据操作,数据库的监控与日志记录同样重要。通过Bash脚本,我们可以定期检查数据库的状态并记录日志。
1. 监控MySQL
可以通过以下命令监控MySQL的状态:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password"
mysqladmin -u $DB_USER -p$DB_PASS status > mysql_status.log ```
2. 监控PostgreSQL
对于PostgreSQL,可以使用以下命令:
```bash
!/bin/bash
DB_USER="your_username" DB_PASS="your_password"
export PGPASSWORD=$DB_PASS psql -U $DB_USER -c "SELECT * FROM pg_stat_activity;" >> postgres_activity.log ```
3. 监控SQLite
SQLite的监控相对简单,一般是查看数据库文件状态:
```bash
!/bin/bash
DB_FILE="your_database.db" stat $DB_FILE > sqlite_status.log ```
结论
Bash脚本在数据库编程中提供了高效、简单的解决方案。通过结合命令行数据库工具,Bash可以用来执行复杂的数据库操作,实现数据的管理、备份与监控。尽管Bash可能不如一些高级编程语言强大,但它在系统管理和运维中的重要性不可低估。掌握Bash数据库编程,可以帮助开发者及运维工程师更好地管理数据库系统,提高工作效率。希望本文对您理解Bash语言在数据库中的应用有所启发。
相关文章:
Bash语言的数据库编程
Bash语言的数据库编程 引言 在现代软件开发中,数据库编程是一个不可或缺的部分。从小型项目到大型系统,数据库通常是存储和管理数据的核心。然而,许多开发者往往将焦点放在高级编程语言如Python、Java或C#上,忽视了Shell脚本语言…...
易支付二次元网站源码及部署教程
易支付二次元网站源码及部署教程 引言 在当今数字化时代,二次元文化逐渐成为年轻人生活中不可或缺的一部分。为了满足这一庞大用户群体的需求,搭建一个二次元主题网站显得尤为重要。本文将为您详细介绍易支付二次元网站源码的特点及其部署教程…...
ios脚本巨魔商店多巴胺越狱基本操作教程
准备工作 确认设备兼容性:A9-A11(iPhone6s-X):iOS15.0-16.6.1;A12-A14(iPhoneXR-12PM):iOS15.0-16.5.1;A15-A16(iPhone13-…...
ScratchLLMStepByStep:SFT之分类微调
1. 引言 前面我们花了三节内容来介绍预训练,包括如何从零搭建、如何加速运算、如何分布式加速训练,本节开始我们将进入监督微调(SFT)阶段。 常见语言模型的微调任务有两类,分类微调和指令微调。 分类微调模型通常是…...
人工智能知识分享第十天-机器学习_聚类算法
聚类算法 1 聚类算法简介 1.1 聚类算法介绍 一种典型的无监督学习算法,主要用于将相似的样本自动归到一个类别中。 目的是将数据集中的对象分成多个簇(Cluster),使得同一簇内的对象相似度较高,而不同簇之间的对象相…...
MySQL和Hive中的行转列、列转行
水善利万物而不争,处众人之所恶,故几于道💦 文章目录 MySQL1.行转列2.列转行 Hive1.行转列2.列转行(1)侧窗(2)union MySQL 1.行转列 把多行转成列。直接group,sum(if()) 2.列转行 Hive 1.行转列 select name,sum(if(kmshuxu…...
汽车供应链关键节点:物流采购成本管理全解析
在汽车行业,供应链管理是一项至关重要的任务。汽车制造从零部件的生产到整车的交付,涉及多个环节,其中物流、采购与成本管理是核心节点。本文将深入分析这些关键环节,探讨如何通过供应商管理系统及相关工具优化供应链管理。 一、…...
USB 驱动开发 --- Gadget 设备连接 Windows 免驱
环境信息 测试使用 DuoS(Arm CA53, Linux 5.10) 搭建方案验证环境,使用 USB sniff Wirekshark 抓包分析,合照如下: 注:左侧图中设备:1. 蓝色,USB sniff 非侵入工 USB 抓包工具;2. …...
计算机网络之---数据链路层的功能与作用
数据链路层概念 数据链路层(Data Link Layer)是计算机网络中的第二层,它位于物理层和网络层之间,主要负责数据在物理链路上的可靠传输。其基本功能是将网络层传来的数据分成帧,并负责在物理链路上可靠地传输这些数据帧…...
前端 图片上鼠标画矩形框,标注文字,任意删除
效果: 页面描述: 对给定的几张图片,每张能用鼠标在图上画框,标注相关文字,框的颜色和文字内容能自定义改变,能删除任意画过的框。 实现思路: 1、对给定的这几张图片,用分页器绑定…...
为什么HTTP请求后面有时带一个sign参数(HTTP请求签名校验)
前言 最近在开发过程中,发现前端有很多的接口发送请求时都会携带signxxxx参数,但是后端明明没有写,也不需要这个参数,后面才知道,这个前面是为了给http请求签名,主要是为了防止请求体和请求参数被拦截篡改…...
第二十八周机器学习笔记:PINN求正反解求PDE文献阅读——反问题、动手深度学习
第二十八周周报 一、文献阅读题目信息摘要Abstract网络架构实验——Data-driven discovery of partial differential equations(偏微分方程的数据驱动发现)1. Continuous time models(连续时间模型)例子:(Navier–Stok…...
计算机毕业设计hadoop+spark知网文献论文推荐系统 知识图谱 知网爬虫 知网数据分析 知网大数据 知网可视化 预测系统 大数据毕业设计 机器学习
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
C#Struct堆栈
Struct若其内部含有堆对象,Struct的该对象放在堆上; Struct当做参数传递时,其堆属性作为引用传递,值属性还是作为值传递; struct TS { public int[] t1; public int t2; } public void TF1(TS t) { int[] t1 t.t1; …...
页面转 PDF 功能的实现思路与使用方法
引言 在 Web 开发中,有时我们需要将页面的特定部分转换为 PDF 格式,以便用户下载和保存。本文将详细介绍如何使用 html2canvas 和 jspdf 这两个强大的库来实现这一功能,并且结合实际代码讲解其实现思路与使用方法。完整源码(src/…...
【保姆级教程】基于OpenCV+Python的人脸识别上课签到系统
【保姆级教程】基于OpenCVPython的人脸识别上课签到系统 一、软件安装及环境配置1. 安装IDE:PyCharm2. 搭建Python的环境3. 新建项目、安装插件、库 二、源文件编写1. 采集人脸.py2. 训练模型.py3. 生成表格.py4. 识别签到.py5. 创建图形界面.py 三、相关函数分析1.…...
docker-compose部署下Fastapi中使用sqlalchemy和Alembic
本篇介绍使用Fastapi sqlalchemy alembic 来完成后端服务的数据库管理,并且通过docker-compose来部署后端服务和数据库Mysql。包括: 数据库创建,数据库用户创建数据库服务发现Fastapi 连接数据库Alembic 连接数据库服务健康检查 部署数据…...
Oracle:ORA-00904: “10“: 标识符无效报错详解
1.报错Oracle语句如下 SELECT YK_CKGY.ID,YK_CKGY.DJH,YK_CKGY.BLRQ,YK_CKGY.ZBRQ,YK_CKGY.SHRQ,YK_CKGY.YT,YK_CKGY.ZDR,YK_CKGY.SHR,YK_CKGY.BZ,YK_CKGY.JZRQ,YK_CKGY.ZT,YK_CKGY.CKLX,(case YK_CKGY.CKLXwhen 09 then药房调借when 02 then科室退药when 03 then损耗出库when…...
C语言#define定义宏
目录 一、什么是宏以及宏的声明方式 1.宏常量: 2.宏函数: 二、宏的替换原则 三、宏设计的易犯错误 ERROR1:尾部加分号(当然有些特定需要加了分号,这里说明一般情况) ERROR2:宏函数定义时&…...
SpringBoot操作spark处理hdfs文件
SpringBoot操作spark处理hdfs文件 1、导入依赖 <!-- spark依赖--><dependency><groupId>org.apache.spark</groupId><artifactId>spark-core_2.12</artifactId><version>3.2.2</version></dependency><depend…...
铭豹扩展坞 USB转网口 突然无法识别解决方法
当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...
通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...
2.Vue编写一个app
1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...
质量体系的重要
质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...
【git】把本地更改提交远程新分支feature_g
创建并切换新分支 git checkout -b feature_g 添加并提交更改 git add . git commit -m “实现图片上传功能” 推送到远程 git push -u origin feature_g...
Python如何给视频添加音频和字幕
在Python中,给视频添加音频和字幕可以使用电影文件处理库MoviePy和字幕处理库Subtitles。下面将详细介绍如何使用这些库来实现视频的音频和字幕添加,包括必要的代码示例和详细解释。 环境准备 在开始之前,需要安装以下Python库:…...
如何理解 IP 数据报中的 TTL?
目录 前言理解 前言 面试灵魂一问:说说对 IP 数据报中 TTL 的理解?我们都知道,IP 数据报由首部和数据两部分组成,首部又分为两部分:固定部分和可变部分,共占 20 字节,而即将讨论的 TTL 就位于首…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...
基于Java+VUE+MariaDB实现(Web)仿小米商城
仿小米商城 环境安装 nodejs maven JDK11 运行 mvn clean install -DskipTestscd adminmvn spring-boot:runcd ../webmvn spring-boot:runcd ../xiaomi-store-admin-vuenpm installnpm run servecd ../xiaomi-store-vuenpm installnpm run serve 注意:运行前…...
