{"id":1060,"date":"2008-11-04T09:02:59","date_gmt":"2008-11-04T06:02:59","guid":{"rendered":"http:\/\/firefang.net\/blog\/?p=1060"},"modified":"2008-11-04T09:02:59","modified_gmt":"2008-11-04T06:02:59","slug":"sqlfairy","status":"publish","type":"post","link":"https:\/\/firefang.net\/blog\/1060","title":{"rendered":"sqlfairy"},"content":{"rendered":"<p>\u05d4\u05e1\u05d9\u05d8\u05d5\u05d0\u05e6\u05d9\u05d4 \u05d4\u05d1\u05d0\u05d4 \u05ea\u05d4\u05d9\u05d4 \u05de\u05d5\u05db\u05e8\u05ea \u05dc\u05db\u05de\u05d4 \u05de\u05e4\u05ea\u05d7\u05d9\u05dd:<\/p>\n<p>\u05d1\u05d7\u05d1\u05e8\u05d4 \u05e2\u05d5\u05d1\u05d3\u05d9\u05dd \u05e2\u05dc \u05ea\u05d5\u05db\u05e0\u05d4 \u05d1\u05e6\u05d3 \u05d4\u05e9\u05e8\u05ea \u05e9\u05db\u05d5\u05dc\u05dc\u05ea \u05d1\u05e1\u05d9\u05e1 \u05e0\u05ea\u05d5\u05e0\u05d9\u05dd. \u05db\u05de\u05d5\u05d1\u05df \u05e9\u05dc\u05d0 \u05de\u05e4\u05ea\u05d7\u05d9\u05dd \u05d9\u05e9\u05d9\u05e8\u05d5\u05ea \u05e2\u05dc \u05de\u05e2\u05e8\u05db\u05ea \u05d4\u05e4\u05e8\u05d5\u05d3\u05e7\u05e9\u05df, \u05d0\u05dc\u05d0 \u05e2\u05dc \u05de\u05e2\u05e8\u05db\u05ea \u05d3\u05d5\u05de\u05d4 &#8211; \u05d5\u05d0\u05d5\u05dc\u05d9 \u05d0\u05e4\u05d9\u05dc\u05d5 \u05db\u05dc \u05de\u05e4\u05ea\u05d7 \u05e2\u05d5\u05d1\u05d3 \u05e2\u05dc \u05d2\u05e8\u05e1\u05d0 \u05de\u05e7\u05d5\u05de\u05d9\u05ea \u05e9\u05dc \u05d1\u05e1\u05d9\u05e1 \u05d4\u05e0\u05ea\u05d5\u05e0\u05d9\u05dd.<\/p>\n<p>\u05d1\u05de\u05e9\u05da \u05d4\u05d6\u05de\u05df, \u05de\u05e4\u05ea\u05d7\u05d9\u05dd \u05de\u05e9\u05e0\u05d9\u05dd \u05d0\u05ea \u05d4\u05de\u05d1\u05e0\u05d4 \u05e9\u05dc \u05d1\u05e1\u05d9\u05e1 \u05d4\u05e0\u05ea\u05d5\u05e0\u05d9\u05dd, \u05de\u05d5\u05e1\u05d9\u05e4\u05d9\u05dd \u05d8\u05d1\u05dc\u05d5\u05ea,\u05e2\u05de\u05d5\u05d3\u05d5\u05ea \u05d5\u05d0\u05d9\u05e0\u05d3\u05e7\u05e1\u05d9\u05dd, \u05d5\u05d0\u05d5\u05dc\u05d9 \u05d2\u05dd \u05de\u05d5\u05d7\u05e7\u05d9\u05dd \u05db\u05de\u05d4.<br \/>\n\u05d9\u05db\u05d5\u05dc \u05dc\u05d4\u05d9\u05d5\u05ea \u05e9\u05d9\u05e9 \u05d9\u05d5\u05ea\u05e8 \u05de\u05de\u05e4\u05ea\u05d7 \u05d0\u05d7\u05d3 \u05e9\u05e2\u05d5\u05e9\u05d4 \u05d0\u05ea \u05d6\u05d4.<\/p>\n<p>\u05d0\u05d9\u05da \u05de\u05e2\u05d1\u05d9\u05e8\u05d9\u05dd \u05d0\u05ea \u05d4\u05e9\u05d9\u05e0\u05d5\u05d9\u05d9\u05dd \u05d4\u05d0\u05dc\u05d5 \u05dc\u05de\u05e2\u05e8\u05db\u05ea \u05d4\u05e4\u05e8\u05d5\u05d3\u05e7\u05e9\u05df?<\/p>\n<p>\u05d0\u05dd \u05de\u05e2\u05e8\u05db\u05ea \u05d4\u05e4\u05e8\u05d5\u05d3\u05e7\u05e9\u05df \u05e2\u05d3\u05d9\u05d9\u05df \u05dc\u05d0 \u05dc\u05de\u05e2\u05dc\u05d4, \u05d0\u05e4\u05e9\u05e8 \u05db\u05de\u05d5\u05d1\u05df \u05dc\u05d4\u05e2\u05d9\u05e3 \u05d0\u05ea \u05d1\u05e1\u05d9\u05e1 \u05d4\u05e0\u05ea\u05d5\u05e0\u05d9\u05dd \u05d5\u05dc\u05d9\u05e6\u05d5\u05e8 \u05d0\u05ea \u05d4\u05db\u05dc \u05de\u05d7\u05d3\u05e9, \u05d0\u05d1\u05dc \u05d6\u05d4 \u05dc\u05d0 \u05d4\u05de\u05e7\u05e8\u05d4 \u05d1\u05d3\u05e8\u05da \u05db\u05dc\u05dc.<br \/>\n\u05d0\u05d5\u05e4\u05e6\u05d9\u05d4 \u05d0\u05d7\u05e8\u05ea \u05d4\u05d9\u05d0 \u05dc\u05e9\u05d0\u05d5\u05dc \u05d0\u05ea \u05d4\u05de\u05e4\u05ea\u05d7\u05d9\u05dd, \u05de\u05d4 \u05e9\u05d9\u05e0\u05d9\u05ea\u05dd? \u05d0\u05d1\u05dc \u05d4\u05dd \u05d0\u05d7\u05e8\u05d9 \u05e9\u05d1\u05d5\u05e2\u05d9\u05d9\u05dd, \u05d0\u05e3 \u05d0\u05d7\u05d3 \u05dc\u05d0 \u05d6\u05d5\u05db\u05e8 \u05d1\u05d3\u05d9\u05d5\u05e7 \u05de\u05d4 \u05d4\u05d5\u05d0 \u05e9\u05d9\u05e0\u05d4 \u05db\u05d3\u05d9 \u05dc\u05e4\u05ea\u05d5\u05e8 \u05d1\u05d0\u05d2 \u05d0\u05d6\u05d5\u05d8\u05e8\u05d9 \u05d6\u05d4 \u05d0\u05d5 \u05d0\u05d7\u05e8 \u05d0\u05d5 \u05db\u05d3\u05d9 \u05dc\u05d4\u05d5\u05e1\u05d9\u05e3 \u05e4\u05d9\u05e6'\u05e8 \u05de\u05e1\u05d5\u05d9\u05d9\u05dd, \u05d5\u05db\u05de\u05d5\u05d1\u05df \u05e9\u05d0\u05e3 \u05d0\u05d7\u05d3 \u05dc\u05d0 \u05e8\u05d5\u05e9\u05dd \u05d3\u05d1\u05e8\u05d9\u05dd \u05db\u05d0\u05dc\u05d5.<br \/>\n\u05d0\u05d5\u05e4\u05e6\u05d9\u05d4 \u05e9\u05dc\u05d9\u05e9\u05d9\u05ea \u05d4\u05d9\u05d0 \u05dc\u05d4\u05e9\u05d5\u05d5\u05ea \u05d9\u05d3\u05e0\u05d9\u05ea, \u05dc\u05d0 \u05db\u05d9\u05e3 \u05d2\u05d3\u05d5\u05dc \u05d5\u05de\u05d5\u05e2\u05d3 \u05dc\u05d8\u05e2\u05d5\u05d9\u05d5\u05ea.<\/p>\n<p>\u05d0\u05d1\u05dc \u05d7\u05d9\u05d9\u05d1\u05ea \u05dc\u05d4\u05d9\u05d5\u05ea \u05d3\u05e8\u05da \u05dc\u05d1\u05e6\u05e2 \u05d0\u05d5\u05d8\u05d5\u05de\u05e6\u05d9\u05d4 \u05e9\u05dc \u05d4\u05d0\u05d5\u05e4\u05e6\u05d9\u05d4 \u05d4\u05e9\u05dc\u05d9\u05e9\u05d9\u05ea, \u05d6\u05d4 \u05ea\u05d4\u05dc\u05d9\u05da \u05d3\u05d9 \u05de\u05db\u05d0\u05e0\u05d9.<br \/>\n\u05de\u05e1\u05ea\u05d1\u05e8 \u05e9\u05d9\u05e9 \u05d3\u05e8\u05da, \u05db\u05dc\u05d9 \u05d1\u05e9\u05dd <a href=\"http:\/\/sqlfairy.sourceforge.net\/\">SQLFairy<\/a> \u05e9\u05de\u05d0\u05e4\u05e9\u05e8 \u05dc\u05e7\u05d1\u05dc \u05d4\u05d1\u05d3\u05dc\u05d9\u05dd \u05d1\u05d9\u05df \u05e9\u05ea\u05d9 \u05e1\u05db\u05d9\u05de\u05d5\u05ea MySQL \u05d5\u05de\u05e4\u05d9\u05e7 \u05d4\u05d5\u05e8\u05d0\u05d5\u05ea MySQL \u05dc\u05de\u05e2\u05d1\u05e8 \u05de\u05e1\u05db\u05d9\u05de\u05d4 \u05d0\u05d7\u05ea \u05dc\u05e9\u05e0\u05d9\u05d4. \u05d4\u05d5\u05d0 \u05de\u05d0\u05e4\u05e9\u05e8 \u05e2\u05d5\u05d3 \u05db\u05de\u05d4 \u05d3\u05d1\u05e8\u05d9\u05dd, \u05d0\u05d1\u05dc \u05d0\u05e0\u05d9 \u05d7\u05d5\u05e9\u05d1 \u05e9\u05d6\u05d4 \u05d4\u05db\u05d9 \u05de\u05e2\u05e0\u05d9\u05d9\u05df.<br \/>\n\u05ea\u05d9\u05d0\u05d5\u05e8\u05d8\u05d9\u05ea \u05d4\u05db\u05dc\u05d9 \u05ea\u05d5\u05de\u05da \u05d2\u05dd \u05d1\u05de\u05e2\u05d1\u05e8 \u05d1\u05d9\u05df \u05d1\u05e1\u05d9\u05e1\u05d9 \u05e0\u05ea\u05d5\u05e0\u05d9\u05dd \u05e9\u05d5\u05e0\u05d9\u05dd, \u05d0\u05d1\u05dc \u05e7\u05d9\u05d1\u05dc\u05ea\u05d9 \u05e8\u05d5\u05e9\u05dd \u05e9\u05d6\u05d4 \u05e2\u05d5\u05d1\u05d3 \u05de\u05de\u05e9 \u05e8\u05e7 \u05e2\u05dd MySQL.<\/p>\n<p>\u05d1\u05d2\u05d3\u05d5\u05dc, \u05db\u05d3\u05d9 \u05dc\u05e2\u05d1\u05d5\u05e8 \u05de\u05e1\u05db\u05d9\u05de\u05d4 \u05d0\u05d7\u05ea \u05dc\u05e9\u05e0\u05d9\u05d4, \u05de\u05d4 \u05e9\u05e6\u05e8\u05d9\u05da \u05dc\u05e2\u05e9\u05d5\u05ea \u05d6\u05d4 \u05dc\u05d4\u05d5\u05e8\u05d9\u05d3 \u05d0\u05ea \u05d4\u05de\u05d1\u05e0\u05d4 \u05e9\u05dc \u05e9\u05e0\u05d9 \u05d4\u05e1\u05db\u05d9\u05de\u05d5\u05ea \u05dc\u05e7\u05d5\u05d1\u05e5 \u05e2\u05dd mysqldump, \u05dc\u05de\u05e9\u05dc:<br \/>\n[code]<br \/>\nsource db.conf<br \/>\nmysqldump &#8211;no-data -h $HOST -u $USER &#8211;password=$PASS $DB_NAME $TABLES | gzip > struct.sql.gz<br \/>\n[\/code]<\/p>\n<p>\u05db\u05d0\u05e9\u05e8 \u05d4\u05e7\u05d5\u05d1\u05e5 db.conf \u05de\u05db\u05d9\u05dc \u05d0\u05ea \u05d4\u05de\u05e9\u05ea\u05e0\u05d9\u05dd \u05d4\u05d3\u05e8\u05d5\u05e9\u05d9\u05dd \u05dc\u05d4\u05ea\u05d7\u05d1\u05e8:<br \/>\n[code]<br \/>\nHOST=server_host (usually localhost)<br \/>\nUSER=username<br \/>\nPASS=password<br \/>\nDB_NAME=database_name<br \/>\nTABLES=&quot;table1 table2 table3&quot;<br \/>\n[\/code]<\/p>\n<p>\u05d1\u05e8\u05d2\u05e2 \u05e9\u05e9\u05d9\u05e9 \u05dc\u05e0\u05d5 \u05d0\u05ea \u05e9\u05ea\u05d9 \u05d4\u05e1\u05db\u05d9\u05de\u05d5\u05ea \u05d1\u05d9\u05d3, \u05d5\u05d0\u05d7\u05e8\u05d9 \u05e9\u05d4\u05ea\u05e7\u05e0\u05d5 \u05d0\u05ea SQLFairy \u05db\u05de\u05d5\u05d1\u05df (apt-get install sqlfairy \u05e2\u05dc \u05d3\u05d1\u05d9\u05d0\u05df \u05dc\u05e0\u05d9, \u05d0\u05dd \u05d0\u05ea\u05dd \u05e2\u05dc Etch \u05ea\u05ea\u05e7\u05d9\u05e0\u05d5 \u05d9\u05d3\u05e0\u05d9\u05ea \u05de\u05d4\u05e7\u05d5\u05d3, \u05d4\u05d2\u05e8\u05e1\u05d0 \u05e9\u05d1Etch \u05dc\u05d0 \u05e2\u05d5\u05d1\u05d3\u05ea \u05d8\u05d5\u05d1), \u05d0\u05e4\u05e9\u05e8 \u05dc\u05e7\u05d1\u05dc \u05d4\u05d5\u05e8\u05d0\u05d5\u05ea \u05de\u05e2\u05d1\u05e8 \u05de\u05e1\u05db\u05d9\u05de\u05d4 \u05d0\u05d7\u05ea \u05dc\u05e9\u05e0\u05d9\u05d4 \u05db\u05da:<br \/>\n[code]<br \/>\nsqlt-diff current.sql=MySQL new.sql=MySQL 2> \/dev\/null > diff.sql<br \/>\n[\/code]<\/p>\n<p>\u05d6\u05d4 \u05d9\u05e4\u05d9\u05e7 \u05d4\u05d5\u05e8\u05d0\u05d5\u05ea \u05de\u05e2\u05d1\u05e8 (CREATE , ALTER, DROP) \u05e9\u05d9\u05d4\u05d9\u05d4 \u05d0\u05e4\u05e9\u05e8 \u05dc\u05d4\u05e8\u05d9\u05e5 \u05e2\u05dc \u05d1\u05e1\u05d9\u05e1 \u05d4\u05e0\u05ea\u05d5\u05e0\u05d9\u05dd \u05db\u05d3\u05d9 \u05dc\u05d9\u05e9\u05e8 \u05e7\u05d5 \u05d1\u05d9\u05df \u05d4\u05e1\u05db\u05d9\u05de\u05d5\u05ea.<br \/>\n(\u05d0\u05e0\u05d9 \u05e9\u05d5\u05dc\u05d7 \u05d0\u05ea stderr \u05dc\/dev\/null \u05db\u05d9 \u05d9\u05e9 \u05d0\u05d6\u05d4\u05e8\u05d5\u05ea \u05d7\u05e1\u05e8\u05d5\u05ea \u05d7\u05e9\u05d9\u05d1\u05d5\u05ea \u05de\u05d4\u05e1\u05e7\u05e8\u05d9\u05e4\u05d8 \u05e9\u05e0\u05d5\u05d1\u05e2\u05d5\u05ea \u05de\u05d2\u05e8\u05e1\u05ea perl \u05d9\u05d5\u05ea\u05e8 \u05d7\u05d3\u05e9\u05d4 \u05de\u05d6\u05d5 \u05e9\u05d4\u05e1\u05e7\u05d9\u05e4\u05d8 \u05e4\u05d5\u05d7\u05ea \u05e2\u05dc\u05d9\u05d4)<br \/>\n\u05d0\u05e0\u05d9 \u05de\u05e9\u05ea\u05de\u05e9 \u05d1\u05e1\u05e7\u05e8\u05d9\u05e4\u05d8 \u05d3\u05d5\u05de\u05d4 \u05dc\u05d6\u05d4 \u05db\u05d3\u05d9 \u05dc\u05d4\u05e4\u05d5\u05da \u05d0\u05ea \u05d4\u05ea\u05d4\u05dc\u05d9\u05da \u05dc\u05d9\u05d5\u05ea\u05e8 \u05e7\u05dc (\u05d4\u05e7\u05d5\u05d1\u05e5 prod-struct.sql.gz \u05de\u05db\u05d9\u05dc \u05d0\u05ea \u05de\u05d1\u05e0\u05d4 \u05d4\u05e1\u05db\u05d9\u05de\u05d4 \u05e9\u05d0\u05e0\u05d9 \u05e8\u05d5\u05e6\u05d4 \u05dc\u05e7\u05d1\u05dc) :<br \/>\n[code]<br \/>\n#! \/bin\/bash<br \/>\nsource db.conf<br \/>\nmysqldump &#8211;no-data -h $HOST -u $USER &#8211;password=$PASS $DB_NAME $TABLES > current.sql<br \/>\nzcat prod-struct.sql.gz > new.sql<br \/>\nsqlt-diff current.sql=MySQL new.sql=MySQL 2> \/dev\/null > diff.sql<br \/>\ncat diff.sql<br \/>\necho &quot;Type yes to apply changes&quot;<br \/>\nread RESP<br \/>\n[[ $RESP == &quot;yes&quot; ]] || { rm -f current.sql diff.sql new.sql;exit; }<br \/>\necho &quot;updating database structure&quot;<br \/>\ncat diff.sql | mysql -h $HOST  -u $USER &#8211;password=$PASS $DB_NAME<br \/>\nrm current.sql new.sql diff.sql<br \/>\n[\/code]<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u05d4\u05e1\u05d9\u05d8\u05d5\u05d0\u05e6\u05d9\u05d4 \u05d4\u05d1\u05d0\u05d4 \u05ea\u05d4\u05d9\u05d4 \u05de\u05d5\u05db\u05e8\u05ea \u05dc\u05db\u05de\u05d4 \u05de\u05e4\u05ea\u05d7\u05d9\u05dd: \u05d1\u05d7\u05d1\u05e8\u05d4 \u05e2\u05d5\u05d1\u05d3\u05d9\u05dd \u05e2\u05dc \u05ea\u05d5\u05db\u05e0\u05d4 \u05d1\u05e6\u05d3 \u05d4\u05e9\u05e8\u05ea \u05e9\u05db\u05d5\u05dc\u05dc\u05ea \u05d1\u05e1\u05d9\u05e1 \u05e0\u05ea\u05d5\u05e0\u05d9\u05dd. \u05db\u05de\u05d5\u05d1\u05df \u05e9\u05dc\u05d0 \u05de\u05e4\u05ea\u05d7\u05d9\u05dd \u05d9\u05e9\u05d9\u05e8\u05d5\u05ea \u05e2\u05dc \u05de\u05e2\u05e8\u05db\u05ea \u05d4\u05e4\u05e8\u05d5\u05d3\u05e7\u05e9\u05df, \u05d0\u05dc\u05d0 \u05e2\u05dc \u05de\u05e2\u05e8\u05db\u05ea \u05d3\u05d5\u05de\u05d4 &#8211; \u05d5\u05d0\u05d5\u05dc\u05d9 \u05d0\u05e4\u05d9\u05dc\u05d5 \u05db\u05dc \u05de\u05e4\u05ea\u05d7 \u05e2\u05d5\u05d1\u05d3 \u05e2\u05dc \u05d2\u05e8\u05e1\u05d0 \u05de\u05e7\u05d5\u05de\u05d9\u05ea \u05e9\u05dc \u05d1\u05e1\u05d9\u05e1 \u05d4\u05e0\u05ea\u05d5\u05e0\u05d9\u05dd. \u05d1\u05de\u05e9\u05da \u05d4\u05d6\u05de\u05df, \u05de\u05e4\u05ea\u05d7\u05d9\u05dd \u05de\u05e9\u05e0\u05d9\u05dd \u05d0\u05ea \u05d4\u05de\u05d1\u05e0\u05d4 \u05e9\u05dc \u05d1\u05e1\u05d9\u05e1 \u05d4\u05e0\u05ea\u05d5\u05e0\u05d9\u05dd, \u05de\u05d5\u05e1\u05d9\u05e4\u05d9\u05dd \u05d8\u05d1\u05dc\u05d5\u05ea,\u05e2\u05de\u05d5\u05d3\u05d5\u05ea \u05d5\u05d0\u05d9\u05e0\u05d3\u05e7\u05e1\u05d9\u05dd, \u05d5\u05d0\u05d5\u05dc\u05d9 \u05d2\u05dd \u05de\u05d5\u05d7\u05e7\u05d9\u05dd \u05db\u05de\u05d4. \u05d9\u05db\u05d5\u05dc &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/firefang.net\/blog\/1060\" class=\"more-link\">\u05dc\u05d4\u05de\u05e9\u05d9\u05da \u05dc\u05e7\u05e8\u05d5\u05d0<span class=\"screen-reader-text\"> sqlfairy<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3,17,7],"tags":[],"class_list":["post-1060","post","type-post","status-publish","format-standard","hentry","category-linux","category-open-soruce","category-programming"],"_links":{"self":[{"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/posts\/1060","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/comments?post=1060"}],"version-history":[{"count":3,"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/posts\/1060\/revisions"}],"predecessor-version":[{"id":1085,"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/posts\/1060\/revisions\/1085"}],"wp:attachment":[{"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/media?parent=1060"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/categories?post=1060"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/firefang.net\/blog\/wp-json\/wp\/v2\/tags?post=1060"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}