免费注册 查看新帖 |

Chinaunix

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

shell数据库问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-02 22:03 |只看该作者 |倒序浏览
如何用shell将数据库的字段值取出,赋值给shell的变量,在C里面可以用select date into :date from workdate,请问大侠们,shell有没有这样的语句,或者如何实现这样的功能?

论坛徽章:
0
2 [报告]
发表于 2008-12-02 22:06 |只看该作者

论坛徽章:
0
3 [报告]
发表于 2008-12-03 10:29 |只看该作者
呵呵,我想起来mysql导入的例子。
用一个SQL文件导入数据库,其实就是shell操作数据库
(1):直接让mysql执行语句,例如:
[root@localhost ~]# mysql -uroot -pmypass -e "use bug; select * from t_addr"
+----+----------------+------+---------------------+-------+
| Id | ip             | flag | last_link_time      | valid |
+----+----------------+------+---------------------+-------+
|  2 | 192.168.54.57  |   -1 | 2008-11-04 15:35:15 |     1 |
| 10 | 192.168.54.71  |    1 | 2008-12-01 16:41:43 |     1 |
| 12 | 192.168.54.76  |    1 | 2008-11-04 16:36:40 |     1 |
| 13 | 192.168.54.66  |    1 | 2008-11-05 14:03:21 |     1 |
| 14 | 192.168.54.69  |    1 | 2008-11-05 10:25:51 |     1 |
| 15 | 127.0.0.1      |   -1 | 2008-11-05 10:40:47 |     1 |
| 16 | 192.168.54.80  |    1 | 2008-11-05 14:02:03 |     1 |
| 17 | 192.168.54.167 |   -1 | 2008-11-17 16:45:56 |     1 |
+----+----------------+------+---------------------+-------+

(2):从文件中导入命令:
[root@localhost ~]# cat 1.sql
use bug;
select * from t_addr;

然后执行
[root@localhost ~]# mysql -uroot -pmypass< 1.sql                           
Id      ip      flag    last_link_time  valid
2       192.168.54.57   -1      2008-11-04 15:35:15     1
10      192.168.54.71   1       2008-12-01 16:41:43     1
12      192.168.54.76   1       2008-11-04 16:36:40     1
13      192.168.54.66   1       2008-11-05 14:03:21     1
14      192.168.54.69   1       2008-11-05 10:25:51     1
15      127.0.0.1       -1      2008-11-05 10:40:47     1
16      192.168.54.80   1       2008-11-05 14:02:03     1
17      192.168.54.167  -1      2008-11-17 16:45:56     1


[ 本帖最后由 duanjigang 于 2008-12-3 10:35 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2008-12-04 09:57 |只看该作者

回复 #3 duanjigang 的帖子

不是这样的,我要的是从数据库里取出一个值赋给变量,如表workdate表里有一个workdate的字段值是20081204,我要将这个值赋值给一个shell变量$a。以便下面用mkdir来创建目录,mkdir $a

论坛徽章:
0
5 [报告]
发表于 2008-12-04 10:03 |只看该作者
原帖由 huiyzou 于 2008-12-4 09:57 发表
不是这样的,我要的是从数据库里取出一个值赋给变量,如表workdate表里有一个workdate的字段值是20081204,我要将这个值赋值给一个shell变量$a。以便下面用mkdir来创建目录,mkdir $a

先调用shell访问数据库得到结果,然后再解析结果。。。这么不能实现吗?

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
6 [报告]
发表于 2008-12-04 12:38 |只看该作者
原帖由 duanjigang 于 2008-12-4 10:03 发表

先调用shell访问数据库得到结果,然后再解析结果。。。这么不能实现吗?


a=$(awk 'NR==1{print $1;exit}' <(mysql -uroot -pmypass -e "use bug; select * from t_addr"));echo $a
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP