>  기사  >  백엔드 개발  >  쉘은 mysql 추가, 삭제, 수정 및 쿼리를 처리합니다.

쉘은 mysql 추가, 삭제, 수정 및 쿼리를 처리합니다.

WBOY
WBOY원래의
2016-08-08 09:25:191354검색

소개

요즘 두 개의 데이터 테이블의 데이터를 비교하는 작업을 하고 있는데 어제 PHP로 버전을 작성했습니다. 그러나 일부 시스템에는 PHP가 없거나 PHP가 mysql 확장을 컴파일하지 않는다는 점을 고려하면 사용할 수 없습니다. mysql 시리즈의 함수를 사용하면 스크립트가 유효하지 않습니다. 오늘은 모든 Linux 시리즈 시스템에서 실행될 수 있도록 쉘 버전을 작성하겠습니다.

쉘은 mysql을 어떻게 운영하나요?

쉘 작업 mysql은 실제로 mysql 명령을 통해 매개변수를 통해 명령문을 실행하는 것인데, 다음 매개변수를 살펴보세요.

<code>-e, --execute=name  Execute command and quit. (Disables --force and history file.)</code>
따라서 다음과 같이 mysql -e를 통해 명령문을 실행할 수 있습니다.

<code>mysql -hlocalhost -P3306 -uroot -p123456 $test --default-character-set=utf8 -e "select * from users"</code>
실행 후 다음 결과가 반환됩니다.


쉘은 mysql 추가, 삭제, 수정 및 쿼리를 처리합니다.

쉘 스크립트에서 mysql 조작

데이터 내보내기

<code>MYSQL="mysql -h192.168.1.102 -uroot -p123456 --default-character-set=utf8 -A -N"
#这里面有两个参数,-A、-N,-A的含义是不去预读全部数据表信息,这样可以解决在数据表很多的时候卡死的问题
#-N,很简单,Don't write column names in results,获取的数据信息省去列名称
sql="select * from test.user"
result="$($MYSQL -e "$sql")"

dump_data=./data.user.txt
>$dump_data
echo -e "$result" > $dump_data
#这里要额外注意,echo -e "$result" > $dump_data的时候一定要加上双引号,不让导出的数据会挤在一行

#下面是返回的测试数据
3       吴彦祖  32
5       王力宏  32
6       ab      32
7       黄晓明  33
8       anonymous       32</code>
데이터 삽입

<code>#先看看要导入的数据格式,三列,分别是id,名字,年龄(数据是随便捏造的),放入data.user.txt
12 tf 23
13 米勒 24
14 西安电子科技大学 90
15 西安交大 90
16 北京大学 90

#OLF_IFS=$IFS
#IFS=","
#临时设置默认分隔符为逗号
cat data.user.txt | while read id name age
do
	sql="insert into test.user(id, name, age) values(${id}, '${name}', ${age});"
	$MYSQL -e "$sql"
done</code>
출력결과

<code>+----+--------------------------+-----+
| id | name                     | age |
+----+--------------------------+-----+
| 12 | tf                       |  23 |
| 13 | 米勒                   	|  24 |
| 14 | 西安电子科技大学 	|  90 |
| 15 | 西安交大             	|  90 |
| 16 | 北京大学             	|  90 |
+----+--------------------------+-----+</code>
데이터 업데이트

<code>#先看看更新数据的格式,将左边一列替换为右边一列,只有左边一列的删除,下面数据放入update.user.txt
tf twoFile
西安电子科技大学 西军电
西安交大 西安交通大学
北京大学

cat update.user.txt | while read src dst
do
	if [ ! -z "${src}" -a ! -z "${dst}" ]
	then
		sql="update test.user set name='${dst}' where name='${src}'"
	fi
	if [ ! -z "${src}" -a -z "${dst}" ]
	then
		sql="delete from test.user where name='${src}'"
	fi
	$MYSQL -e "$sql"
done</code>
출력 결과:

<code>+----+--------------------------+-----+
| id | name                     | age |
+----+--------------------------+-----+
| 12 | twoFile                  |  23 |
| 13 | 米勒                   	|  24 |
| 14 | 西军电		 	|  90 |
| 15 | 西安交通大学         	|  90 |
+----+--------------------------+-----+</code>
이 글의 저작권은 영원히 [

luluyrt at 163 dot com

위 내용은 내용적인 측면을 포함하여 mysql의 추가, 삭제, 수정, 쿼리 등의 쉘 처리 과정을 소개하고 있어 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.