Solved

check the last time the table schema change.

Posted on 2014-01-05
14
943 Views
Last Modified: 2014-01-11
Dear all,

Right now need to check whick table has schema change since the time it create and the last time it change.

should I just use this:

        SELECT *	
    FROM INFORMATION_SCHEMA.TABLES
    WHERE TABLE_SCHEMA='database name' and table_type<> 'view' ;

Open in new window


and use the UPDATE_TIME field ?
0
Comment
Question by:marrowyung
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 8
  • 6
14 Comments
 
LVL 8

Assisted Solution

by:Surrano
Surrano earned 500 total points
ID: 39758641
Yes but take into account that update_time may be null e.g. for freshly created tables.

select table_name, create_time, update_time 
from information_schema.tables 
where table_schema='dbname' and coalesce(update_time,create_time)>'2014-01-06';

Open in new window

0
 
LVL 1

Author Comment

by:marrowyung
ID: 39758650
so null ONLY means for FIRST time created talbe and no schema change after that?

so inserting new record do not affect update_time ?
0
 
LVL 8

Expert Comment

by:Surrano
ID: 39758657
Yes, NULL means only creation.

No, schema contains only the structure of the table and not the contents. UPDATE_TIME should be the time of the latest DDL command executed on that particular object.
0
 Database Backup and Recovery Best Practices

Join Percona’s, Architect, Manjot Singh as he presents Database Backup and Recovery Best Practices (with a Focus on MySQL) on Thursday, July 27, 2017 at 11:00 am PDT / 2:00 pm EDT (UTC-7). In the case of a failure, do you know how long it will take to restore your database?

 
LVL 1

Accepted Solution

by:
marrowyung earned 0 total points
ID: 39758688
do you tested it on MySQL 5.5? I tested it and it seems that even record updates, this update_time also will change.
0
 
LVL 1

Author Comment

by:marrowyung
ID: 39758706
any other way to detect or show out which tables has schema change but not data change ?
0
 
LVL 8

Expert Comment

by:Surrano
ID: 39758754
Yes, it works for me in mysql 5.5. I gave it a try and found that for some reason update_time is always NULL for me, even after DDL commands, while create_time is updated when I change the table structure.

I suspect it depends on engine: we use InnoDB and update_time is constant NULL. Same for MEMORY, CSV and PERFORMANCE_SCHEMA engines. However, MyISAM engine always has an update time, so it seems. Will be back soon with some more tests.
0
 
LVL 8

Expert Comment

by:Surrano
ID: 39758768
OK I dug a bit deeper. Update_time is actually the modification time of the data file which means structure *or* data.

Some changes in table structure modify the create_time field (sic!) *but* even some such ddl commands don't change neither create_time nor update_time.

So it's more like create_time you need and even it is not reliable.

The only thing I can come up with as alternative solution is to use "show create table" in two different points in time and you'll be able to tell (most of) the changes that happened between those two timestamps.
0
 
LVL 1

Author Comment

by:marrowyung
ID: 39758875
show create table don't show the time, it just provide you the statement to create the table.
0
 
LVL 8

Expert Comment

by:Surrano
ID: 39758958
yes, it can be used only to compare an "old" version to the "current" version. It makes sense if you do it in an automated and well defined way, e.g. every night you compare the current state to last night's state. But I'm afraid that's the most MySQL (at least 5.5) can offer you. Sad, isn't it.
0
 
LVL 1

Author Comment

by:marrowyung
ID: 39759115
one thing is, once show create table, how can we compare 2x very long string ? this is the pint then..
0
 
LVL 1

Author Comment

by:marrowyung
ID: 39759120
I just think the other issue, like once we found out the diff. how can we tell what field has been changed? by comparing string, we can only found out the length diff, but not which field it is ?
0
 
LVL 8

Expert Comment

by:Surrano
ID: 39759207
I'd use the "diff" command. That tells you all the info you need. If using windows, consider having a look at GNU tools for windows (if need a command line tool) or use any file compare tool, e.g. Total Commander.
You may also use a versioning system for keeping track of changes, like SVN or CVS.
0
 
LVL 1

Author Comment

by:marrowyung
ID: 39761126
"I'd use the "diff" command."

no! it is my short typing, I don't want to type the whole word..

"If using windows, consider having a look at GNU tools for windows (if need a command line tool) or use any file compare tool, e.g. Total Commander.
You may also use a versioning system for keeping track of changes, like SVN or CVS. "

no,  I need to build an automated method, not like that!!

what if, for any kind of schema cahnge, I tell the developer to include all chance in the delivery notes and I can just cahnge it manually ?

much easlier, right?
0
 
LVL 1

Author Closing Comment

by:marrowyung
ID: 39773141
it seems it works in the other way around.
0

Featured Post

On Demand Webinar: Networking for the Cloud Era

Did you know SD-WANs can improve network connectivity? Check out this webinar to learn how an SD-WAN simplified, one-click tool can help you migrate and manage data in the cloud.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction This article is intended for those who are new to PHP error handling (https://www.experts-exchange.com/articles/11769/And-by-the-way-I-am-New-to-PHP.html).  It addresses one of the most common problems that plague beginning PHP develop…
This post looks at MongoDB and MySQL, and covers high-level MongoDB strengths, weaknesses, features, and uses from the perspective of an SQL user.
In this video, viewers are given an introduction to using the Windows 10 Snipping Tool, how to quickly locate it when it's needed and also how make it always available with a single click of a mouse button, by pinning it to the Desktop Task Bar. Int…
Visualize your data even better in Access queries. Given a date and a value, this lesson shows how to compare that value with the previous value, calculate the difference, and display a circle if the value is the same, an up triangle if it increased…

627 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question