`psql` расширенная эквивалентность режима для`mysql`
Я разочарован такими вещами, как:
0:33:1407402356:root@ahost:~# echo 'use wordpress_3_6_1; select * from wp_posts;'
| mysql -u mysqluser -pmysqlpasswdord | wc -l -L
42 40585
Результаты SQL-запроса искажены.
PostgreSQL с psql
предоставляет расширенный режим вспомогательных функций. Посмотрите это в действии:
postgres@ahost:~$ echo '\c openerp7-0 \\ select * from pg_shadow' | psql
You are now connected to database "openerp7-0" as user "postgres".
usename | usesysid | usecreatedb | usesuper | usecatupd | userepl |
passwd | valuntil | useconfig
----------+----------+-------------+----------+-----------+---------+----------
-------------------------+----------+-----------
openerp | 16384 | t | t | t | t |
ahash | |
postgres | 10 | t | t | t | t |
anotherhash | |
(2 rows)
postgres@ahost:~$ echo '\c openerp7-0 \\ \x \\ select * from pg_shadow' |
psql
You are now connected to database "openerp7-0" as user "postgres".
Expanded display is on.
-[ RECORD 1 ]------------------------------------
usename | openerp
usesysid | 16384
usecreatedb | t
usesuper | t
usecatupd | t
userepl | t
passwd | ahash
valuntil |
useconfig |
-[ RECORD 2 ]------------------------------------
usename | postgres
usesysid | 10
usecreatedb | t
usesuper | t
usecatupd | t
userepl | t
passwd | anotherhash
valuntil |
useconfig |
Этот расширенный режим хорош для таблиц с множеством столбцов:
postgres@ahost:~$ echo '\c openerp7-0 \\ \x \\ select * from res_partner' |
psql | wc -l -L
223 44423
postgres@ahost:~$ echo '\c openerp7-0 \\ select * from res_partner' | psql |
wc -l -L
9 94030
Конечно, это только тогда, когда люди не возражают исказить количество строк с wc -l
,
Как люди могут достичь mysql
функция, аналогичная расширенному режиму, представленному в psql
?
1 ответ
Решение
Если я правильно понимаю, чего вы хотите достичь, вы можете попробовать это с разделителем \G (вместо точки с запятой), например так:
echo 'SELECT * FROM mytable\G' | mysql -u myuser -p mypassword mydb
Пример вывода:
*************************** 1. row ***************************
id: 1
locale: de
name: Afghanistan
*************************** 2. row ***************************
id: 2
locale: de
name: Ägypten