扣丁学堂Linux培训简述shell简单处理mysql查询结果的方法

2018-11-03 15:27:02 461浏览

最近有同学在扣丁学堂官网向老师询问一些Linux技术问题,今天小编给读者们整理分享一个Linux问题,想要参加Linux培训或者是对Linux开发感兴趣的小伙伴就随小编一起来了解一下shell简单处理mysql查询结果的方法吧。

扣丁学堂Linux培训简述shell简单处理mysql查询结果的方法

首先理清要了解shell脚本的数组与字符串的一些特性:


str=("hello" "world" "!") #结果: str: 3 #普通的字符串数组
echo "str: " ${#str[@]}
str1=("hello world !") #结果: str1: 1 #普通的字符串数组
echo "str1: "${#str1[@]}
str2=(`echo "Hello world !"`) #结果: str2: 3 #等价于 str
echo "str2: " ${#str2[@]} 


function strDeal(){
  param=("$@")
  echo ${param[@]}
  echo $1
  echo $2
  echo $3
}
echo "-----------first----------------"
strDeal "Hello world !" 
echo "-----------second----------------"
strDeal "Hello" "world" "!"
echo "-----------third----------------"
strDeal $str1  #等价于second



用mysql自带数据库world.city为例来展示处理查询结果:


#!/bin/sh
#filename:demo.sh
cityRes=""
cityColNum=5
function getCurValue(){
  curValue=""
  colIndex=$1
  rowIndex=$2
  idx=$[$cityColNum*$colIndex+$rowIndex-1]  #通过行列进行计算目标位置
  if [ $idx -le ${#cityRes[@]} ] ;then
    echo ${cityRes[$idx]} #获取目标结果
  fi
}

#获取city表总行数
function getCityRowNum(){
  echo $[${#cityRes[@]}/$cityColNum-1]
}


cityRes=(`mysql -uroot -p123456 world -e "select * from city"`)  #查询结果以数组来保存,等价于上面的str2
curValue=`getCurValue $1 $2`  #$1为行数 $2为列数
echo $curValue
rowNum=`getCityRowNum` #获取总行数
echo $rowNum


调用示例:


sh demo.sh 1 2


注意的事项:


getCityRowNum后的记录数与实际的记录数并不一致,这是由于city表Name 或者District字段中由于多个字符串组成,如:Andorra la Vella


这样就会占用3个位置。




想要了解更多关于Linux开发方面内容的小伙伴,请关注扣丁学堂Linux培训官网、微信等平台,扣丁学堂IT职业在线学习教育平台为您提供权威的Linux开发环境搭建视频,Linux培训后的前景无限,行业薪资和未来的发展会越来越好的,扣丁学堂老师精心推出的Linux视频直播课定能让你快速掌握Linux从入门到精通开发实战技能。扣丁学堂Linux技术交流群:422345477。


扣丁学堂微信公众号


【关注微信公众号获取更多学习资料】



查看更多关于“Linux培训资讯”的相关文章>>



标签: 扣丁学堂Linux培训 shell简单处理mysql查询结果的方法 linux系统入门学习 linux培训 linux视频教程 linux基础教程 linux在线视频 linux在线学习 linux从入门到精通 linux开发环境包 linux系统 linux开发教程

热门专区

暂无热门资讯

课程推荐

微信
微博
15311698296

全国免费咨询热线

邮箱:codingke@1000phone.com

官方群:148715490

北京千锋互联科技有限公司版权所有   北京市海淀区宝盛北里西区28号中关村智诚科创大厦4层
京ICP备12003911号-6   Copyright © 2013 - 2019

京公网安备 11010802030908号