免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3480 | 回复: 12
打印 上一主题 下一主题

[系统管理] 求教——Shell调用mysql的脚本【新问题】! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-31 23:03 |只看该作者 |倒序浏览
本帖最后由 chao1999 于 2013-02-03 16:28 编辑

如何做一个可以被其他程序调用执行的数据插入的脚本呢?
刚刚接触这方面的确不会虚心向前辈们请教啊!

数据库:smsserver
用户名:root
密码:root
实现功能:每次调用执行这个文件都会向库里插入一条指定的数据。

请帮忙看看这个对吗?

#!/bin/bash  
  
MysqlLogin="mysql -uroot –proot -e'use smsserver "
                  
do
  ${MysqlLogin} -e "insert into smsserver_out (type,recipient,text,encoding,create_date) values ('O','13888888888','发送成功','U',now());"  
  ((i++))
  sleep 2;
done

论坛徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亚冠之浦和红钻
日期:2015-06-29 15:30:48
2 [报告]
发表于 2013-02-01 00:39 |只看该作者
  1. #!/bin/bash  
  2. MysqlLogin="mysql -uroot –proot -e'use smsserver "
  3. ${MysqlLogin} -e "insert into smsserver_out (type,recipient,text,encoding,create_date) values ('O','13888888888','发送成功','U',now());"  
复制代码
这样就够了。保存一个文件,别忘记chmod +x。

论坛徽章:
0
3 [报告]
发表于 2013-02-01 11:34 |只看该作者
谢谢,但是好像不行啊

论坛徽章:
0
4 [报告]
发表于 2013-02-01 11:37 |只看该作者
mysql -uroot -proot -D smsserver -e "insert into………………………………"
好像是命令不对
这样对不对呢?

是Mysql数据库的

论坛徽章:
0
5 [报告]
发表于 2013-02-01 11:38 |只看该作者
回复 3# chao1999


smsserver 是数据库名字是吧,如果是,这样应当就可以了
  1. #!/bin/bash  
  2. MysqlLogin="mysql -uroot –proot
  3. ${MysqlLogin} smsserver -e "insert into smsserver_out (type,recipient,text,encoding,create_date) values ('O','13888888888','发送成功','U',now());"  
复制代码

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
6 [报告]
发表于 2013-02-01 11:50 |只看该作者
上面的应该可以吧。不然就写一句,你先在命令行下执行看看,如果可以,那么在脚本里也就可以了。否则你贴上错误提示:
  1. #!/bin/bash  
  2. mysql -uroot –proot smsserver -e "insert into smsserver_out (type,recipient,text,encoding,create_date) values ('O','13888888888','发送成功','U',now());"
  3. # 或
  4. # mysql -uroot –proot -e "insert into smsserver.smsserver_out (type,recipient,text,encoding,create_date) values ('O','13888888888','发送成功','U',now());"
复制代码

论坛徽章:
0
7 [报告]
发表于 2013-02-01 16:42 |只看该作者
多谢多谢
现在已经解决了
不过
这条数据插到数据库然后发到手机中文全是乱码了

这是怎么回事啊,编码的问题吗?
如何及解决啊?

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
8 [报告]
发表于 2013-02-01 16:49 |只看该作者
回复 7# chao1999


    那先查查数据库里的原始数据是正常的还是乱码。如果是正常的,那可能是发送过程用的编码不对或手机上显示的编码不统一了。

论坛徽章:
0
9 [报告]
发表于 2013-02-01 23:09 |只看该作者
谢谢你的热心帮助
问题已经解决是数据库编码的问题

论坛徽章:
0
10 [报告]
发表于 2013-02-02 21:46 |只看该作者
本帖最后由 chao1999 于 2013-02-03 12:04 编辑

经测试如下的语句是对的,
谢谢!!
==================================================================

#!/bin/bash
mysql -uroot -proot -D smsserver -e "insert into smsserver_out (type,recipient,text,encoding,create_date) values ('O','1399999999','短信内容','U',now());"

==================================================================
现在又有新的问题:
1、上面红色部分的电话号码要从“smsserver”数据库里的“sender”表里读取所有的电话号码,(表里有id字段代表序号,sender_number字段里是手机号码,目前存入2个电话号码);
2、上面蓝色部分的短信内容要从“smsserver”数据库里的“default_content”表里读取id为1的信息,(表里id字段代表序号,content_sms字段代表预定义的短信内容,目前有1-4条不同的短信内容)

请帮忙给指教下吧再次感谢!!






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


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP