1

我需要对我的数据库进行一些维护和更改。我不想编写 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 语法吗?我的意思是创建变量、运行循环、执行其他编程过程......
  • 你有什么好的资源(教程)可以指点我吗? 我的意思是除了mySQL手册之外,因为我不够聪明,无法理解那里写的任何内容......

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

特别是在这个我正在更新一个设置定义的数据库,我在我的整个应用程序中访问它。我正在添加一个值,ID 已使用 auto_increment 编号,但现在我添加的值在逻辑上应该位于顶部,ID 为 1。

所以把它想象成我在引用颜色。现在我有红色,黄色,绿色。现在买我真的很需要蓝色,而蓝色其实是最重要的颜色,所以我需要把它排序在上面。

我从未指定任何外键,我只使用 JOIN 语句从我的数据库中提取数据。我不认为我的表在 PHP 之外相互通信......

另一个我可能需要此类技术的示例是用于一般数据库管理和维护。也强烈地取决于我的应用程序正在增长的事实,并且在我对它进行 BETA 测试时,我可能不得不改变周围的东西,必须对数据进行一些批量编辑,我更愿意使用原子化函数(FOR 、WHILE 等)然后单击每个字段并手动更改它。

希望这现在更有意义。

除此之外:嘿,即使它刹车我的东西,我只是想知道如何让它工作。如何在 mySQL 中运行代码。再说一遍:我可以简单地用 PHP 编写它,在 PHP 代码和 DB 查询之间来回切换,但是既然 SQL 似乎提供了编程命令,为什么不使用这些命令并省去上传和调试 PHP 脚本的麻烦,然后简单地打卡代码直接进入 phpMyAdmin... 如果你愿意,可以想一个不同的例子!:D

4

2 回答 2

2

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”,因为当您需要更新其代码时,需要删除存储过程才能再次重新创建它们。

于 2013-08-16T01:42:39.607 回答
1

我不确定您为什么要这样更改 ID 本身。进一步解释您正在尝试做的事情会有所帮助。ID真的不应该改变。

就查询而言,您可以像这样声明变量(对于 MySQL 中的用户定义变量,您不需要 DECLARE)

SET @id_to_update = 100;

查询可能是这样的

UPDATE table SET somecolumn = somecolumn + 1 
WHERE somecolumn BETWEEN 1 AND @id_to_update;

有很多东西需要学习,比如触发器、存储过程、索引、备份/恢复等。W3schools 是学习 SQL(以及其他许多语言)的良好开端。您确实避免将查询编写为循环。在编写 SQL 时,您需要集中思考。

于 2013-08-16T01:43:50.750 回答