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