1

10個のエントリを含むSQLデータベースがあるとしましょう。

id  |  code   |  name
-------------------------
1   |  00001  |  Entry 1
2   |  00002  |  Entry 2
3   |  00003  |  Entry 3
4   |  00004  |  Entry 4
5   |  00005  |  Entry 5
6   |  00006  |  Entry 6
7   |  00007  |  Entry 7
8   |  00008  |  Entry 8
9   |  00009  |  Entry 9
10  |  00010  |  Entry 10

pre1.idの1〜5のすべての行のコードエントリに接頭辞を付け、idの6〜10のすべての行に接頭辞を付けられるようにしたいpre2.ので、最終的には次のようになります。

id  |  code         |  name
-------------------------------
1   |  pre1.00001   |  Entry 1
2   |  pre1.00002   |  Entry 2
3   |  pre1.00003   |  Entry 3
4   |  pre1.00004   |  Entry 4
5   |  pre1.00005   |  Entry 5
6   |  pre2.00006   |  Entry 6
7   |  pre2.00007   |  Entry 7
8   |  pre2.00008   |  Entry 8
9   |  pre2.00009   |  Entry 9
10  |  pre2.00010   |  Entry 10

これはできますか?できればphpMyAdminまたはMySQLWorkbenchを使用したいのですが、どのような方法でも検討できます。

4

1 に答える 1

2
UPDATE 
  yourTable 
SET 
  code = CONCAT(
    IF(id BETWEEN 1 AND 5,
       'pre1.',
       'pre2.'),
    code);

またはより一般的なケース

UPDATE 
  yourTable 
SET 
  code = CONCAT('pre1',code)
WHERE
  id BETWEEN 1 AND 5; 

他の範囲についても繰り返します。

于 2011-02-10T12:44:04.020 に答える