Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gosqlite
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gosqlite
Commits
1a72a524
Commit
1a72a524
authored
Mar 23, 2014
by
gwenn
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Prefer double quote for identifier
parent
6bc819a9
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
34 additions
and
34 deletions
+34
-34
meta.go
meta.go
+11
-11
pragma.go
pragma.go
+7
-4
trace.go
trace.go
+1
-1
util.go
util.go
+15
-18
No files found.
meta.go
View file @
1a72a524
...
@@ -45,7 +45,7 @@ func (c *Conn) Tables(dbName string, temp bool) ([]string, error) {
...
@@ -45,7 +45,7 @@ func (c *Conn) Tables(dbName string, temp bool) ([]string, error) {
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
sql
=
"SELECT name FROM sqlite_master WHERE type = 'table' AND name NOT LIKE 'sqlite_%' ORDER BY 1"
sql
=
"SELECT name FROM sqlite_master WHERE type = 'table' AND name NOT LIKE 'sqlite_%' ORDER BY 1"
}
else
{
}
else
{
sql
=
Mprintf
(
"SELECT name FROM %Q.sqlite_master WHERE type = 'table' AND name NOT LIKE 'sqlite_%%' ORDER BY 1"
,
dbName
)
sql
=
fmt
.
Sprintf
(
"SELECT name FROM %s.sqlite_master WHERE type = 'table' AND name NOT LIKE 'sqlite_%%' ORDER BY 1"
,
doubleQuote
(
dbName
)
)
}
}
if
temp
{
if
temp
{
sql
=
strings
.
Replace
(
sql
,
"sqlite_master"
,
"sqlite_temp_master"
,
1
)
sql
=
strings
.
Replace
(
sql
,
"sqlite_master"
,
"sqlite_temp_master"
,
1
)
...
@@ -73,7 +73,7 @@ func (c *Conn) Views(dbName string, temp bool) ([]string, error) {
...
@@ -73,7 +73,7 @@ func (c *Conn) Views(dbName string, temp bool) ([]string, error) {
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
sql
=
"SELECT name FROM sqlite_master WHERE type = 'view' ORDER BY 1"
sql
=
"SELECT name FROM sqlite_master WHERE type = 'view' ORDER BY 1"
}
else
{
}
else
{
sql
=
Mprintf
(
"SELECT name FROM %Q.sqlite_master WHERE type = 'view' ORDER BY 1"
,
dbName
)
sql
=
fmt
.
Sprintf
(
"SELECT name FROM %s.sqlite_master WHERE type = 'view' ORDER BY 1"
,
doubleQuote
(
dbName
)
)
}
}
if
temp
{
if
temp
{
sql
=
strings
.
Replace
(
sql
,
"sqlite_master"
,
"sqlite_temp_master"
,
1
)
sql
=
strings
.
Replace
(
sql
,
"sqlite_master"
,
"sqlite_temp_master"
,
1
)
...
@@ -102,7 +102,7 @@ func (c *Conn) Indexes(dbName string, temp bool) (map[string]string, error) {
...
@@ -102,7 +102,7 @@ func (c *Conn) Indexes(dbName string, temp bool) (map[string]string, error) {
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
sql
=
"SELECT name, tbl_name FROM sqlite_master WHERE type = 'index'"
sql
=
"SELECT name, tbl_name FROM sqlite_master WHERE type = 'index'"
}
else
{
}
else
{
sql
=
Mprintf
(
"SELECT name, tbl_name FROM %Q.sqlite_master WHERE type = 'index'"
,
dbName
)
sql
=
fmt
.
Sprintf
(
"SELECT name, tbl_name FROM %s.sqlite_master WHERE type = 'index'"
,
doubleQuote
(
dbName
)
)
}
}
if
temp
{
if
temp
{
sql
=
strings
.
Replace
(
sql
,
"sqlite_master"
,
"sqlite_temp_master"
,
1
)
sql
=
strings
.
Replace
(
sql
,
"sqlite_master"
,
"sqlite_temp_master"
,
1
)
...
@@ -145,9 +145,9 @@ type Column struct {
...
@@ -145,9 +145,9 @@ type Column struct {
func
(
c
*
Conn
)
Columns
(
dbName
,
table
string
)
([]
Column
,
error
)
{
func
(
c
*
Conn
)
Columns
(
dbName
,
table
string
)
([]
Column
,
error
)
{
var
pragma
string
var
pragma
string
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
pragma
=
Mprintf
(
"PRAGMA table_info(%Q)"
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA table_info("%s")`
,
escapeQuote
(
table
)
)
}
else
{
}
else
{
pragma
=
Mprintf2
(
"PRAGMA %Q.table_info(%Q)"
,
dbName
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA %s.table_info("%s")`
,
doubleQuote
(
dbName
),
escapeQuote
(
table
)
)
}
}
s
,
err
:=
c
.
prepare
(
pragma
)
s
,
err
:=
c
.
prepare
(
pragma
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -286,9 +286,9 @@ type ForeignKey struct {
...
@@ -286,9 +286,9 @@ type ForeignKey struct {
func
(
c
*
Conn
)
ForeignKeys
(
dbName
,
table
string
)
(
map
[
int
]
*
ForeignKey
,
error
)
{
func
(
c
*
Conn
)
ForeignKeys
(
dbName
,
table
string
)
(
map
[
int
]
*
ForeignKey
,
error
)
{
var
pragma
string
var
pragma
string
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
pragma
=
Mprintf
(
"PRAGMA foreign_key_list(%Q)"
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA foreign_key_list("%s")`
,
escapeQuote
(
table
)
)
}
else
{
}
else
{
pragma
=
Mprintf2
(
"PRAGMA %Q.foreign_key_list(%Q)"
,
dbName
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA %s.foreign_key_list("%s")`
,
doubleQuote
(
dbName
),
escapeQuote
(
table
)
)
}
}
s
,
err
:=
c
.
prepare
(
pragma
)
s
,
err
:=
c
.
prepare
(
pragma
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -331,9 +331,9 @@ type Index struct {
...
@@ -331,9 +331,9 @@ type Index struct {
func
(
c
*
Conn
)
TableIndexes
(
dbName
,
table
string
)
([]
Index
,
error
)
{
func
(
c
*
Conn
)
TableIndexes
(
dbName
,
table
string
)
([]
Index
,
error
)
{
var
pragma
string
var
pragma
string
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
pragma
=
Mprintf
(
"PRAGMA index_list(%Q)"
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA index_list("%s")`
,
escapeQuote
(
table
)
)
}
else
{
}
else
{
pragma
=
Mprintf2
(
"PRAGMA %Q.index_list(%Q)"
,
dbName
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA %s.index_list("%s")`
,
doubleQuote
(
dbName
),
escapeQuote
(
table
)
)
}
}
s
,
err
:=
c
.
prepare
(
pragma
)
s
,
err
:=
c
.
prepare
(
pragma
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -362,9 +362,9 @@ func (c *Conn) TableIndexes(dbName, table string) ([]Index, error) {
...
@@ -362,9 +362,9 @@ func (c *Conn) TableIndexes(dbName, table string) ([]Index, error) {
func
(
c
*
Conn
)
IndexColumns
(
dbName
,
index
string
)
([]
Column
,
error
)
{
func
(
c
*
Conn
)
IndexColumns
(
dbName
,
index
string
)
([]
Column
,
error
)
{
var
pragma
string
var
pragma
string
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
pragma
=
Mprintf
(
"PRAGMA index_info(%Q)"
,
index
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA index_info("%s")`
,
escapeQuote
(
index
)
)
}
else
{
}
else
{
pragma
=
Mprintf2
(
"PRAGMA %Q.index_info(%Q)"
,
dbName
,
index
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA %s.index_info("%s")`
,
doubleQuote
(
dbName
),
escapeQuote
(
index
)
)
}
}
s
,
err
:=
c
.
prepare
(
pragma
)
s
,
err
:=
c
.
prepare
(
pragma
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
pragma.go
View file @
1a72a524
...
@@ -154,13 +154,13 @@ func (c *Conn) ForeignKeyCheck(dbName, table string) ([]FkViolation, error) {
...
@@ -154,13 +154,13 @@ func (c *Conn) ForeignKeyCheck(dbName, table string) ([]FkViolation, error) {
if
len
(
table
)
==
0
{
if
len
(
table
)
==
0
{
pragma
=
"PRAGMA foreign_key_check"
pragma
=
"PRAGMA foreign_key_check"
}
else
{
}
else
{
pragma
=
Mprintf
(
"PRAGMA foreign_key_check(%Q)"
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA foreign_key_check("%s")`
,
escapeQuote
(
table
)
)
}
}
}
else
{
}
else
{
if
len
(
table
)
==
0
{
if
len
(
table
)
==
0
{
pragma
=
Mprintf
(
"PRAGMA %Q.foreign_key_check"
,
dbName
)
pragma
=
fmt
.
Sprintf
(
"PRAGMA %s.foreign_key_check"
,
doubleQuote
(
dbName
)
)
}
else
{
}
else
{
pragma
=
Mprintf2
(
"PRAGMA %Q.foreign_key_check(%Q)"
,
dbName
,
table
)
pragma
=
fmt
.
Sprintf
(
`PRAGMA %s.foreign_key_check("%s")`
,
doubleQuote
(
dbName
),
escapeQuote
(
table
)
)
}
}
}
}
s
,
err
:=
c
.
prepare
(
pragma
)
s
,
err
:=
c
.
prepare
(
pragma
)
...
@@ -226,7 +226,10 @@ func pragma(dbName, pragmaName string) string {
...
@@ -226,7 +226,10 @@ func pragma(dbName, pragmaName string) string {
if
len
(
dbName
)
==
0
{
if
len
(
dbName
)
==
0
{
return
"PRAGMA "
+
pragmaName
return
"PRAGMA "
+
pragmaName
}
}
return
Mprintf
(
"PRAGMA %Q."
+
pragmaName
,
dbName
)
if
dbName
==
"main"
||
dbName
==
"temp"
{
return
fmt
.
Sprintf
(
"PRAGMA %s.%s"
,
dbName
,
pragmaName
)
}
return
fmt
.
Sprintf
(
"PRAGMA %s.%s"
,
doubleQuote
(
dbName
),
pragmaName
)
}
}
func
(
c
*
Conn
)
oneValue
(
query
string
,
value
interface
{})
error
{
// no cache
func
(
c
*
Conn
)
oneValue
(
query
string
,
value
interface
{})
error
{
// no cache
...
...
trace.go
View file @
1a72a524
...
@@ -398,7 +398,7 @@ func (s *Stmt) ExplainQueryPlan(w io.Writer) error {
...
@@ -398,7 +398,7 @@ func (s *Stmt) ExplainQueryPlan(w io.Writer) error {
if
len
(
sql
)
==
0
{
if
len
(
sql
)
==
0
{
return
s
.
specificError
(
"empty statement"
)
return
s
.
specificError
(
"empty statement"
)
}
}
explain
:=
Mprintf
(
"EXPLAIN QUERY PLAN %s"
,
s
.
SQL
()
)
explain
:=
"EXPLAIN QUERY PLAN "
+
s
.
SQL
(
)
sExplain
,
err
:=
s
.
Conn
()
.
prepare
(
explain
)
sExplain
,
err
:=
s
.
Conn
()
.
prepare
(
explain
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
util.go
View file @
1a72a524
...
@@ -12,14 +12,13 @@ package sqlite
...
@@ -12,14 +12,13 @@ package sqlite
static inline char *my_mprintf(char *zFormat, char *arg) {
static inline char *my_mprintf(char *zFormat, char *arg) {
return sqlite3_mprintf(zFormat, arg);
return sqlite3_mprintf(zFormat, arg);
}
}
static inline char *my_mprintf2(char *zFormat, char *arg1, char *arg2) {
return sqlite3_mprintf(zFormat, arg1, arg2);
}
*/
*/
import
"C"
import
"C"
import
(
import
(
"fmt"
"reflect"
"reflect"
"strings"
"unsafe"
"unsafe"
)
)
...
@@ -39,21 +38,6 @@ func mPrintf(format, arg string) *C.char { // TODO may return nil when no memory
...
@@ -39,21 +38,6 @@ func mPrintf(format, arg string) *C.char { // TODO may return nil when no memory
return
C
.
my_mprintf
(
cf
,
ca
)
return
C
.
my_mprintf
(
cf
,
ca
)
}
}
// Mprintf2 is like fmt.Printf but implements some additional formatting options
// that are useful for constructing SQL statements.
// (See http://sqlite.org/c3ref/mprintf.html)
func
Mprintf2
(
format
string
,
arg1
,
arg2
string
)
string
{
cf
:=
C
.
CString
(
format
)
defer
C
.
free
(
unsafe
.
Pointer
(
cf
))
ca1
:=
C
.
CString
(
arg1
)
defer
C
.
free
(
unsafe
.
Pointer
(
ca1
))
ca2
:=
C
.
CString
(
arg2
)
defer
C
.
free
(
unsafe
.
Pointer
(
ca2
))
zSQL
:=
C
.
my_mprintf2
(
cf
,
ca1
,
ca2
)
// TODO may return nil when no memory...
defer
C
.
sqlite3_free
(
unsafe
.
Pointer
(
zSQL
))
return
C
.
GoString
(
zSQL
)
}
func
btocint
(
b
bool
)
C
.
int
{
func
btocint
(
b
bool
)
C
.
int
{
if
b
{
if
b
{
return
1
return
1
...
@@ -73,3 +57,16 @@ func gostring(cs *C.char) string {
...
@@ -73,3 +57,16 @@ func gostring(cs *C.char) string {
return *(*string)(unsafe.Pointer(&x))
return *(*string)(unsafe.Pointer(&x))
}
}
*/
*/
func
escapeQuote
(
identifier
string
)
string
{
if
strings
.
ContainsRune
(
identifier
,
'"'
)
{
// escape quote by doubling them
identifier
=
strings
.
Replace
(
identifier
,
`"`
,
`""`
,
-
1
)
}
return
identifier
}
func
doubleQuote
(
dbName
string
)
string
{
if
dbName
==
"main"
||
dbName
==
"temp"
{
return
dbName
}
return
fmt
.
Sprintf
(
`"%s"`
,
escapeQuote
(
dbName
))
// surround identifier with quote
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment