Последние записи
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
- wprintf как напечатать кириллицу
- Взаимодействие через командную строку
- Сравнение языков на массивах. Часть 1
- Сравнение языков по скорости
- Чтение огромных xml-файлов
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
28th
Фев
«Перемешать» данные в БД
Posted by maloy under sql
s88s
Доброго времени суток .
У меня есть база данных примерно такого вида
id
title
nick
и так далее … в общем суть в чем мне надо сделать запрос такого вида что бы можно было все ячейки переставить местами то есть ID оставить как есть а вот все остальное что бы изменилось
Пример
как сейчас
1 текст1 ник1 …
2 текст2 ник2 …
3 текст3 ник3 …
4 текст4 ник4 …
а после запроса что бы стало так
1 текст2 ник2 …
2 текст4 ник4 …
3 текст1 ник1 …
4 текст3 ник3 …
и при каждом запросе все становилось рандомно .
вот у меня есть один запрос но он не работает :
<?php
if (!defined('Q_COMMON')) exit('stop');
$error = test_db_connect();
if ($error) {
test_print_error($error);
exit;
}
/************************************************/
/* Processing */
$res = mysql_query('SELECT count(*) AS cnt FROM '.MYSQL_TABLE_PREFIX.'test LIMIT 1');
list ($count) = mysql_fetch_array($res);
mysql_free_result($res);
$ind = $count*10;
$res = mysql_query('SELECT id, last_use FROM '.MYSQL_TABLE_PREFIX.'test');
while ($row = mysql_fetch_array($res)) {
$new_date = date("Y-m-d H:i:s", time()-rand(100, $ind));
$sql = 'UPDATE '.MYSQL_TABLE_PREFIX.'test SET last_use="'.$new_date.'" WHERE id='.$row['id'];
if(!mysql_query($sql)) {
echo '<br>'.mysql_error();
exit();
}
}
?>
Помогите пожалуйста
evg_m
подозреваю что ТС всего навсего надо достать(!) N случайных записей из ….
ну и пронумеровать их.
1 текст2 ник2 … 2 текст4 ник4 … 3 текст1 ник1 … 4 текст3 ник3 … и при каждом запросе все становилось рандомно . |
веселее всего окажется если среди ID не окажется 1. хотя при его вольготном обращении c ID… такого просто не может быть.
mix;
select top N
id as num, .... from ... order by id
select newid() as r, * into #t from t
select top N
(select count(*) from #t as mix where mix.r<t.r) as num
, * from #t as t order by t.r
select newid() as r, id into #t from t
select top N
(select count(*) from #t as mix where mix.r<t.r) as num, b.*
from #t as t
inner join b on t.id=b.id
as t order by t.r
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)