当powershell遇上mysql引发的血案

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了当powershell遇上mysql引发的血案相关的知识,希望对你有一定的参考价值。


 

 

------------------【故事来由】------------------


起因:
群友问:把
cmd.exe /c a:\mysql5.6\bin\mysql.exe -uroot < a:\xxx\yyy.sql
替换成
powershell.exe /c a:\mysql5.6\bin\mysql.exe -uroot < a:\xxx\yyy.sql
就不行了。

经研究发现是由于powershell不支持【<】号导致的。

解决方法:
代替小于号的方法为,用source命令或用cmd。
start-process -FilePath ‘a:\mysql5.6\bin\mysql.exe‘ -ArgumentList ‘ -uroot -e "source a:\xxx\yyy.sql"‘

start-process -FilePath ‘cmd.exe‘ -ArgumentList ‘ /c a:\mysql5.6\bin\mysql.exe -uroot < a:\xxx\yyy.sql‘

 

代替大于号的方法是,用-r。详见mysql手册。
http://dev.mysql.com/doc/refman/5.7/en/mysqldump.html
mysqldump.exe -uroot -B -r 库名 a:\xxx\yyy.sql
--result-file=file_name, -r file_name


------------------【展开的讨论】------------------


问:mysqldump是什么?
答:
导出数据库,生成sql源码文本。
通过叫通 ip/端口/用户名/密码,来查询服务端口,得到字符串,处理字符串,然后写入文本。
这里要说明的是,实际上是一次产生n行,写入内存缓存,(受my.ini中,[mysqldump]字段中,max_allowed_packet = xxM参数控制)然后追
加入文件。并不是一行一追加。况且一行一追加,并没有意义。和二进制追加写入没区别。


问:mysql.exe < xxx.sql是什么?
答:
载入文本并提交给服务器端口。
命令行载入文本,都必须用【<】号了么?为什么Get-Content不用?

 

问:win,linux命令行中,程序通用的数的写法,应该是什么?
答:
命令名 -参数名 参数值
命令名 --参数名 参数值

命令名 /参数名 参数值


powershell 传教士 原创文章 始作于 2016-02-19 允许转载,但必须保留名字和出处,否则追究法律责任

问:powershell中【<】取消了么?
答:


问:假设powershell中【>】取消了,那我用什么?
答:

out-file -InputObject $要输出的内容 -FilePath 文件名
https://technet.microsoft.com/en-us/library/hh849882.aspx

或用
Set-Content -Value $要输出的内容 -Path 文件名
https://technet.microsoft.com/en-us/library/hh849828.aspx


问:假设powershell中【>>】取消了,那我用什么?
答:

Add-Content -Value $要输出的内容 -Path 文件名
https://technet.microsoft.com/en-us/library/hh849859.aspx

注意:上述ps命令支持管道,支持单行,支持多行,支持换行和不换行。


------------------【其他数据库是如何做的?】------------------

让我们先看看,其他数据库的做法。


oracle:
E:\>exp system/oracle FILE=c.dmp FULL=Y

sqlserver:
sqlcmd:
恢复
sqlcmd -S ./sqlexpress -i c:/createdata.sql

 

powershell:
在SQL Server 2012 中,微软增加了4个新的备份和还原的cmdlet
Backup-SqlDatabase
Restore-SqlDatabase
Backup-ASDatabase
Restore-ASDatabase


结论:
这些数据库软件的,导出sql命令,导入sql命令,都没有用到【<】,【>】,【>>】这些符号。

------------------【引发的思考】------------------


1 这应不应该算mysql客户端程序不合理的设计?bug?

2 应不应该给mysqldump.exe 添加 --outfile 之类的参数来代替【>】?
答:
已经有了,是-r参数。

3 应不应该给mysql.exe 添加 --runsqlfile 之类的参数来代替【<】?
既然上面的可以不用大于号,为什么这个命令没有,不用小于号的参数?

 


如果你是一只猴子,我要抢走你【<】,【>】,【>>】牌香蕉,你会很不满意的大吼么?
到底要不要夺走猴子的这只香蕉???


------------------【完】------------------

 

以上是关于当powershell遇上mysql引发的血案的主要内容,如果未能解决你的问题,请参考以下文章

MySql的时区(serverTimezone)引发的血案

MYSQL数据库误赋权引发的血案

delete from t引发的血案

一个NODE_ENV 引发的血案

编码格式引发的血案

php弱类型引发的血案