Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8881747
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 14, 20262026-06-14T20:24:25+00:00 2026-06-14T20:24:25+00:00

I have the following script in bash: #!/bin/bash PSQL=psql -a -e -d users -U

  • 0

I have the following script in bash:

#!/bin/bash
PSQL="psql -a -e -d users -U postgres --no-align -F$'\t' -c"
FILENAME="file.ext"
QUERY="select * from users limit 1;"
${PSQL} "${QUERY}" # > ${FILENAME}

But the -F$'\t' is evaluated differently. How can we make sure that the string will not be evaluated to return a different string, i.e. finally we would like to execute the command as: psql -a -e -d users -U postgres --no-align -F$'\t' -c "select * from users limit 1;" > file.ext

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-14T20:24:26+00:00Added an answer on June 14, 2026 at 8:24 pm

    The best way to solve your problem is to use arrays:

    PSQL=( psql -a -e -d users -U postgres --no-align $'-F\t' -c )
    FILENAME="file.ext"
    QUERY="select * from users limit 1;"
    "${PSQL[@]}" "${QUERY}" # > ${FILENAME}
    

    Explanation. The first line defines a new array named PSQL. You can think of it as:

    PSQL[0] = psql
    PSQL[1] = -a
    PSQL[2] = -e
    PSQL[3] = -d
    PSQL[4] = users
    PSQL[5] = -U
    PSQL[6] = postgres
    PSQL[7] = --no-align
    PSQL[8] = -F<tab>
    PSQL[9] = -c
    

    In the last line, the (double-quoted) term "${PSQL[@]}" will expand to the 10 “words” that constitute the array PSQL and the (double-quoted) term "${QUERY}" will expand to the string select * from users limit 1; considered a single word. To make things clearer, I’m going to show you how the expansion works using { and } to group each argument bash sees when expanding the line "${PSQL[@]}" "${QUERY}":

    { psql } { -a } { -e } { -d } { users } { -U } { postgres } { --no-align } { -F<tab> } { -c } { select * from users limit 1; }
    

    Remark. Using all upper-case variable names in bash is considered bad practice.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a following bash script: 1 #!/bin/bash 2 query='query= SELECT * WHERE {
I have a shell script file (run.sh) that contains the following: #!/bin/bash %JAVA_HOME%/bin/java -jar
I have a script which outputs some data from a postgres database: #!/bin/bash dbname=inventory
Say I have the following Bash script stored in the file foo.sh : #!/bin/bash
I have the following bash script: #!/bin/bash FILE=p.txt while read line; do export http_proxy=http://$line
So I have the following script (just a test) #!/bin/bash for file in *
I have the following bash script, we can call it script1.sh : #!/bin/bash exec
I have a bash-script (let's call it /usr/bin/bosh ) using the following she-bang line:
I have a bash script that looks like the following: #!/bin/bash FILES=public_html/*.php # */
linux 3.5.6-1.fc17.x86_64 GNU bash, version 4.2.37 Hello, I have the following bash script file.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.