免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2333 | 回复: 9
打印 上一主题 下一主题

请问如何在mysql中实现将当前的时间作为建表时的表名 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-01-09 11:44 |只看该作者 |倒序浏览
请问如何在mysql中实现将当前的时间作为建表时的表名
我需要通过sql自动实现每天建一个table,这个table需要以日期作为table name。

论坛徽章:
0
2 [报告]
发表于 2006-01-10 10:41 |只看该作者
没人知道吗?

论坛徽章:
0
3 [报告]
发表于 2006-01-10 11:31 |只看该作者
你自己试验过没,你的结果是什么?

论坛徽章:
0
4 [报告]
发表于 2006-01-10 12:51 |只看该作者
这个问题不难吧.取当前的时候,建表时以此为表名就是了,有什么问题吗?所有的东西最好先动手试试,这样印象深一些.

论坛徽章:
0
5 [报告]
发表于 2006-01-10 13:09 |只看该作者
呵呵,是有些难度的。因为我以前也这么做过,所以我想知道楼主进度到哪里。
如果用 2006-01-01 或者 20060101 这两种方式,那么都要加上反引号才行:`2006-01-01`、`20060101`。
而且,这还是用脚本程序配合mysql来做的,如果单独在mysql中用sql实现,从取时间开始,我还真不知道怎么做。

论坛徽章:
0
6 [报告]
发表于 2006-01-10 14:11 |只看该作者
不行牙,我试过很多种了
比如:
create table `curdate()`
是不是要加什么转换函数啊?

论坛徽章:
0
7 [报告]
发表于 2006-01-10 15:26 |只看该作者
原帖由 rardge 于 2006-1-10 13:09 发表
而且,这还是用脚本程序配合mysql来做的,如果单独在mysql中用sql实现,从取时间开始,我还真不知道怎么做。

我说了呀,用脚本我成功过,比如 $table = '`20060101`',然后再提交查询 create table $table (...) 到 MySQL 服务器。
只在mysql环境下用sql语句来做我也没方向。

论坛徽章:
0
8 [报告]
发表于 2006-01-10 16:06 |只看该作者

没看懂

具体要怎么写啊?
先设定环境变量?
原帖由 rardge 于 2006-1-10 15:26 发表

我说了呀,用脚本我成功过,比如 $table = '`20060101`',然后再提交查询 create table $table (...) 到 MySQL 服务器。
只在mysql环境下用sql语句来做我也没方向。

论坛徽章:
0
9 [报告]
发表于 2006-01-10 16:48 |只看该作者
一个shell脚本,你修改后放到crontab去就可以了。
--------------------------------------------------------------------------------------
#!/bin/sh

DATE=$(date "+%Y%m%d")
TB='`'$DATE'`'

/usr/local/mysql/bin/mysql -t -uroot -pYourPassword test <<QUERY_SQL
CREATE TABLE IF NOT EXISTS $TB (id int);
INSERT INTO $TB VALUES (1),(2),(3);
SELECT * FROM $TB;
QUIT
QUERY_SQL
exit 0
--------------------------------------------------------------------------------------

论坛徽章:
0
10 [报告]
发表于 2006-01-11 09:27 |只看该作者
支持楼上的。顶
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP