AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 406514
Accepted
FaxMax
FaxMax
Asked: 2017-11-24 01:24:36 +0800 CST2017-11-24 01:24:36 +0800 CST 2017-11-24 01:24:36 +0800 CST

Por que canalizar `mysql` para 'tail' altera o formato de saída?

  • 772

Quando vejo o resultado de um SELECTcom o MySQL Workbench, está correto com um único \

max@host 10:13:58: ~$ mysql -h db-master.domain.local -uuser -ppw db -e '
>                 SELECT
>                 DISTINCT i.filesourceregexp
>                 FROM db.ImportLogFiles i'

+------------------------------------------------+
| filesourceregexp                               |
+------------------------------------------------+
| ^[0-9]{8}_1062355673_merge_google_pbn\.csv$    |
| ^[0-9]{8}_8026062435_merge_google_pbn\.csv$    |
| ^[0-9]{8}_1062355673_store_visits_report\.csv$ |
+------------------------------------------------+

max@host 10:14:10: ~$ mysql -h db-master.domain.local -uuser -ppw db -e '
                SELECT
                DISTINCT i.filesourceregexp
                FROM db.ImportLogFiles i' | tail -n +2
^[0-9]{8}_1062355673_merge_google_pbn\\.csv$
^[0-9]{8}_8026062435_merge_google_pbn\\.csv$
^[0-9]{8}_1062355673_store_visits_report\\.csv$
max@host 10:14:19: ~$ 

Tenho essas opções em my.cnf:

[client] 
host = db-master 
user = user 
password = pass 
default-character-set=utf8

Por que canalizar o resultado tailaltera a saída/string? (observe o duplo \).

pipe mysql
  • 1 1 respostas
  • 2118 Views

1 respostas

  • Voted
  1. Best Answer
    Stéphane Chazelas
    2017-11-24T01:59:31+08:002017-11-24T01:59:31+08:00

    Não é tail, é a tubulação.

    mysqlusa um tabular com formato de saída ASCII boxing quando seu stdout é um dispositivo terminal, quando é destinado a um usuário, e reverte para um formato de script quando não é, como quando é um pipe ou um arquivo normal.

    Você veria o mesmo formato diferente com

    mysql... | cat
    

    ou

    mysql > file; cat file
    

    Veja também -r/ --raw, -s/ --silent, -B/ --batch, -N/ --skip-column-names/ --column-names=0​​, -H/ --html, -t/ --table... que afetam o formato de saída.

    Se você deseja a saída tabular mesmo quando a saída não vai para um dispositivo terminal, adicione a -topção:

    mysql -t ... | tail -n +2
    

    Mas se o objetivo for remover a linha do cabeçalho, basta usar -N, com ou sem -t.

    Aqui para pegar os valores do banco de dados o mais bruto possível e sem cabeçalho, eu usaria:

    mysql --defaults-extra-file=/some/protected/file/with/credentials \
          --batch --raw --skip-column-names -e 'select...' database
    

    Aquilo é:

    • não exponha a senha na saída de pspassando as credenciais em um arquivo (como o seu my.cnf) com --defaults-extra-file.
    • use o modo de lote para evitar a saída tabular (e reconheça o fato de que estamos realmente em lotes, o que pode ter outras implicações).
    • --rawpara evitar a fuga . Supondo que os valores não contenham novas linhas, caso contrário, a saída não poderia ser pós-processada de forma confiável.
    • --skip-column-namespara remover a linha de cabeçalho.
    • 36

relate perguntas

  • MySQL Select com função IN () com array bash

  • ordem de substituição de processos `te` e `bash`

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Matriz JSON para bash variáveis ​​usando jq

    • 4 respostas
  • Marko Smith

    A data pode formatar a hora atual para o fuso horário GMT? [duplicado]

    • 2 respostas
  • Marko Smith

    bash + lê variáveis ​​e valores do arquivo pelo script bash

    • 4 respostas
  • Marko Smith

    Como posso copiar um diretório e renomeá-lo no mesmo comando?

    • 4 respostas
  • Marko Smith

    conexão ssh. Conexão X11 rejeitada devido a autenticação incorreta

    • 3 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Marko Smith

    comando systemctl não funciona no RHEL 6

    • 3 respostas
  • Marko Smith

    rsync porta 22 e 873 uso

    • 2 respostas
  • Marko Smith

    snap /dev/loop em 100% de utilização -- sem espaço livre

    • 1 respostas
  • Marko Smith

    chave de impressão jq e valor para todos no subobjeto

    • 2 respostas
  • Martin Hope
    EHerman Matriz JSON para bash variáveis ​​usando jq 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux A data pode formatar a hora atual para o fuso horário GMT? [duplicado] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC Como posso copiar um diretório e renomeá-lo no mesmo comando? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve Como as permissões de arquivo funcionam para o usuário "root"? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe Altere o editor padrão para vim para _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey Como baixar o pacote não instalá-lo com o comando apt-get? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao Por que os diretórios /home, /usr, /var, etc. têm o mesmo número de inode (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg — o comando list-keys gera uid [ desconhecido ] depois de importar a chave privada para uma instalação limpa 2017-11-26 18:26:02 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve