- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要对我的数据库进行一些维护和更改。我不想编写 PHP 代码来执行此操作,我更愿意将一些代码插入到 phpMyAdmin 的 SQL 执行窗口中。
比如我想设置一个表中所有行的ID值+1。但是由于它们是唯一的,如果我尝试说 UPDATE table SET column_ID = column_ID +1
它会冲我大喊大叫,说它不能重复 ID - 当然不是因为它将从 ID 1 开始,将其设置为 2,但 ID 2 已存在。
所以我想继续做这样的事情:从 ID 100 开始,然后逐步减少到 1。
DECLARE @id_to_update = 100
WHILE @id_to_update >= 1
BEGIN
UPDATE table SET column_ID = column_ID +1 WHERE column_ID = @id_to_update
@id_to_update = @id_to_update -1
END
但这一定不是正确的语法...
所以这是我的问题:
编辑:我为什么要这样做?好吧,我的数据库系统仍处于开发阶段,虽然我正在添加功能并进行更改 - 主要是因为我的应用程序在增长,但也因为我对如何组织我的东西有了更好的想法,我可能需要变化。
特别是在这个方面,我正在更新一个设置定义的数据库,我在整个应用程序中都在访问该数据库。我正在添加一个值,ID 已使用 auto_increment 进行编号,但现在我添加的值在逻辑上应该位于顶部,ID 为 1。
所以把它想象成我在引用颜色。现在我有红色、黄色、绿色。现在购买 我真的需要蓝色,而蓝色实际上是最重要的颜色,所以我需要将它排序在最前面。
我从未指定任何外键,我只是使用 JOIN 语句从我的数据库中提取数据。我不认为我的表在 PHP 之外相互交谈......
另一个例子,为什么我可能需要这样的技术来进行一般的数据库管理和维护。我的应用程序正在增长这一事实也强烈决定了这一点,虽然我正在对其进行 BETA 测试,但我可能不得不改变周围的东西,必须对数据进行一些批量编辑,我更愿意使用原子化功能(FOR 、WHILE 等),然后单击每个字段并手动更改。
希望这现在更有意义。
除此之外:嘿,即使它会影响我的东西,我只想知道如何让它工作。如何在 mySQL 中运行代码。再说一遍:我可以简单地用 PHP 编写它,在 PHP 代码和数据库查询之间来回切换,但是既然 SQL 似乎提供了编程命令,为什么不使用它们并省去上传和调试 PHP 脚本的麻烦,然后简单地插入将代码直接放入 phpMyAdmin 中...如果您愿意,请考虑一个不同的示例! :D
最佳答案
MySQL 流控制语句(例如 while、if 等)只能在存储过程中完成(参见 http://dev.mysql.com/doc/refman/5.0/en/flow-control-statements.html)。这是关于如何创建存储过程的文档:http://dev.mysql.com/doc/refman/5.0/en/create-procedure.html .
这是一个让您入门的基本存储过程示例:
DELIMITER $$
DROP PROCEDURE IF EXISTS `myProcedure` $$
CREATE PROCEDURE `myProcedure`()
BEGIN
DECLARE counter int(3) DEFAULT 0;
WHILE (counter < 50) DO
SELECT * from my_table where id = counter;
set counter := counter +1;
END WHILE;
END $$
然后你可以调用它:
call my_schema.myProcedure();
请注意,我包含了“DROP PROCEDURE IF EXISTS”,因为当您需要更新其代码时,需要先删除存储过程,然后才能再次重新创建它们。
关于mysql - 如何声明变量、运行循环和进行其他自动化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18263726/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to nest OR statements in JavaScript? 有没有办法做到这一点:
在 JavaScript 中有没有办法让一个变量总是等于一个变量?喜欢var1 = var2但是当var2更新,也是var1 . 例子 var var1 = document.getElementBy
我正在努力理解这代表什么 var1 = var2 == var3 我的猜测是这等同于: if (var2 == var3): var1 = var2 最佳答案 赋值 var1 = var2
这个问题已经有答案了: What does the PHP error message "Notice: Use of undefined constant" mean? (2 个回答) 已关闭 8
我在临时表中有几条记录,我想从每条记录中获取一个值并将其添加到一个变量中,例如 color | caption -------------------------------- re
如何将字符串转为变量(字符串变量--> $variable)? 或者用逗号分隔的变量列表然后转换为实际变量。 我有 2 个文件: 列名文件 行文件 我需要根据字符串匹配行文件中的整行,并根据列名文件命
我有一个我无法解决的基本 php 问题,我也想了解为什么! $upperValueCB = 10; $passNodeMatrixSource = 'CB'; $topValue= '$uppe
这可能吗? php $variable = $variable1 || $variable2? 如果 $variable1 为空则使用 $variable2 是否存在类似的东西? 最佳答案 PHP 5
在 Perl 5.20 中,for 循环似乎能够修改模块作用域的变量,但不能修改父作用域中的词法变量。 #!/usr/bin/env perl use strict; use warnings; ou
为什么这不起作用: var variable; variable = variable.concat(variable2); $('#lunk').append(variable) 我无法弄清楚这一点
根据我的理解,在32位机器上,指针的sizeof是32位(4字节),而在64位机器上,它是8字节。无论它们指向什么数据类型,它们都有固定的大小。我的计算机在 64 位上运行,但是当我打印包含 * 的大
例如: int a = 10; a += 1.5; 这运行得很完美,但是 a = a+1.5; 此作业表示类型不匹配:无法从 double 转换为 int。所以我的问题是:+= 运算符 和= 运算符
您好,我写了这个 MySQL 存储过程,但我一直收到这个语法错误 #1064 - You have an error in your SQL syntax; check the manual that
我试图在我的场景中显示特定的奖牌,这取决于你的高分是基于关卡的目标。 // Get Medal Colour if levelHighscore goalScore { sc
我必须维护相当古老的 Visual C++ 源代码的大型代码库。我发现代码如下: bIsOk = !!m_ptr->isOpen(some Parameters) bIsOk的数据类型是bool,is
我有一个从 MySQL 数据库中提取的动态产品列表。在 list 上有一个立即联系 按钮,我正在使用一个 jquery Modal 脚本,它会弹出一个表单。 我的问题是尝试将产品信息变量传递给该弹出窗
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
jQuery Core Style Guidelines建议两种不同的方法来检查变量是否已定义。 全局变量:typeof variable === "undefined" 局部变量:variable
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: “Variable” Variables in Javascript? 我想肯定有一种方法可以在 JavaScrip
在语句中使用多重赋值有什么优点或缺点吗?在简单的例子中 var1 = var2 = true; 赋值是从右到左的(我相信 C# 中的所有赋值都是如此,而且可能是 Java,尽管我没有检查后者)。但是,
我是一名优秀的程序员,十分优秀!