gpt4 book ai didi

mysql - 如何声明变量、运行循环和进行其他自动化

转载 作者:行者123 更新时间:2023-11-29 05:27:37 25 4
gpt4 key购买 nike

我需要对我的数据库进行一些维护和更改。我不想编写 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

但这一定不是正确的语法...

所以这是我的问题:

  • 如何使上面的查询有效?
  • 我应该了解哪些基本知识除了简单地选择、插入或更新行?我的意思是创建变量,运行循环,做其他事情编程程序...
  • 你有什么好的资源(教程)可以指点我吗? 我的意思是除了 mySQL 手册之外,因为我不够聪明,无法理解其中所写的任何内容那里...

编辑:我为什么要这样做?好吧,我的数据库系统仍处于开发阶段,虽然我正在添加功能并进行更改 - 主要是因为我的应用程序在增长,但也因为我对如何组织我的东西有了更好的想法,我可能需要变化。

特别是在这个方面,我正在更新一个设置定义的数据库,我在整个应用程序中都在访问该数据库。我正在添加一个值,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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com