文档章节

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

Jamie-Liu
 Jamie-Liu
发布于 2016/07/19 13:38
字数 409
阅读 192
收藏 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
DBA成长之路---mysql数据库服务(二)

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

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

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

段超超
2017/12/28
0
0
数据库:数据导入/数据导出

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

庞然大悟
2017/12/29
0
0
如何高效快速地优化MySQL、SQL语句(附源码)

作者介绍 韩锋,宜信技术研发中心数据库架构师。精通多种关系型数据库,曾任职于当当网、TOM在线等公司,曾任多家公司首席DBA、数据库架构师等职,多年一线数据库架构、设计、开发经验。著有...

Yomut
2016/10/10
135
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

49.Nginx防盗链 访问控制 解析php相关 代理服务器

12.13 Nginx防盗链 12.14 Nginx访问控制 12.15 Nginx解析php相关配置(502的问题) 12.16 Nginx代理 扩展 502问题汇总 http://ask.apelearn.com/question/9109 location优先级 http://blog....

王鑫linux
50分钟前
0
0
Nginx防盗链、访问控制、解析php相关配置、Nginx代理

一、Nginx防盗链 1. 编辑虚拟主机配置文件 vim /usr/local/nginx/conf/vhost/test.com.conf 2. 在配置文件中添加如下的内容 { expires 7d; valid_referers none blocked server_names *.tes......

芬野de博客
今天
0
0
spring EL 和资源调用

资源调用 import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.PropertySource;import org.springframework.core.io.Resource;......

Canaan_
今天
1
0
memcached命令行、memcached数据导出和导入

一、memcached命令行 yum装telnet yum install telent 进入memcached telnet 127.0.0.1 11211 命令最后的2表示,两位字节,30表示过期时间(秒) 查看key1 get key1 删除:ctrl+删除键 二、m...

Zhouliang6
今天
0
0
Linux定时备份MySQL数据库

做项目有时候要备份数据库,手动备份太麻烦,所以找了一下定时备份数据库的方法 Linux里有一个 crontab 命令被用来提交和管理用户的需要周期性执行的任务,就像Windows里的定时任务一样,用这...

月夜中徘徊
今天
1
1

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部