在使用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
-------------------------------------------------------------------------------------------------------------------------