Вы можете сделать что-то вроде этого:
mysql_connect('localhost','user',password);
mysql_query("CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';");
mysql_query("GRANT ALL ON db1.* TO 'username'@'localhost'");
mysql_query("CREATE DATABASE newdatabase");
mysql_close();
Вы можете посмотреть документацию MySQL на GRANT и CREATE USER
Магические переменные %
n содержат аргументы, используемые для вызова файла: %0
- это путь к самому bat-файлу, %1
- первый аргумент после, %2
является вторым и т. д.
Поскольку аргументы часто являются файловыми путями, для извлечения частей пути есть дополнительный синтаксис. ~d
- это диск, ~p
- это путь (без диска), ~n
- имя файла. Они могут быть объединены, поэтому ~dp
- это диск + путь.
%~dp0
поэтому очень полезен в летучей мыши: это папка, в которой находится исполняемый файл bat.
Вы также можете получить другую информацию о файле: ~t
- это метка времени, ~z
- размер.
Посмотрите здесь для справки для всех команд командной строки. Коды тильды-магии описаны в для .
%~d0
дает вам букву диска аргумента 0 (имя скрипта), %~p0
путь.
Да, есть другие ярлыки, которые вы можете использовать, которые приведены ниже. В вашей команде ~ d0 будет означать букву диска 0-го аргумента.
~ expands the given variable
d gets the drive letter only
0 is the argument you are referencing
Поскольку 0-й аргумент представляет собой путь к скрипту, он получает букву диска пути для вас. Вы также можете использовать следующие ярлыки.
%~1 - expands %1 removing any surrounding quotes (")
%~f1 - expands %1 to a fully qualified path name
%~d1 - expands %1 to a drive letter only
%~p1 - expands %1 to a path only
%~n1 - expands %1 to a file name only
%~x1 - expands %1 to a file extension only
%~s1 - expanded path contains short names only
%~a1 - expands %1 to file attributes
%~t1 - expands %1 to date/time of file
%~z1 - expands %1 to size of file
%~$PATH:1 - searches the directories listed in the PATH
environment variable and expands %1 to the fully
qualified name of the first one found. If the
environment variable name is not defined or the
file is not found by the search, then this
modifier expands to the empty string
%~dp1 - expands %1 to a drive letter and path only
%~nx1 - expands %1 to a file name and extension only
%~dp$PATH:1 - searches the directories listed in the PATH
environment variable for %1 and expands to the
drive letter and path of the first one found.
%~ftza1 - expands %1 to a DIR like output line
Это также можно найти непосредственно в командной строке при запуске CALL /? или FOR /?
Это расширенные подстановки переменных. Они изменяют переменные% N, используемые в пакетных файлах. Очень полезно, если вы участвуете в пакетном программировании в Windows.
%~I - expands %I removing any surrounding quotes ("")
%~fI - expands %I to a fully qualified path name
%~dI - expands %I to a drive letter only
%~pI - expands %I to a path only
%~nI - expands %I to a file name only
%~xI - expands %I to a file extension only
%~sI - expanded path contains short names only
%~aI - expands %I to file attributes of file
%~tI - expands %I to date/time of file
%~zI - expands %I to size of file
%~$PATH:I - searches the directories listed in the PATH
environment variable and expands %I to the
fully qualified name of the first one found.
If the environment variable name is not
defined or the file is not found by the
search, then this modifier expands to the
empty string
Вы можете найти это, выполнив FOR /?
.
Этот код объясняет использование символа ~ tilda, что было для меня самым запутанным. Как только я понял это, это значительно облегчает понимание:
@ECHO off
SET "PATH=%~dp0;%PATH%"
ECHO %PATH%
ECHO.
CALL :testargs "these are days" "when the brave endure"
GOTO :pauseit
:testargs
SET ARGS=%~1;%~2;%1;%2
ECHO %ARGS%
ECHO.
exit /B 0
:pauseit
pause
Еще один совет, который поможет многому - установить текущий каталог на другой диск, сначала нужно будет использовать %~d0
, затем cd %~dp0
. Это изменит каталог на диск пакетного файла, а затем переключится на его папку.
Для #oneLinerLovers, cd /d %~dp0
изменит как диск, так и каталог:)
Надеюсь, что это поможет кто-то.
pushd %~dp0
, который не имеет проблем с изменением текущего диска и дает дополнительный бонус для возможности popd
вернуться к исходному диску / пути позже.
– bcrist
13 March 2016 в 02:48
Некоторые исправления, на которые следует обратить внимание:
Если вы дважды щелкните командный файл %0
, будет окружен кавычками. Например, если вы сохраните этот файл как c:\test.bat
:
@echo %0
@pause
Двойной щелчок откроет новую командную строку с выходом:
"C:\test.bat"
Но если вы сначала откройте командную строку и вызовите ее непосредственно из этой командной строки, %0
будет ссылаться на все, что вы набрали. Если вы наберете test.bat
Enter, вывод %0
не будет иметь кавычек, потому что вы не вводили кавычки:
c:\>test.bat
test.bat
Если вы наберете test
Enter, вывод %0
будет иметь нет расширения, потому что вы не вводили расширение:
c:\>test
test
То же самое для tEsT
Введите:
c:\>tEsT
tEsT
Если вы наберете "test"
Enter, вывод %0
будут иметь кавычки (поскольку вы их набрали), но не расширение:
c:\>"test"
"test"
Наконец, если вы наберете "C:\test.bat"
, вывод будет таким, как если бы вы дважды нажали на него:
c:\>"C:\test.bat"
"C:\test.bat"
Обратите внимание, что это не все возможные значения %0
могут быть вызваны тем, что вы можете вызвать скрипт из других папок:
c:\some_folder>/../teST.bAt
/../teST.bAt
Все приведенные выше примеры также повлияют на %~0
, потому что выход %~0
является просто выходом %0
минус-кавычек (если есть).
Из Разбор имени файла в пакетном файле и другие идиомы - Real-How [to] :
Путь (без диска), где скрипт: ~ p0
Диск, где скрипт: ~ d0
Отображает текущее местоположение файла или каталога, в котором вы сейчас находитесь. если ваш пакетный файл был в каталоге рабочего стола, тогда «% ~ dp0» отобразит каталог рабочего стола. если вы хотите, чтобы он отображал текущий каталог с текущим именем файла, вы можете ввести «% ~ dp0% ~ n0% ~ x0».
echo %~dp0
не будет работать в командной строке только в пакетном файле. Duh! – northben 27 March 2015 в 19:40%~d0
и%~d0%
? – Geoffrey 11 May 2015 в 13:23echo %~pd0
дает тот же результат, что и echo%~dp0
(вместо обратного, как ожидалось). Кроме того, значение%0
равно в зависимости от того, дважды ли вы щелкните командный файл или запустите его из cmd. – Pacerier 11 August 2015 в 12:09