方法一:

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

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

#!/bin/bash

HOSTNAME="192.168.111.84" #数据库信息

PORT="3306"

USERNAME="root"

PASSWORD=""

DBNAME="test_db_test" #数据库名称

TABLENAME="test_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/bashmysql -uvpsee -ppassword test << EOFMYSQL
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 MySQLdbdb = 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:breakprint "%s, %s, %s, %s" % (row[0], row[1], row[2], row[3])
#!/usr/bin/pythondb = MySQLdb.Connect("localhost", "vpsee", "password", "test")
cursor = db.cursor()
query = "SELECT * FROM test_mark"while (1):if row == None:breakprint "%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";
}
?>

本文转自 chengxuyonghu 51CTO博客,原文链接:http://blog.51cto.com/6226001001/1571841,如需转载请自行联系原作者

Shell脚本调用mysql语句相关推荐

  1. 使用shell脚本调用mysql数据库存储过程,并设置定时任务

    本来是要mysql数据库中创建事件任务来,定时执行存储过程,做数据传输的...后来由于种种原因,就使用crontab来定时执行,调用存储过程. 实现这个数据传输分为两步: 第一步:编写shell脚本调 ...

  2. shell脚本获取mysql插入数据自增长id的值

    shell脚本获取mysql插入数据自增长id的值 在shell脚本中我们可以通过last_insert_id()获取id值,但是,需要注意的是,该函数必须在执行插入操作的sql语句之后,立即调用,否 ...

  3. shell脚本之until语句和函数

    文章目录 shell脚本之until语句.函数和数组 一.until语句 1.1until语句结构 1.2until语句的应用 1.2.1通过循环累加的方式计算1-100的和 1.2.2 为制定用户发 ...

  4. linux shell脚本执行sql语句建表建库

    linux shell脚本执行sql语句建表建库 1. 创建sql脚本 2. 创建shll脚本 1. 创建sql脚本 创建contract_ddl.sql -- 创建数据库contract_user ...

  5. shell编程系列22--shell操作数据库实战之shell脚本与MySQL数据库交互(增删改查)

    shell编程系列22--shell操作数据库实战之shell脚本与MySQL数据库交互(增删改查)Shell脚本与MySQL数据库交互(增删改查)# 环境准备:安装mariadb 数据库 [root ...

  6. shell脚本修复MySQL主从同步

    shell脚本修复MySQL主从同步 发布:thebaby   来源:net     [大 中 小] 分享一例shell脚本,用于修改mysql的主从同步问题,有需要的朋友参考下吧. 一个可以修改my ...

  7. Linux Shell脚本多循环语句练习题

    Linux Shell脚本多循环语句练习题 99乘法表 矩形 正直角三角形 反直角三角形 倒直角三角形 等腰三角形 倒等腰三角形 菱形 平行四边形 直角梯形 等腰梯形 99乘法表 #!/bin/bas ...

  8. shell备份mysql思路_写一个shell脚本备份mysql数据库的步骤

    写一个shell脚本备份mysql数据库的步骤 发布时间:2020-05-25 15:47:41 来源:51CTO 阅读:221 作者:三月 下文我给大家简单讲讲关于写一个shell脚本备份mysql ...

  9. Shell脚本读取mysql结果集各数据项的值

    在linux下用shell脚本读取mysql结果集各数据项的值,按行读取sql结果,将sql执行结果读取到shell变量中,然就可进行处理. HOSTNAME="172.16.xx.xx&q ...

最新文章

  1. 2021全国高校计算机能力挑战赛(初赛)C语言
  2. 近期活动盘点:2019清华大数据系统软件峰会(9.15)
  3. MyBatis-03 MyBatis XML方式之select元素
  4. 别再用 httpClient了,快试试这款优雅的 HTTP 客户端工具!
  5. 人生的主干,提及程序化
  6. JAVA vector的遍历_谈谈vector容器的三种遍历方法
  7. 面试: 14 个实用的数据库设计技巧,一次性教给你!
  8. 荣耀x10max能不能升级为鸿蒙,荣耀终于放出大招!4部荣耀旗舰可升级鸿蒙,网友:终于等到了...
  9. 云服务器的主机名是否可以修改??
  10. list redis 怎样做排行_list类型的应用场景 —— Redis实战经验
  11. 心得7--JDBC回顾-批处理案例解说
  12. 韩顺平mysql优化笔记_韩顺平 mysql优化笔记.doc
  13. 安装protobuf
  14. 模拟电路与数字电路基础知识及实训QY-DG760A
  15. 怎么用imp命令把dmp文件从本地导入到远处的数据库服务器,Oracle 数据库导入导出dmp文件...
  16. 责任链模式的高级用法
  17. Mean Shift和CamShift算法
  18. 软件设计(中线提取)
  19. python文件操作(1)
  20. 基于unity3D的趣味桌球游戏开发

热门文章

  1. Code Push 热更新使用详细说明和教程
  2. mysql cmd常用命令
  3. animiz动画制作软件_学习动画制作需要掌握的常用软件合集
  4. 线程池之CachedThreadPool学习
  5. iOS 快速定位约束冲突
  6. swift_029(Swift 的泛型)
  7. 传输层端口号的范围是多少?被分为哪两部分_Cu2ZnSnS4纳米晶做空穴传输层经配体改性将低温可喷涂碳电极基钙钛矿太阳能电池的性能提高到17.71...
  8. Jquery源码分析-整体结构
  9. 联合索引和多个单列索引选择
  10. Java 编程下使用 Class.forName() 加载类