本文简要说明了MySQL数据库安装好后自带的INFORMATION_SCHEMA,MySQL,TEST三个数据库的用途。

第一个数据库INFORMATION_SCHEMA:提供了访问数据库元数据的方式。
元数据是关于数据的数据,如数据库名或表名,列的数据类型,或访问权限等。有些时候用于表述该信息的其他术语包括“数据词典”和“系统目录”。
INFORMATION_SCHEMA是信息数据库,其中保存着关于MySQL服务器所维护的所有其他数据库的信息。在INFORMATION_SCHEMA中,有数个只读表。它们实际上是视图,而不是基本表,因此,你将无法看到与之相关的任何文件。
每位MySQL用户均有权访问这些表,但仅限于表中的特定行,在这类行中含有用户具有恰当访问权限的对象。

更多信息请参考这里:

http://dev.mysql.com/doc/refman/5.1/zh/information-schema.html

现在很多人用phpmyadmin管理mysql数据库,有时候不想让普通用户通过phpmyadmin看到INFORMATION_SCHEMA数据库,可以设置一下

在config.inc.php(有的是config.default.php)中设置这样一句
$cfg['Servers'][$i]['hide_db']      = 'information_schema';

SQLyog的设置方法:在设置用户名密码的时候,有个DataBase(s),在其中指定你需要访问的db就可以了。但这样就只能看一个,不知道如果在这里面使用“;”隔开会不会生效,没有试过。

MySQL-front 的设置方法:  这种客户端如果不想看到这个“information_schema”,在设置的Login选项卡中,用户名密码的下面,也有一个DataBase,指定就可以了。

第二个数据库mysql:这个是mysql的核心数据库,类似于sql server中的master表,主要负责存储数据库的用户、权限设置、关键字等mysql自己需要使用的控制和管理信息。不可以删除,如果对mysql不是很了解,也不要轻易修改这个数据库里面的表信息。

第三个数据库是test:这个是安装时候创建的一个测试数据库,和它的名字一样,是一个完全的空数据库,没有任何表,可以删除。

information_schema使用:

select table_name,table_type,engine from information_schema.tables where table_schema='sanguo' order by
table_name desc;

 table_name(表名)
 table_type(表类型)
 引擎
 v56  
 VIEW(视图)
 NULL
 v3

VIEW(视图)

 NULL
 v2

VIEW(视图)

 NULL
 v

VIEW(视图)

 NULL
 tables 
 BASE TABLE(基本表)
 MyISAM 

如何查看某个表更新:

SELECT * FROMinformation_schema.tables where TABLE_SCHEMA='sanguo' AND TABLE_NAME='tb_ad_crontab';

查看update_time字段(很久没有更新不代表现在没有使用哦)。但是我发现update_time为null。

找出在7天前修改的。

USE information_schema;
 
SELECT TABLE_SCHEMA , TABLE_NAME
FROM
TABLES
WHERE UPDATE_TIME IS NOT NULL
AND
UPDATE_TIME > NOW() - INTERVAL 7 DAY
AND
TABLE_SCHEMA = 'store'
AND
TABLE_NAME = 'prices'

stackoverflow:

How can I tell when a MySQL table was last updated?

In later versions of MySQL you can use the information_schema database to tell you when another table was updated:

SELECT UPDATE_TIME
FROM information_schema.tables
WHERE TABLE_SCHEMA ='dbname'AND TABLE_NAME ='tabname'

This does of course mean opening a connection to the database.

An alternative option would be to "touch" a particular file whenever the MySQL table is updated:

On database updates:

  • Open your timestamp file in O_RDRW mode
  • close it again

or alternatively

  • use the PHP equivalent of the utimes() function to change the file timestamp.

On page display:

  • use stat() to read back the file modification time.

找到为什么update_time为null了。因为This only works for MyISAM engine。

我查myisam就有数据:

SELECT table_name,`ENGINE`,update_time FROM `TABLES` where table_name='news';

news MyISAM  2014-02-09 15:14:28

http://stackoverflow.com/questions/2785429/how-can-i-determine-when-an-innodb-table-was-last-changed

http://dba.stackexchange.com/questions/9569/fastest-way-to-check-if-innodb-table-has-changed

    $sql="SELECT UPDATE_TIME
FROM information_schema.tables
WHERE TABLE_SCHEMA ='$dbName' AND TABLE_NAME ='tb_ad_crontab2' "; $sqlModify=$db->createCommand($sql)->queryScalar();
//echo "sqlModify:",$sqlModify,"\n"; $fileMtime=filemtime($this->crontabFile);
 clearstatcache() ;
//echo "fileMtime:",$fileMtime," ",date("Y-m-d H:i:s",$fileMtime),"\n"; $list=array();
//文件过期
if($fileMtime<strtotime($sqlModify))
{
$model=new CDAOCrontab();
$list=$model->getList();
$content="<?php\n return ".var_export($list,TRUE).";\n?>";
file_put_contents($this->crontabFile,$content);
}
else
{
$list=require($this->crontabFile);
}
return $list;

注意:

filemtime和stat一样, 函数的结果会被缓存。请使用 clearstatcache() 来清除缓存。

还有一点要特别注意:

$file=fopen("my.txt","rw");

模式打开

,这样的filemtime的结果一直是当前时间。用只读模式打开则没有问题。

用fopen("my.txt",'r");

MySQL默认INFORMATION_SCHEMA,MySQL,TEST三个数据库用途的更多相关文章

  1. (转载)MySQL默认INFORMATION_SCHEMA,MySQL,TEST三个数据库用途

    (转载)http://www.45it.com/database/201204/29390.htm 本文简要说明了MySQL数据库安装好后自带的INFORMATION_SCHEMA,MySQL,TES ...

  2. MySQL默认INFORMATION_SCHEMA,MySQL,TEST三个数据库用途(转)

    本文简要说明了MySQL数据库安装好后自带的INFORMATION_SCHEMA,MySQL,TEST三个数据库的用途. 第一个数据库INFORMATION_SCHEMA:提供了访问数据库元数据的方式 ...

  3. MySQL、SqlServer、Oracle 三种数据库的优缺点

    MySQL.SqlServer.Oracle 三种数据库的优缺点 一.MySQL 优点: 缺点: 二.SqlServer 优点: 缺点: 三.Oracle 优点: 缺点: 一.MySQL 优点: 体积 ...

  4. mysql系统库INFORMATION_SCHEMA,MySQL,TEST,mysql系统表的作用

    本文简要说明了MySQL数据库安装好后自带的INFORMATION_SCHEMA,MySQL,TEST三个数据库的用途. 第一个数据库INFORMATION_SCHEMA: 提供了访问数据库元数据的方 ...

  5. MySql、SqlServer、Oracle 三种数据库查询分页方式

    SQL Server关于分页 SQL 的资料许多,有的使用存储过程,有的使用游标.本人不喜欢使用游标,我觉得它耗资.效率低:使用存储过程是个不错的选择,因为存储过程是颠末预编译的,执行效率高,也更灵活 ...

  6. MySql、PostgreSql、SqlServer三种数据库的造数存储过程实例

    主要实例:把临时表tmp_table数据插入到目标表target_table 一.MySql造数存储过程实例 mysql造数 -- 第一步,创建临时表 CREATE TEMPORARY TABLE I ...

  7. MySQL、SqlServer、Oracle,这三种数据库的优缺点,你知道吗?

    盘点MySQL.SqlServer.Oracle 三种数据库优缺点 MySQL SqlServer Oracle 一.MySQL 优 点 体积小.速度快.总体拥有成本低,开源:支持多种操作系统:是开源 ...

  8. ubantu 下 修改mysql 默认编码

    启动mysql后,以root登录mysql root@Eadgar-virtual-machine:~# mysql -uroot -proot mysql> show variables li ...

  9. 查看MySQL默认字符集

    MySQL默认字符集相信大家都有所了解,下面就为您介绍一下查看MySQL默认字符集的命令,希望对您学习MySQL默认字符集能有些帮助. MySQL的字符集支持(Character Set Suppor ...

随机推荐

  1. Tomcat源码分析--转

    一.架构 下面谈谈我对Tomcat架构的理解 总体架构: 1.面向组件架构 2.基于JMX 3.事件侦听 1)面向组件架构 tomcat代码看似很庞大,但从结构上看却很清晰和简单,它主要由一堆组件组成 ...

  2. HTML表单介绍

    表单语法结构如下: <form action="url" method="get|post" name="value" enctype ...

  3. [转] 考验你的JavaScript底细

    http://sentsin.com/ 尽管今日的JavaScript已经突飞猛进,但JS的许多特性仍然保留,以下题目并不是有意设坑,许多地方将验证你的JS底细,如果错了一半,请别告诉我你从事前端. ...

  4. python版本简历

  5. 10.30 morning

    P75竞赛时间: ????年??月??日??:??-??:?? 注意事项(请务必仔细阅读) [ 问题描述] 从1 − N中找一些数乘起来使得答案是一个完全平方数,求这个完全平方数最大可能是多少.[输入 ...

  6. 9.30 noip模拟试题

    时限均为1s,内存 256MB 1.某种密码(password.*) 关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY. ...

  7. C# 内存管理优化实践

    内存优化畅想系列文章已经结束了,很多读者读完之后可能觉得“然并卵”,毕竟都是给微软提的建议而已,现在都没有实现.那么为了优化内存,有没有什么我们现在就能用的技巧呢?我的答案是:有.网上关于.net内存 ...

  8. HTML5 Media事件

    Media 事件 由媒介(比如视频.图像和音频)触发的事件(适用于所有 HTML 元素,但常见于媒介元素中,比如 <audio>.<embed>.<img>.< ...

  9. Intellij Idea 13 vmoptions (Mac版本)

    -ea -server -Xms1g -Xmx1g -Xss16m -XX:PermSize=256m -XX:MaxPermSize=256m -XX:+DoEscapeAnalysis -XX:+ ...

  10. 层模型--固定定位(position:fixed)

    fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身. 由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口 ...