MYSQL执行sql语句,批量更改为指定时间段的随机时间
比如,update phome_ecms_news set newstime='新时间' where newstime='原时间',这样的更改只会更改为相同的时间。 展开
1、首先打开mysql,连接一个数据库,点击上方的【查询】按钮,再点击【新建查询】,如图所示。
2、在查询框中,输入sql语句“EXPLAIN select * from users”,前面加了EXPLAIN,则查询语句在执行时,会记录执行过程效率。
3、在查询框中,输入sql语句“EXPLAIN select * from users”,前面加了EXPLAIN,则查询语句在执行时,会记录执行过程效率。
4、然后看到结果1那一栏,可以看到,查询的表是【users】,查询类型是【SIMPLE】,type是【all】,因为用了“select *”语句。
5、最后一栏显示的是【状态】,即表示一些执行的状态,如接收到的字节数,值是多少;发送的字节数,值是多少等。
推荐于2017-11-25
CREATE TABLE test_random_time (
id int,
newstime datetime
);
INSERT INTO test_random_time
SELECT 1, '2012-11-13 01:00:00' UNION ALL
SELECT 2, '2012-11-13 02:00:00' UNION ALL
SELECT 3, '2012-11-13 03:00:00' UNION ALL
SELECT 4, '2012-11-13 04:00:00' UNION ALL
SELECT 5, '2012-11-13 05:00:00';
-- 20点至23点。
-- 区间=3小时=180分钟=10800秒
-- 下面更新时间 = '2012-11-13 20:00:00' 之后的 随机秒数。(区间在 1- 10800 之间)
UPDATE test_random_time
SET
newstime = DATE_ADD('2012-11-13 20:00:00', INTERVAL FLOOR(1 + (RAND() * 10800)) SECOND )
WHERE
DATE(newstime) = '2012-11-13';
-- 数据核对.
mysql> SELECT * FROM test_random_time;
+------+---------------------+
| id | newstime |
+------+---------------------+
| 1 | 2012-11-13 22:25:14 |
| 2 | 2012-11-13 22:41:16 |
| 3 | 2012-11-13 20:10:35 |
| 4 | 2012-11-13 21:49:08 |
| 5 | 2012-11-13 22:33:55 |
+------+---------------------+
5 rows in set (0.00 sec)
是不是可以直接放在sql运行呢!这样好像日期没有换了吗?
什么叫 “直接放在sql运行呢” ?
难道我上面贴的语句, 都不是 sql 语句?
上面第一行, 创建一个测试表
后面 插入5行测试数据。 时间为 2012-11-13 1点到5点。
然后就是一条更新用的 sql 语句。
就是在 mysql 命令行下面, 输入的语句啊。
没有用其它的语言来折腾啦。
至于你问的 “这样好像日期没有换了吗?”
我又去看了看你的那个题目, 发现还有个日期区间的限制条件。
我这里就 删除表, 重建表, 插入相同的测试数据以后, 执行下面的 SQL
-- 20点至23点。
-- 区间=3小时=180分钟=10800秒
-- 下面更新时间 = '2012-05-01 20:00:00' 之后的 随机秒数。(区间在 1- 10800 之间)
-- 2012-5-1到2013-6-6的范围
-- 区间= 401 天
-- 下面更新日期 = '2012-05-01 随机时间' 之后的 随机天数。 (区间在 1-401 之间)
UPDATE test_random_time
SET
newstime =
DATE_ADD(
DATE_ADD('2012-05-01 20:00:00', INTERVAL FLOOR(1 + (RAND() * 10800)) SECOND ),
INTERVAL FLOOR(1 + (RAND() * 401)) DAY)
WHERE
DATE(newstime) = '2012-11-13';
mysql> SELECT * FROM test_random_time;
+------+---------------------+
| id | newstime |
+------+---------------------+
| 1 | 2012-09-04 20:53:06 |
| 2 | 2012-10-31 22:02:11 |
| 3 | 2013-04-05 20:43:37 |
| 4 | 2013-05-13 21:29:02 |
| 5 | 2012-08-14 20:38:56 |
+------+---------------------+
5 rows in set (0.00 sec)
function rand_time($a,$b)
{
$a=strtotime($a);
$b=strtotime($b);
return date( "Y-m-d H:m:s", mt_rand($a,$b));
}
$date1="2010-05-10 20:03:01";
$date2="2010-05-11 20:21:32";
$num = 10;
$i=0;
while ($i < $num){
$date = rand_time($date1,$date2);
$datea[]= $date;
$i++;
}
sort($datea);
foreach ($datea as $values)
{
echo $values."<br>";
}
?>
要怎么使用,不要直接复制来的。最起码说一下嘛!
这就是一个取随机日期的代码,$num变量的值改成所要循环执行sql语句的次数,
比如更新20条数据,$num=20就好了。循环执行sql语句的时候,每执行一次更新,就在时间数组
里取一个日期,作为set newstime='新时间'中newstime的值:比如,执行第一次更新的时候sql
语句就是
“update phome_ecms_news set newstime='“.$datea[$i].”' where newstime='原时间'”
$i是循环变量,是从0开始的。