博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Shell脚本调用mysql语句
阅读量:6304 次
发布时间:2019-06-22

本文共 4489 字,大约阅读时间需要 14 分钟。

方法一:

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/perluse 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 << EOFMYSQLselect * 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/pythonimport 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:                break        print "%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:                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";}?>
本文转自 chengxuyonghu 51CTO博客,原文链接:http://blog.51cto.com/6226001001/1571841,如需转载请自行联系原作者
你可能感兴趣的文章
一个小代码,欢迎大佬的意见,求指正
查看>>
搭建LAMP架构
查看>>
神经网络注意力机制--Attention in Neural Networks
查看>>
Spring.Net+WCF实现分布式事务
查看>>
在Linux上高效开发的7个建议
查看>>
java数据结构 - 数组使用的代码
查看>>
个人简历-项目经验
查看>>
swoole异步任务task处理慢请求简单实例
查看>>
DHCP
查看>>
oracle数据泵导入分区表统计信息报错(四)
查看>>
spring技术内幕读书笔记之IoC容器的学习
查看>>
细说多线程(五) —— CLR线程池的I/O线程
查看>>
JavaScript instanceof和typeof的区别
查看>>
Hadoop文件系统详解-----(一)
查看>>
《面向模式的软件体系结构2-用于并发和网络化对象模式》读书笔记(8)--- 主动器...
查看>>
状态码
查看>>
我的友情链接
查看>>
用sqlplus远程连接oracle命令
查看>>
多年一直想完善的自由行政审批流程组件【2002年PHP,2008年.NET,2010年完善数据设计、代码实现】...
查看>>
自动生成四则运算题目
查看>>