mysql中select某表时排除个别字段,shell实现
mysql中select某表时排除个别字段,shell实现
Jamie-Liu 发表于1年前
mysql中select某表时排除个别字段,shell实现
  • 发表于 1年前
  • 阅读 143
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 技术升级10大核心产品年终让利>>>   

摘要: 本文中提供的shell脚本只适用于数据量较小的表,因为shell窗口不能同时罗列几千几万行数据,只能保留几百行数据在终端显示屏上,所以数据量大的时候还是考虑写SQL(才疏学浅,完全不会)脚本,进入数据库中去执行吧!

    在使用mysql的日常生活中,偶尔会有一些奇奇怪怪的需求,例如实现类似:select * EXCEPT password,address from users; 要想从users信息表中查询用户信息,但又不想把用户密码(加密后的,完全没有看的必要)、用户地址显示在查询结果中,该怎么办呢?PS:mysql中是没有EXCEPT这种用法的,上面只是打个比方。

    网上有看到建议写SQL脚本的,应该会很牛逼,但是本人mysql才疏学浅,完全不会啊!咋办呢?只能用shell脚本试试了。

    试试就试试!两个小时后.....

-------------------------------------------------------------------------------------------------------------------------

#!/bin/bash
mysql_host="127.0.0.1"                      # mysql主机地址
mysql_port="3306"                              # 数据库端口号
mysql_user="root"                               # mysql用户名
mysql_password="123456"                 # mysql密码
mysql_database="testing"                   # 数据库名称
mysql_table="users"                            # 数据库某张表名称
key_word="Field"                                 # desc时grep取得关键词
except="user_id|password|address|en_name"       # 排除在外的字段,格式为 A|B|C|D......

echo
number=`mysql -u$mysql_user -p$mysql_password -h$mysql_host -P$mysql_port -e"use $mysql_database;desc $mysql_table;" | gawk '{print $1}' | egrep -cxv "($key_word|$except)"`
line=`mysql -u$mysql_user -p$mysql_password -h$mysql_host -P$mysql_port -e"use $mysql_database;desc $mysql_table;" | gawk '{print $1}' | egrep -xv "($key_word|$except)" | gawk -vi=$number '{if (NR==i){print $1} else {printf"%s,",$1}}'`
mysql -u$mysql_user -p$mysql_password -h$mysql_host -P$mysql_port -e"select $line from $mysql_database.$mysql_table"
echo

-------------------------------------------------------------------------------------------------------------------------

    哎,不得不说,本人的shell水平也是够菜的,两个小时就整了这么个玩意儿,不过还好终于实现了自己当初想要的效果,凑合着用吧!

 

共有 人打赏支持
粉丝 2
博文 16
码字总数 10381
×
Jamie-Liu
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: