- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试构建一个 SQL 参数自动绑定(bind)到新查询的系统。根据这个线程:
SQL Server - Invalid characters in parameter names
@、_ 和# 字符应允许在标识符中。所以我尝试将参数构建为:
:表名#字段名
但是当我这样做时会出现错误:
PBdatabase.select_query: [1] DB[2] prepare() SELECT * FROM creature WHERE pk = :creature#pk [near "#pk": syntax error]
SELECT pk, number, location FROM fleet;
:fleet#pk
:fleet#number
:fleet#location
SELECT pk, fk_fleet, name FROM ship WHERE fk_fleet = :fleet#pk
最佳答案
SQLite 和 SQL Server 相似,但它们的语法略有不同,就像 SQL 的所有实现通常有不同的规则一样。
SQLite 允许使用字母 A
- Z
, a
- z
, 0
- 9
, _
, $
, 冒号对 "::"
在第一个字符之后,并且 Unicode 字符大于 u007f。
此外,在参数末尾,可以添加括号:(
和 )
, 其间可以是除 ASCII 空白字符和 )
之外的任何字符字符。 0x00
也永远不允许(因为这表示 C 字符串的结尾)。
例子
所以以下参数是有效的::a
, :_
, :$
, :a::
, :A
, :9
, :😁
, :
(U+2000,Unicode en 四空格字符),:a(:/$asd()
.
虽然这些是无效的::#
, :::
, ::
, :;
, :(
, :( )
(一个普通的 ASCII 空间)
来源
我在 SQLite 网站上找到了一篇文章(参见 https://www.sqlite.org/draft/tokenreq.html),其中指定命名参数(也称为变量)可以包括:
A "parameter name" is defined to be a sequence of one or morecharacters that consists of ALPHANUMERIC characters and/ordollar-signs (u0025) intermixed with pairs of colons (u003a) andoptionally followed by any sequence of non-zero, non-WHITESPACEcharacters enclosed in parentheses (u0028 and u0029).
ALPHABETICAny of the characters in the range u0041 through u005a (letters "A" through "Z")or in the range u0061 through u007a (letters "a" through "z") or the characteru005f ("_") or any other character larger than u007f.
NUMERICAny of the characters in the range u0030 through u0039 (digits "0" through "9")
0xd800
至
0xdfff
也没有工作,因为 Python3 拒绝用这些值创建一个字符串(见
https://en.wikipedia.org/wiki/UTF-16#U+D800_to_U+DFFF 了解原因),所以这可能在 SQLite C 代码中工作。
import sqlite3
import tqdm
import itertools
with sqlite3.connect(":memory:") as conn:
with conn as cur:
cur.execute("create table test(x);")
strings_to_test = ["{}", "a{}", "{0}{0}", "a{0}{0}", "a({})"]
# make a list to hold the invalid chars for each test item
strings_to_test = {x: list() for x in strings_to_test}
def attempt_insert(string, i, invalid_list):
try:
cur.execute("insert into test values ( :{} );".format(string)
.format(chr(i)),{"{}".format(string).format(chr(i)): 42})
except Exception as e:
invalid_list.append(i)
# 0x10FFFF is the max value for UTF chars
for char_num in tqdm.trange(0, 0x10FFFF):
for string, invalid_char_list in strings_to_test.items():
attempt_insert(string, char_num, invalid_char_list)
def gen_ranges(i):
# from https://stackoverflow.com/a/4629241 with changes for Python3
for a, b in itertools.groupby(enumerate(i), lambda x: x[1] - x[0]):
b = list(b)
yield b[0][1], b[-1][1]
def ranges(invalid_chars):
return "{}".format(["0x{:06x} to 0x{:06x}".format(*range) \
for range in gen_ranges(invalid_chars)])
print("Invalid Single Chars: ie :x were: {}".format(
ranges(strings_to_test["{}"])))
print("Invalid Single Second Chars: ie :ax were: {}".format(
ranges(strings_to_test["a{}"])))
print("Invalid Double Chars: ie :xx were: {}".format(
ranges(strings_to_test["{0}{0}"])))
print("Invalid Double Chars in second pos: ie :axx were: {}".format(
ranges(strings_to_test["a{0}{0}"])))
print("Invalid Parenthesised Chars: ie :abc(x) were: {}".format(
ranges(strings_to_test["a({})"])))
关于SQLITE 标识符的限制字符是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31788990/
C++ Primer 说: The identifier we define in our programs may not contain 2 consecutive underscores, no
标识符术语在文档 alongside constants 中定义。 , 使用几乎相同的用例,尽管术语在运行时计算它们的值,而常量在编译时得到它。潜在地,这可能会使术语使用全局变量,但这是一个遥远而丑陋
我想知道,.Net 标识符中接受哪些字符? 不是 C# 或 VB.Net,而是 CLR。 我问这个的原因是我正在查看 yield return 语句是如何实现的 (C# In Depth),并看到
在PowerShell中,当我专门使用Active Directory时,通常会编译一个包含一组人群列表的对象,通常使用$x = get-adgroup -filter {name -like "*"
使用 hibernate 时: 我必须为每个实体指定一个 ID 或复合 ID,如果我想使用没有任何主键且没有复合键的表怎么办... 提前致谢 最佳答案 没有键的表不是一个好的关系模型。我不会推荐它。
所以我有一些代码正在尝试编译,但我不断收到此错误: 3SATSolver.java:3: expected 这是代码。我只是没有看到什么吗? import java.util.ArrayList;
我正在寻找有关 C 标准(C99 和/或 C11)部分内容的一些说明,主要是关于标识符的使用。 上下文是一个完整的C99标准库的实现,我希望它完全符合标准。 基本问题是:C 标准允许我在多大程度上声明
我有这个 Shader.h 文件,我正在用这段代码制作它: #include #include #include #include in vec2 TexCoords; out vec4 co
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
这是我的代码: #include "stdafx.h" #include #include #include #include using namespace std; int _tmain(
pthread_create() 的第一个参数是一个thread 对象,用于标识新创建的线程。但是,我不确定我是否完全理解其中的含义。 例如,我正在编写一个简单的聊天服务器并且我计划使用线程。线程会随
我想从我的标识符中获得匹配项。 我在 {/describe:foo} 中有一个这样的字符串,我正在尝试匹配 {/describe:} 以返回 foo,但我没有得到正确的正则表达式,会有人介意指出我做错
我遇到了一个奇怪的问题,我似乎找不到答案,但我想我不妨问问。 我有一个执行碰撞检查的抽象类,它有一个“更新”函数,以及“updateX”和“updateY”函数。 class MapCollidabl
我正在尝试创建一个程序来将所有文件从一个目录复制到另一个目录。但我遇到了一个基本问题。它说当我尝试在第 52 行编译时需要标识符。 public bool RecursiveCopy() {
1>cb.c(51): error C2061: syntax error : identifier 'SaveConfiguration' 1>cb.c(51): error C2059: synt
我刚刚发现命名变量 arguments 是个坏主意。 var arguments = 5; (function () { console.log(arguments); })(); Outpu
我们对我们的网站进行了安全测试,并发现了一个漏洞。 问题 If the session identifier were known by an attacker who had access to t
为了估计程序在一次内核启动中可以处理多少数据,我尝试使用 cudaMemGetInfo() 获取一些内存信息。但是,编译器告诉我: 错误:标识符“cudaMemGetInfo”未定义 cudaGetD
我发现我需要使用 xpath 查询来定位几乎是 regexp 类型的字符串,但无法看到如何管理它。我正在使用的当前查询是: $result = $xpath->query('//ul/li[sta
我正在创建我的学生计划表的虚拟版本,它基本上可以让你记下你有哪些科目的作业。 这是界面: 用户从组合框中选择主题,并在相邻的备忘录中输入一些注释。完成后,他们将单击“保存”按钮,将其保存到 .ini
我是一名优秀的程序员,十分优秀!