Перейти к содержанию
newjey

Помогите составить sql запрос по генерации sku

Рекомендуемые сообщения

Добрый день.

Помогите составить sql запрос для внесения всем товарам данных в поле sku по принципу:

$sku = rand ( 1000 , 9999 ) . "-" . $product_id;
$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = '" . $sku . "' WHERE product_id = '" . (int)$product_id . "'");
тоесть надо всем товарам прописать sku ххх-хххх где ххх-это произвольное, рандомное число, а ххх-это id товара.
Спасибо.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = concat(product_id,'_',product_id)");

 

Поскольку product_id уникален, то и sku будет уникальным.

 

Рандом лучше не использовать - чисто случайно возможно дублирование.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

как вариант - есть такой модуль ;)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

 

$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = concat(product_id,'_',product_id)");
 
Поскольку product_id уникален, то и sku будет уникальным.
 
Рандом лучше не использовать - чисто случайно возможно дублирование.

 

Спасибо, но надо ещё рандомное число, так как id может быть и 1 или 5  и как-то не логично его использовать.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Тогда так

 

$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = concat(product_id+1000,'_',product_id)");

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Тогда так

 

$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = concat(product_id+1000,'_',product_id)");

Выдаёт ошибку 

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = concat(product_id+10' at line 1

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Скопировали неправильно.

 

В предыдущий запрос я добавил только +1000 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Так а как прописать что бы бралось рандомное число?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Если уж так хочется именно рандомное, то

$this->db->query("UPDATE " . DB_PREFIX . "product SET sku = concat(ROUND((RAND() * (9999 - 1000)) + 1000),'_',product_id)");

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Спасибо, получилось.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.