Declare variable in SQLite and use it(在 SQLite 中声明变量并使用它)
问题描述
我想在 SQLite 中声明一个变量并在 insert
操作中使用它.
I want to declare a variable in SQLite and use it in insert
operation.
就像在 MS SQL 中一样:
Like in MS SQL:
declare @name as varchar(10)
set name = 'name'
select * from table where name = @name
例如,我需要获取 last_insert_row
并在 insert
中使用它.
For example, I will need to get last_insert_row
and use it in insert
.
我发现了一些关于绑定的东西,但我并没有完全理解它.
I have found something about binding but I didn't really fully understood it.
推荐答案
SQLite 不支持本机变量语法,但您可以使用内存中的临时表实现几乎相同的效果.
SQLite doesn't support native variable syntax, but you can achieve virtually the same using an in-memory temp table.
我已经在大型项目中使用了以下方法并且效果很好.
I've used the below approach for large projects and works like a charm.
/* Create in-memory temp table for variables */
BEGIN;
PRAGMA temp_store = 2; /* 2 means use in-memory */
CREATE TEMP TABLE _Variables(Name TEXT PRIMARY KEY, RealValue REAL, IntegerValue INTEGER, BlobValue BLOB, TextValue TEXT);
/* Declaring a variable */
INSERT INTO _Variables (Name) VALUES ('VariableName');
/* Assigning a variable (pick the right storage class) */
UPDATE _Variables SET IntegerValue = ... WHERE Name = 'VariableName';
/* Getting variable value (use within expression) */
... (SELECT coalesce(RealValue, IntegerValue, BlobValue, TextValue) FROM _Variables WHERE Name = 'VariableName' LIMIT 1) ...
DROP TABLE _Variables;
END;
这篇关于在 SQLite 中声明变量并使用它的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 SQLite 中声明变量并使用它


基础教程推荐
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01