shell 执行mysql操作

本文详细介绍了在shell脚本中使用MySQL的两种方法,包括创建数据库、表、执行SQL语句以及高级管道和文件操作。同时,对比了使用Perl/Python/PHP等编程语言操作数据库的便捷性。
部署运行你感兴趣的模型镜像

方法一:

mysql -hhostname -Pport -uusername -ppassword -e 相关mysql的sql语句。

不用在mysql的提示符下运行mysql,即可以在shell中操作mysql的方法。

#!/bin/bash

HOSTNAME="127.0.0.1" #数据库信息

PORT="3306"

USERNAME="root"

PASSWORD="root"

DBNAME="db_test" #数据库名称

TABLENAME="table_test" #数据库中表的名称

#创建数据库

create_db_sql="create database IF NOT EXISTS ${DBNAME}"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -e "${create_db_sql}"

#创建表

create_table_sql="create table IF NOT EXISTS ${TABLENAME} ( name varchar(20), id int(11) default 0 )"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${create_table_sql}"

#插入数据

insert_sql="insert into ${TABLENAME} values('billchen',2)"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${insert_sql}"

#查询

select_sql="select * from ${TABLENAME}"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

#更新数据

update_sql="update ${TABLENAME} set id=3"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${update_sql}"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

#删除数据

delete_sql="delete from ${TABLENAME}"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${delete_sql}"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

方法二:

#!/bin/sh

echo "use MHFCDB;

insert into \`robot_action\` (ActionId, RobotAction) VALUES('0', '随机');

insert into \`robot_action\` (ActionId, RobotAction) VALUES('1', '移动');

insert into \`robot_action\` (ActionId, RobotAction) VALUES('2', '喊话');

insert into \`robot_action\` (ActionId, RobotAction) VALUES('3', '技能');

insert into \`robot_action\` (ActionId, RobotAction) VALUES('4', '副本');

INSERT INTO \`login_position\` (PostionName, PostionCoord, PostionOrit) VALUES('出生点', '609.30*758.43*148.25@1', '0*0*0');

INSERT INTO \`login_position\` (PostionName, PostionCoord, PostionOrit) VALUES('主城酒馆二楼', '661.90*759.38*150.51@1', '0*0*0');

" > sqlfile

mysql -u root < sqlfile

rm sqlfile

echo "robot_action init succesed!!"

===========================================================================================

1.直接管道过去

echo "show databases" | mysql -uroot -p'123456'

Database

information_schema

mysql

sakila

test

2.从文件

[root@kenthy sakila-db]# cat file

show databases;

[root@kenthy sakila-db]# mysql -uroot -p'123456' < file

Database

information_schema

mysql

sakila

test

3.块

[root@kenthy sakila-db]# mysql -uroot -p'123456' << SQL

> show databases;

> SQL

Database

information_schema

mysql

sakila

test

===========================================================================================

Bash#!/usr/bin/perl

use DBI;

$db = DBI->connect('dbi:mysql:test', 'vpsee', 'password');

$query = "select * from test_mark";

$cursor = $db->prepare($query);

$cursor->execute;

while (@row = $cursor->fetchrow_array) {

print "@row\n";

}#!/bin/bash

mysql -uvpsee -ppassword test <

select * from test_mark;

EOFMYSQL

如果需要复杂的数据库操作的话不建议用 shell 脚本,用 Perl/Python/PHP 操作数据库很方便,分别通过 Perl DBI/Python MySQLdb/PHP MySQL Module 接口来操作数据库。这里再给出这三种不同语言连接、查询数据库的简单例子(为了简单和减少篇幅删除一些不必要的代码):

Perl#!/usr/bin/perl

$db = DBI->connect('dbi:mysql:test', 'vpsee', 'password');

$query = "select * from test_mark";

$cursor = $db->prepare($query);

$cursor->execute;

while (@row = $cursor->fetchrow_array) {

print "@row\n";

}

Python#!/usr/bin/python

import MySQLdb

db = MySQLdb.Connect("localhost", "vpsee", "password", "test")

cursor = db.cursor()

query = "SELECT * FROM test_mark"

cursor.execute(query)

while (1):

row = cursor.fetchone()

if row == None:

break

print "%s, %s, %s, %s" % (row[0], row[1], row[2], row[3])

#!/usr/bin/python

db = MySQLdb.Connect("localhost", "vpsee", "password", "test")

cursor = db.cursor()

query = "SELECT * FROM test_mark"

while (1):

if row == None:

break

print "%s, %s, %s, %s" % (row[0], row[1], row[2], row[3])

PHP

#!/usr/bin/php

?php

$db = mysql_connect("localhost", "vpsee", "password");

mysql_select_db("test");

$result = mysql_query("SELECT * FROM test_mark");

while ($row = mysql_fetch_array($result)) {

print "$row[0] $row[1] $row[2] $row[3]\n";

}

?>#!/usr/bin/php

?php

$db = mysql_connect("localhost", "vpsee", "password");

mysql_select_db("test");

$result = mysql_query("SELECT * FROM test_mark");

while ($row = mysql_fetch_array($result)) {

print "$row[0] $row[1] $row[2] $row[3]\n";

}

?>

您可能感兴趣的与本文相关的镜像

Python3.9

Python3.9

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

Shell脚本中执行MySQL查询是一项常见的任务,主要用于自动化数据库操作、数据提取以及与其他系统集成等场景。下面详细介绍如何通过Shell命令连接到MySQL执行查询。 ### 步骤详解 #### 1. 使用`mysql`命令行工具 MySQL自带了一个名为`mysql`的命令行客户端,可以直接从shell环境中调用它,并传递SQL查询语句。 基本语法如下: ```bash mysql -u 用户名 -p密码 -e "SQL查询语句" 数据库名称 ``` 例如: ```bash mysql -u root -prootpassword -e "SELECT * FROM users;" mydatabase ``` 这条命令表示使用root用户登录mydatabase数据库,并执行一条简单的SELECT语句来获取users表的所有记录。 注意:如果不想将密码直接暴露在命令行上(这可能会导致安全风险),可以省略-p后面的密码部分,在运行时再手动输入密码。 #### 2. 将结果保存至文件 很多时候我们希望把查询的结果导出到某个文本文件里供后续处理。 可以在上述命令基础上添加重定向符号">": ```bash mysql -u root -prootpassword -e "SELECT id,name FROM employees LIMIT 50;" company > output.txt ``` 此示例会选出employees表格前五十条id和name字段值存入output.txt文档内。 #### 3. 调用存储过程或更复杂SQL 对于复杂的业务逻辑或者需要多次复用的功能块来说,则应该考虑创建存储过程而不是每次都写长长的sql串。假设已经有一个叫getTopCustomers() 的存储过程存在company数据库里面了,那么可以通过这种方式去触发这个函数: ```bash mysql -uroot -ppassword -Dcompany --execute="CALL getTopCustomers();" ``` --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值