文档章节

mysql中select某表时排除个别字段,shell实现

Jamie-Liu
 Jamie-Liu
发布于 2016/07/19 13:38
字数 409
阅读 229
收藏 0

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

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

 

© 著作权归作者所有

共有 人打赏支持
Jamie-Liu
粉丝 2
博文 18
码字总数 12142
作品 0
宜昌
私信 提问
MySQL数据库(三)

数据导入与导出 (1)数据导入mysql>load data infile "目录/文件名" into table 表名 /默认目录为 /var/lib/mysql-files,可修改配置文件改变默认目录,如不修改配置文件,默认且一定要在这个...

ww魏伟
01/02
0
0
Mysql(三)-数据导入,导出、管理表记录、条件匹配、表查询方式

############################################################################################## 一、数据导入:把系统文件内容存储到数据库的表里 命令: load data infile "目录/文件"...

段超超
2017/12/28
0
0
DBA成长之路---mysql数据库服务(二)

管理表记录 增加 insert into 库.表 values(字段值列表); insert into 库.表(字段值列表) values(字段值列表); insert into 库.表 values(字段值列表),(字段值列表); 查询 单表查询 select 字...

Xuenqlve
01/04
0
0
数据库:数据导入/数据导出

一、数据导入: 把系统文件的内容存储到数据库的表里mysql> load data infile "目录/文件名" into table 库.表名 fields terminated by "字段间隔符号" lines terminated by "n"; 用户名:密...

庞然大悟
2017/12/29
0
0
数据导入导出 、 表记录基本操作 、 查询及匹配条件 、 多表查询 、

数据管理:(管理表记录)数据导入:把系统文件的内容存储到数据库的表里.mysql> create table uesr( 查看默认使用目录及目录是否存在: show variables inke "securefilepriv" 格式: load data i...

大米叔叔
01/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CentOS配置Tomcat监听80端口,虚拟主机

Tomcat更改默认端口为80 更改的配置文件是: /usr/local/tomcat/conf/server.xml [root@test-a ~]# vim /usr/local/tomcat/conf/server.xml # 找到 Connector port="8080" protocol="HTTP/1......

野雪球
今天
5
0
《稻盛和夫经营学》读后感心得体会3180字范文

《稻盛和夫经营学》读后感心得体会3180字范文: 一代日本经营之圣稻盛和夫凭借刻苦勤奋的精神以及深植于佛教的商业道德准则,成为了“佛系”企业家的代表人物。在《稻盛和夫经营学》“领导人...

原创小博客
今天
3
0
java框架学习日志-5(常见的依赖注入)

依赖注入(dependency injection) 之前提到控制反转(Inversion of Control)也叫依赖注入,它们其实是一个东西,只是看的角度不同,这章详细说一下依赖注入。 依赖——指bean对象创建依赖于...

白话
今天
4
0
红外接收器驱动开发

背景:使用系统的红外遥控软件没有反应,然后以为自己接线错误,反复测试,结果烧坏了一个红外接收器,信号主板没有问题。所以自己开发了一个红外接收器的python驱动。接线参见https://my.os...

mbzhong
今天
2
0
ActiveMQ消息传送机制以及ACK机制详解

AcitveMQ是作为一种消息存储和分发组件,涉及到client与broker端数据交互的方方面面,它不仅要担保消息的存储安全性,还要提供额外的手段来确保消息的分发是可靠的。 一. ActiveMQ消息传送机...

watermelon11
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部