Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

support sqlite 3.41.0 by avoiding double quotes for values #235

Open
Pyrolistical opened this issue Mar 15, 2023 · 20 comments
Open

support sqlite 3.41.0 by avoiding double quotes for values #235

Pyrolistical opened this issue Mar 15, 2023 · 20 comments

Comments

@Pyrolistical
Copy link

Pyrolistical commented Mar 15, 2023

In standard sql single quotes are for values and double quotes are for identities like column names. Although sqlite does support double quote values this seems to have changed in 3.41.0.

I have sqlite 3.41.0 installed and when this extension uses it, I get the following error when I try to open a database:

[12:12:12 AM][vscode-sqlite][ERROR] Failed to open database '...\database.db': Parse error near line 4: no such column: table
  aster                                 WHERE (type="table" OR type="view")     
                                      error here ---^

I was able to track down the query:

const tablesQuery = `SELECT name, type FROM sqlite_master
WHERE (type="table" OR type="view")
AND name <> 'sqlite_sequence'
AND name <> 'sqlite_stat1'
ORDER BY type ASC, name ASC;`;

If one tries to run that query on an empty sqlite database in the cli, we get a similar error

>sqlite3 
SQLite version 3.41.0 2023-02-21 18:09:37
Enter ".help" for usage hints.
Connected to a transient in-memory database.
Use ".open FILENAME" to reopen on a persistent database.
sqlite> SELECT name, type FROM sqlite_master
   ...> WHERE (type="table" OR type="view")
   ...> AND name <> 'sqlite_sequence'
   ...> AND name <> 'sqlite_stat1'
   ...> ORDER BY type ASC, name ASC;
Parse error: no such column: table
  SELECT name, type FROM sqlite_master WHERE (type="table" OR type="view") AND n
                                     error here ---^
sqlite>

The workaround is to pin the sqlite client to the one included with the extension. Set the vscode setting
sqlite.sqlite3 to the correct client in .vscode\extensions\alexcvzz.vscode-sqlite-0.14.1\bin

@Pyrolistical Pyrolistical changed the title Double quotes should not be used for values support sqlite 3.41.0 by avoiding double quotes for values Mar 15, 2023
@DowneyX
Copy link

DowneyX commented Mar 30, 2023

getting same issue. thanks for the work around.

@GreLeBr
Copy link

GreLeBr commented Apr 3, 2023

Unless I am misunderstanding it, it is not quite a fix, you just going back to the old sqlite version that the extension uses by default.
I am having the same issue when using latest sqlite: sqlite-tools-win32-x86-3410200 , sqlite-tools-win32-x86-3410100, sqlite-tools-win32-x86-3410000.
I don't know how many versions of sqlite there are before that but I could get it to work with sqlite-tools-win32-x86-3400000.

@Pyrolistical
Copy link
Author

@GreLeBr correct, its a workaround to restore functionality at the time of the extenion's release but does not fix the underlying issue. however the actual fix should be pretty simple. just replace double quotes with single quotes

@rod2ik
Copy link

rod2ik commented Aug 8, 2023

Hi,

Thanks for this awesome extension !

Unfortunately, I am having the same error on Linux (Manjaro), with latest sqlite3 version installed : v. 3.42.0

I am afraid the (grateful) workaround does not work on Linux, unfortunately..

Fixing the extension path to /usr/bin/sqlite3 (my correct path) does not solve the error.

Could you please fix this ? Thankxx by advance

@smargoli2
Copy link

Hey @Pyrolistical ,

Can you please provide more detail on what I actually need to change?

Is it this setting of the extension? What value am I putting there?
I tried copying the path to the exe from the extension but the database is not opening. (It's not showing the error either.)

image

@Pyrolistical
Copy link
Author

@smargoli2 That should be correct

@smargoli2
Copy link

Thanks, the full path that I used is "C:\Users\Sora Teichman.vscode\extensions\alexcvzz.vscode-sqlite-0.14.1\bin\sqlite-v3.26.0-win32-x86.exe", the database is not opening though.

@Pyrolistical
Copy link
Author

@smargoli2 you are missing a slash before .vscode

@smargoli2
Copy link

It is working, I was just looking in the wrong place :) Thank you!

@kdcllc
Copy link

kdcllc commented Aug 30, 2023

I am running into this issue on Linux box as well. I changed the path to point to binary of the extension and still getting the error

@novojitdas
Copy link

Hey @Pyrolistical ,

Can you please provide more detail on what I actually need to change?

Is it this setting of the extension? What value am I putting there? I tried copying the path to the exe from the extension but the database is not opening. (It's not showing the error either.)

image

I also solved my problem following this. thanks @smargoli2 and @Pyrolistical . you guys saved me from stress.

@jmforsythe
Copy link

A different fix for this: I went to C:\Users<me>.vscode\extensions\alexcvzz.vscode-sqlite-0.14.1\dist\extension.js
At line 1, column 29338 you want to replace
type=\"table"\ OR type=\"view\" with type='table' OR type='view'

@Pyrolistical
Copy link
Author

Pyrolistical commented Oct 15, 2023

type=\"table"\ OR type=\"view\" with type='table' OR type='view'

@jmforsythe make a PR 😃

@jmforsythe
Copy link

#241 Already exists, my fix just does what it does after the plugin is installed.

@b01x
Copy link

b01x commented Nov 10, 2023

The following process worked for me on Windows 10
From the windows command line I can run the following command and it runs sqlite without any issues, but this does not work in VSCODE
C:\Users\Joel.vscode\extensions\alexcvzz.vscode-sqlite-0.14.1\bin\sqlite-v3.26.0-win32-x86.exe

In VSCODE, I changed the slashes from back slashes to forward slashes in the sqlite extension configuration and it worked. I tested the following line in the VSCODE terminal to verify it runs.
C:/Users/Joel/.vscode/extensions/alexcvzz.vscode-sqlite-0.14.1/bin/sqlite-v3.26.0-win32-x86.exe

@bartek1a1b
Copy link

Where can I modify path in vscode? Where Can I found it?
image

@houd1ni
Copy link

houd1ni commented Mar 31, 2024

A different fix for this: I went to C:\Users.vscode\extensions\alexcvzz.vscode-sqlite-0.14.1\dist\extension.js At line 1, column 29338 you want to replace type=\"table"\ OR type=\"view\" with type='table' OR type='view'

This definitely works! Thanks. Maybe make a fork of this estension ?

@LeTuChiBao
Copy link

In SQlite Extention setting custom . SQLite3 command or executable path. => sqlite.sqlite3 it's will work oke

@cmosguy
Copy link

cmosguy commented Dec 13, 2024

This does not work at all, this project is dead. Who is taking over this extension?

@DSA164
Copy link

DSA164 commented Jan 13, 2025

Hi I was struggling on MacOS, so here is a tutorial to correct this issue for both Windows and MacOS:

Quick Tutorial: Fixing the SQL Error in VSCode-SQLite

Problem

The error comes from an incorrect query in the VSCode-SQLite plugin. The query contains double quotes (") and improperly used escape characters (\):

WHERE type=\"table\" OR type=\"view\"

These characters cause failures on some systems, particularly macOS.

Quick Solution

1. Locate the File to Modify

  • On macOS:
    /Users/<your_username>/.vscode/extensions/alexcvzz.vscode-sqlite-0.14.1/dist/extension.js
    
  • On Windows:
    C:\Users\<your_username>\.vscode\extensions\alexcvzz.vscode-sqlite-0.14.1\dist\extension.js
    

2. Edit the File

  • Open the file with a text editor (Vim, VSCode, Notepad++).
  • Search for:
    WHERE type=\"table\" OR type=\"view\"
  • Replace it with:
    WHERE type='table' OR type='view'

3. Save and Test

  • Save the file.
  • Restart VSCode.
  • Run an SQL command to confirm the error is resolved.

Vim Command

For advanced users:

vim /Users/<your_username>/.vscode/extensions/alexcvzz.vscode-sqlite-0.14.1/dist/extension.js
:%s/type=\\\"table\\\" OR type=\\\"view\\\"/type='table' OR type='view'/g
:wq

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests