<?xml version='1.0' encoding='UTF-8'?><?xml-stylesheet href="http://www.blogger.com/styles/atom.css" type="text/css"?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:georss='http://www.georss.org/georss'><id>tag:blogger.com,1999:blog-21821055</id><updated>2009-12-07T21:46:16.086-08:00</updated><title type='text'>木匠 Creative and Flexible</title><subtitle type='html'>Think positive. hope for the best -- and expect the best, too!

Hope you're enjoying your stay here.</subtitle><link rel='http://schemas.google.com/g/2005#feed' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/posts/default'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/'/><link rel='hub' href='http://pubsubhubbub.appspot.com/'/><link rel='next' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default?start-index=26&amp;max-results=25'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email></author><generator version='7.00' uri='http://www.blogger.com'>Blogger</generator><openSearch:totalResults>127</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><entry><id>tag:blogger.com,1999:blog-21821055.post-2552540987775573812</id><published>2009-12-07T14:12:00.000-08:00</published><updated>2009-12-07T14:35:01.870-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>Acting Evolved 以进化的高等智能人类的思考来处理变化</title><content type='html'>"Act like you’ve evolved: breathe, don’t hiss." &lt;br /&gt;&lt;br /&gt;鄙人的理解就是: 对于一些(反感的,恶心的,烦人的)突发事件,不要急躁,紧张,暴跳,而是做深呼吸,冷清分析处理.不要像变色龙/蛇一样焦躁的嘶嘶作响(以尖利的嘘声驱赶或压倒、嘲弄等). 在热带丛林里面,迅速暴力做出反应,应对凶禽猛兽或许适当. 可是在一个软件开发项目里,如此对待同事,客户,或者服务供应商,就不合适了.&lt;br /&gt;&lt;br /&gt;思考需要时间.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;table style="width:auto;"&gt;&lt;tr&gt;&lt;td&gt;&lt;a href="http://picasaweb.google.ca/lh/photo/3uaJMPg3mYTDfhzzuX87TA?feat=embedwebsite"&gt;&lt;img src="http://lh5.ggpht.com/_Wv9Lui_cURQ/Su0Jo5q46VI/AAAAAAAAAMI/aAEuKhwAVnc/s400/100_0097.jpg" /&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td style="font-family:arial,sans-serif; font-size:11px; text-align:right"&gt;From &lt;a href="http://picasaweb.google.ca/charlie.zhu1/2009_Oct?feat=embedwebsite"&gt;2009_Oct&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-2552540987775573812?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/2552540987775573812/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=2552540987775573812' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/2552540987775573812'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/2552540987775573812'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/12/acting-evolved.html' title='Acting Evolved 以进化的高等智能人类的思考来处理变化'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://lh5.ggpht.com/_Wv9Lui_cURQ/Su0Jo5q46VI/AAAAAAAAAMI/aAEuKhwAVnc/s72-c/100_0097.jpg' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-6927086153426882821</id><published>2009-11-03T21:58:00.000-08:00</published><updated>2009-11-03T22:08:30.117-08:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='dog'/><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>我的脚痛 sole of foot</title><content type='html'>脚掌终于承受不了每天十公里的负荷.早上看了医生,指出鄙人脚结构的天生缺陷.需要扔掉$50的运动鞋,换了穿每双$150的辅助校正鞋子(Orthotics).还说计算机工程师钱够,显然也是对ＩＴ人士有偏见.回头看看公司的福利或者保险公司能不能报销这个处方.&lt;br /&gt;&lt;br /&gt;上传美景.&lt;br /&gt;&lt;br /&gt;&lt;table style="width:auto;"&gt;&lt;tr&gt;&lt;td&gt;&lt;a href="http://picasaweb.google.ca/lh/photo/ql3PRxNJl5N_rxWZd_9bsA?feat=embedwebsite"&gt;&lt;img src="http://lh6.ggpht.com/_Wv9Lui_cURQ/Su5ryq3dFGI/AAAAAAAAAOQ/rVynMHH9mA4/s400/100_0158.jpg" /&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td style="font-family:arial,sans-serif; font-size:11px; text-align:right"&gt;From &lt;a href="http://picasaweb.google.ca/lh/sredir?uname=charlie.zhu1&amp;target=ALBUM&amp;id=5398947243091722033&amp;feat=embedwebsite"&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;br /&gt;Port Renfrew 一家饭馆的外面.&lt;br /&gt;..&lt;br /&gt;&lt;table style="width:auto;"&gt;&lt;tr&gt;&lt;td&gt;&lt;a href="http://picasaweb.google.ca/lh/photo/F7sK4VXpnkiia2lHM1Zl4g?feat=embedwebsite"&gt;&lt;img src="http://lh4.ggpht.com/_Wv9Lui_cURQ/Su5rvGg98qI/AAAAAAAAAOE/CCJvlAywCgQ/s400/100_0180.jpg" /&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td style="font-family:arial,sans-serif; font-size:11px; text-align:right"&gt;From &lt;a href="http://picasaweb.google.ca/charlie.zhu1/2009_Oct?feat=embedwebsite"&gt;2009_Oct&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;br /&gt;Tide pool.&lt;br /&gt;..&lt;br /&gt;&lt;table style="width:auto;"&gt;&lt;tr&gt;&lt;td&gt;&lt;a href="http://picasaweb.google.ca/lh/photo/Bl5f94eIuH-ZapHZFHk7mA?feat=embedwebsite"&gt;&lt;img src="http://lh4.ggpht.com/_Wv9Lui_cURQ/Su5rstHX6nI/AAAAAAAAAN8/zMfKh91lUAQ/s400/100_0175.jpg" /&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td style="font-family:arial,sans-serif; font-size:11px; text-align:right"&gt;From &lt;a href="http://picasaweb.google.ca/charlie.zhu1/2009_Oct?feat=embedwebsite"&gt;2009_Oct&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;br /&gt;典型加拿大西海岸风光&lt;br /&gt;..&lt;br /&gt;&lt;table style="width:auto;"&gt;&lt;tr&gt;&lt;td&gt;&lt;a href="http://picasaweb.google.ca/lh/photo/RG-EAmN5Dt1RdVGkKMFaBw?feat=embedwebsite"&gt;&lt;img src="http://lh6.ggpht.com/_Wv9Lui_cURQ/Su5r0Js3VyI/AAAAAAAAAOU/vaJbES2Ku0s/s400/100_0166.jpg" /&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td style="font-family:arial,sans-serif; font-size:11px; text-align:right"&gt;From &lt;a href="http://picasaweb.google.ca/charlie.zhu1/2009_Oct?feat=embedwebsite"&gt;2009_Oct&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;br /&gt;欢德福卡海峡 出海口, 外面就是太平洋了.&lt;br /&gt;..&lt;br /&gt;&lt;table style="width:auto;"&gt;&lt;tr&gt;&lt;td&gt;&lt;a href="http://picasaweb.google.ca/lh/photo/xITInU3eLNAaWmVy0G2FAA?feat=embedwebsite"&gt;&lt;img src="http://lh6.ggpht.com/_Wv9Lui_cURQ/Su5rrIAvd9I/AAAAAAAAAN4/kBuuQ6hEjcA/s400/100_0203.jpg" /&gt;&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td style="font-family:arial,sans-serif; font-size:11px; text-align:right"&gt;From &lt;a href="http://picasaweb.google.ca/charlie.zhu1/2009_Oct?feat=embedwebsite"&gt;2009_Oct&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;br /&gt;使鄙人脚痛的朱丽叶.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-6927086153426882821?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/6927086153426882821/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=6927086153426882821' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6927086153426882821'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6927086153426882821'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/11/sole-of-foot.html' title='我的脚痛 sole of foot'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://lh6.ggpht.com/_Wv9Lui_cURQ/Su5ryq3dFGI/AAAAAAAAAOQ/rVynMHH9mA4/s72-c/100_0158.jpg' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-1097759462057240485</id><published>2009-09-30T21:54:00.000-07:00</published><updated>2009-09-30T22:37:56.404-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='work'/><category scheme='http://www.blogger.com/atom/ns#' term='Amazon'/><title type='text'>2009 Commit and Oracle-L后面的骨干Tim Gorman</title><content type='html'>在亚马逊"老巢"参加两天的DBA内部技术交流会.&lt;br /&gt;&lt;br /&gt;Keynote由Oracle-L后面的骨干Tim Gorman开讲.Tim的主题是如何协调后台的System Admin和前台的UI/Application developer.&lt;br /&gt;&lt;br /&gt;可能国内已经有同行知晓Tim的名气,早上一起在亚马逊登记,然后等候入场,基本是尴尬冷场.&lt;br /&gt;&lt;br /&gt;Tim引用了一个案例,是说数据仓库开发人员不清楚BitMap索引是如何工作的,一个fact表,五个位图索引,使用SQL MERGE加载数据,强制使用并行处理. Tim用分布事物来比喻并行处理,结果BitMap索引是锁上加锁,处理时间漫长无比.&lt;br /&gt;&lt;br /&gt;那么解决方案是什么呢? 鄙人马上脱口而出, exchange partition,&lt;br /&gt;Tim做了补充, union all源数据和目标数据,使用SQL Anylitic function Row_Number()排重(Dedup),然后INSERT进中间表,最终交换表分区.&lt;br /&gt;&lt;br /&gt;这个处理设计和我们正在重建的库存系统的数据加载策略基本吻合. 只是我们的需求更加复杂一些,需要保留同一分区(书商)里面没有匹配的数据,set qty=0.&lt;br /&gt;&lt;br /&gt;最后,更新问题跟踪系统,给developer留个台阶, 备注是这样的: "DBA的责任,已经解决."&lt;br /&gt;&lt;br /&gt;会后我们想谈甚欢,希望以后从他那里接一些分包合同.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-1097759462057240485?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/1097759462057240485/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=1097759462057240485' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1097759462057240485'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1097759462057240485'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/09/2009-commit-and-oracle-ltim-gorman.html' title='2009 Commit and Oracle-L后面的骨干Tim Gorman'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-6354066277135667356</id><published>2009-09-29T09:42:00.000-07:00</published><updated>2009-09-29T09:58:55.391-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='work'/><category scheme='http://www.blogger.com/atom/ns#' term='Oracle'/><title type='text'>基本数据库存取 Basic data access</title><content type='html'>学习了Tom巡回演讲中的一节, 使用索引:&lt;br /&gt;&lt;br /&gt;下面两种引用简单程序逻辑的比喻,非常贴切,这也是鄙人面试时,经常问到的一个题目.&lt;br /&gt;&lt;br /&gt;a) say out loud - full scans are not evil&lt;br /&gt;b) say out loud - indexes are not all goodness&lt;br /&gt;c) goto (a) until you actually believe what you are saying out loud.&lt;br /&gt;&lt;br /&gt;参考: &lt;a href="http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:743251200346166176"&gt;http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:743251200346166176&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-size:130%;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;span style="font-weight: bold;font-family:Arial;font-size:130%;color:black;"   &gt;Mythology – why isn’t it using my index&lt;/span&gt;&lt;br /&gt;  &lt;div class="O1" style="margin-top: 5.76pt; margin-bottom: 0pt; margin-left: 1.06in; text-indent: -0.38in; text-align: left; direction: ltr; unicode-bidi: embed; vertical-align: baseline;"&gt;&lt;span style="font-size:130%;"&gt;&lt;span style=";color:black;" &gt;–&lt;/span&gt;&lt;/span&gt;&lt;span style=";font-family:Arial;font-size:130%;color:black;"   &gt;Loop&lt;/span&gt;&lt;/div&gt;  &lt;div class="O2" style="margin-top: 5.76pt; margin-bottom: 0pt; margin-left: 1.5in; text-indent: -0.25in; text-align: left; direction: ltr; unicode-bidi: embed; vertical-align: baseline;"&gt;&lt;span style="font-size:130%;"&gt;&lt;span style=";font-family:Arial;color:black;"  &gt;•&lt;/span&gt;&lt;/span&gt;&lt;span style=";font-family:Arial;font-size:130%;color:black;"   &gt;Say indexes are not all goodness&lt;/span&gt;&lt;/div&gt;  &lt;div class="O2" style="margin-top: 5.76pt; margin-bottom: 0pt; margin-left: 1.5in; text-indent: -0.25in; text-align: left; direction: ltr; unicode-bidi: embed; vertical-align: baseline;"&gt;&lt;span style="font-size:130%;"&gt;&lt;span style=";font-family:Arial;color:black;"  &gt;•&lt;/span&gt;&lt;/span&gt;&lt;span style=";font-family:Arial;font-size:130%;color:black;"   &gt;Say full scans are not evil&lt;/span&gt;&lt;/div&gt;  &lt;div class="O2" style="margin-top: 5.76pt; margin-bottom: 0pt; margin-left: 1.5in; text-indent: -0.25in; text-align: left; direction: ltr; unicode-bidi: embed; vertical-align: baseline;"&gt;&lt;span style="font-size:130%;"&gt;&lt;span style=";font-family:Arial;color:black;"  &gt;•&lt;/span&gt;&lt;/span&gt;&lt;span style=";font-family:Arial;font-size:130%;color:black;"   &gt;Exit when (you really believe it)&lt;/span&gt;&lt;/div&gt;  &lt;div class="O1" style="margin-top: 5.76pt; margin-bottom: 0pt; margin-left: 1.06in; text-indent: -0.38in; text-align: left; direction: ltr; unicode-bidi: embed; vertical-align: baseline;"&gt;&lt;span style="font-size:130%;"&gt;&lt;span style=";color:black;" &gt;–&lt;/span&gt;&lt;/span&gt;&lt;span style=";font-family:Arial;font-size:130%;color:black;"   &gt;End loop&lt;/span&gt;&lt;/div&gt;&lt;br /&gt;参考: Indexing.ppt , 下载: &lt;a href="http://asktom.oracle.com/pls/asktom/f?p=100:8:1413269270550111::NO"&gt;http://asktom.oracle.com/pls/asktom/f?p=100:8:1413269270550111::NO&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-6354066277135667356?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/6354066277135667356/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=6354066277135667356' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6354066277135667356'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6354066277135667356'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/09/basic-data-access.html' title='基本数据库存取 Basic data access'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-1635216937686908737</id><published>2009-09-24T10:08:00.000-07:00</published><updated>2009-09-24T10:26:34.735-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>为什么不能买日货 why beat rb</title><content type='html'>&lt;div&gt;两国相争, 最后拼得是经济.&lt;br /&gt;&lt;br /&gt;鄙人语文差, 下面这篇文章, 正好代表了我的大部分想法, 转贴过来.&lt;br /&gt;原文: &lt;a href="http://www.360doc.com/content/070907/13/36627_725823.html"&gt;http://www.360doc.com/content/070907/13/36627_725823.html&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;/div&gt; &lt;div&gt;春秋战国时期，中国产生了许多思想家，其数量之多，是古希腊、古罗马、&lt;br /&gt;欧洲文艺复兴时期的总和所望尘莫及，他们的思想光辉，至今还在历史的长河中闪耀。&lt;br /&gt;&lt;br /&gt;诸子百家中，有一子叫“韩非子”，有一家叫“法家”，这个法家思想的集大成者，&lt;br /&gt;说话结巴子的韩非子，说了三句话却是力贯古今：&lt;br /&gt;“上古竞于德，中古逐于智，当今争于力”。“当今争于力”成了相对真理，&lt;br /&gt;被证明了二千二百多年。现今的国家关系，仍旧是争于力，只要国力超强，爱打谁就打谁，&lt;br /&gt;现实世界， 并无公理可言。国家关系，只认实力，有几个人跟你讲道理，讲交情。&lt;br /&gt;&lt;br /&gt;纪念二战胜利刚过，就以二战为例，二战的胜利，也是争于力，&lt;br /&gt;拼的是经济，拼的是国力。&lt;br /&gt;&lt;br /&gt;美军在欧洲战场上，无战争艺术可讲，只是“饱和轰炸，一线平推”而已。&lt;br /&gt;一次德军奇袭了美军的一个机场，把三百多架飞机消灭在地面上，&lt;br /&gt;不出三天，德国人发现，机场上又出现了四百多架崭新的飞机，&lt;br /&gt;所有的德国将军都明白，这个仗不用打了。&lt;br /&gt;即便再多出几个像隆美尔、古德里安、曼斯坦因这样最杰出的将领也无济于事。&lt;br /&gt;&lt;br /&gt;美军在太平洋战场也是一样，以硫磺岛战役为例，美军对日军&lt;br /&gt;的比例是：空军35：1、海军26：1、陆军5：1，登陆作战前，&lt;br /&gt;照例对硫磺岛进行了两个多月的饱和轰炸，硫磺岛被犁了多少遍，&lt;br /&gt;美国人恐怕连自己都搞不清。此种打法，美国人如何能不胜。&lt;br /&gt;&lt;br /&gt;就单兵的素质而言，德、日的士兵高于美、英、前苏联、中国。&lt;br /&gt;&lt;br /&gt;就将领的水平而言，德、日的统帅不逊于同盟国。&lt;br /&gt;&lt;br /&gt;德国的古德里安，在波兰、俄罗斯、包括日本还在崇尚骑兵、&lt;br /&gt;特别是波兰，真诚地崇尚骑兵的时候，就提出了装甲集群、&lt;br /&gt;大纵深突击的战争理论，在这个理论的推演下，德国的闪电战、&lt;br /&gt;德国的坦克部队横扫了欧洲。&lt;br /&gt;&lt;br /&gt;日本的山本五十六，首先提出了海军航空兵的理论。珍珠港一战，&lt;br /&gt;把美国海军赶回了西太平洋，他的海军制空权的理论，已经管用了六十多年。&lt;br /&gt;现今的远洋海军，是由航母、巡洋舰、驱逐舰、&lt;br /&gt;潜艇等构成的航母战斗群，这是美国海军的典型配置。&lt;br /&gt;&lt;br /&gt;但是，士兵的骁勇和将领的优秀，并不能挽救轴心国失败的命运，&lt;br /&gt;因为，到最后，拼的是经济，拼的是国力，是争于力。&lt;br /&gt;二战后期，美英年产十万架飞机，主要是美国生产的。美国一家，&lt;br /&gt;其生产能力，已超出德、意、日生产能力的总和。&lt;br /&gt;&lt;br /&gt;这是二战史上的争于力，当今世界的现实状况是，那个近邻&lt;br /&gt;日本，世界第二大经济强国日本，2002年，人均gdp就高达36000&lt;br /&gt;美元。这还不算日本的海外资产，2002年，日本的海外纯资产已&lt;br /&gt;高达16277亿美元，相当于德国、法国、意大利对外纯债权额总和的六倍。&lt;br /&gt;&lt;br /&gt;可怕的是，日本的政府、媒体、学者共同编造了一个弥天大谎，&lt;br /&gt;明明日本经济在强劲发展，却说成日本的经济衰退了十年，&lt;br /&gt;运用谎言重复一百遍就是真理的办法，把满世界的人骗得信以为真、&lt;br /&gt;晕头转向。中国是“韬晦之计”的故乡，其韬晦之计却被日本人用得炉火纯青。&lt;br /&gt;&lt;br /&gt;可怕的是，日本人在制造一个弥天大谎的同时，尽量夸大中国&lt;br /&gt;经济的发展，大造“中国威胁论”的舆论，让欧美一起来围堵中国，&lt;br /&gt;这一点上，日本人的阴谋也得逞了。日本是“中国威胁论” 的策源地和故乡。&lt;br /&gt;&lt;br /&gt;日本人这两招，目的一个，让世界各国把矛头对准中国，&lt;br /&gt;把中国人置于四面受兵的境地，欧美各国，一再打压人民币升值，&lt;br /&gt;在长时间的高压之下，中国政府不得不于今年升值人民币。&lt;br /&gt;而国内，人民币却大幅贬值，仅举一个参照物，去年&lt;br /&gt;一元钱人民币买半公斤大米，今年要一元六毛五分钱才能买到五百克。&lt;br /&gt;按照经济学理论，每年通货膨胀在百分之二，是正常的，&lt;br /&gt;对经济发展有利。到百分之四，就证明有了问题，&lt;br /&gt;对经济发展不利。到了百分之六，就非常的糟糕......&lt;br /&gt;日本人笑了，而中国的老百姓却是里外受损、两头吃亏。&lt;br /&gt;&lt;br /&gt;日本学者，还在继续造谣，说下一个十年，日本经济还将继续衰退，&lt;br /&gt;日本上下，心领神会，连说谎造谣都众口一词。&lt;br /&gt;&lt;br /&gt;日本人万众一心欺压别国，韩国人同仇敌忾对抗别国欺诈。&lt;br /&gt;&lt;br /&gt;世界上许多民族，都有优点和长处，包括日本民族也不例外，&lt;br /&gt;都有值得我们学习的地方，不重视这一点，只知仇恨，就是愚昧，&lt;br /&gt;那只是1900年义和团的水平，“师夷以制夷”，学习外国人是&lt;br /&gt;为了图强，是为了“人不敢侮”。为什么中国人不能学习异民族所长，&lt;br /&gt;也来个万众一心、同仇敌忾？？？&lt;br /&gt;&lt;br /&gt;中国威胁谁了？笔者不是学历史的，可是笔者清楚得很，自一八四零年鸦片战争以来，&lt;br /&gt;别人少欺负一点中国人就很不错了，六十多年前那一场战争，&lt;br /&gt;中国弄到差一点亡国灭种的地步。直到现在为止，中国人还处于五、四运动时期“外抗强权，&lt;br /&gt;内惩国贼” 的阶段，正在“抵御外侮”，还没有做到“人不敢侮”。别人&lt;br /&gt;一不高兴，精确制导的炸弹把你的大使馆炸个底朝天，然后说一声误会就完事了。&lt;br /&gt;就好比在市中心广场，一个人甩了你几个大嘴巴，朝你脸上啐了几下口水，踹了你几脚，&lt;br /&gt;然后再说一声对不起、 误会，就完事了。&lt;br /&gt;尽管全市的人都知道，你也只能擦擦吐到脸上的口水，把打掉的牙齿往肚里咽，&lt;br /&gt;捂着腮帮子回家，你还能怎么着，除非你准备拼死一战。一百五十五年了，&lt;br /&gt;笔者只知道中国人受尽屈辱，不过是忙着抵御外侮，威胁别人的事，&lt;br /&gt;影子气都没有、门都没有。日本人居然能大造“中国威胁论”的谣言，&lt;br /&gt;真亏日本人想得出来，日本人做事也过于极端了，对中国人也过于阴狠、过于毒辣了。&lt;br /&gt;&lt;br /&gt;从中日关系来看，自建国以来，中日关系现处于最紧张的&lt;br /&gt;时期，就在17日中国的神六顺利返回，举国欢庆的时候，&lt;br /&gt;就选在这一天，小泉再次参拜靖国神社，这是今年第二次参拜，&lt;br /&gt;这是特意向中国人挑衅，或者说警告，你中国人不要高兴，&lt;br /&gt;我日本横下心来要和你中国为敌到底。&lt;br /&gt;&lt;br /&gt;中国有九亿农民，其中至少有五亿生活在联合国划定的贫困线以下，&lt;br /&gt;我们的人均产值还很低，中国人节衣缩食，弄几个载人飞船上天，自己花自己的血汗钱，&lt;br /&gt;自己给自己开一下心，自己给自己提提精神，有什么不可以？&lt;br /&gt;就好比一户贫苦家庭，过春节的时候，买几个炮仗放放，有什么不可以？&lt;br /&gt;你日本人有的是钱，可以天天买炮仗放。你日本人为什么要如此的仇恨？&lt;br /&gt;你日本人的心理为什么要如此的阴暗潮湿？？&lt;br /&gt;&lt;br /&gt;五四运动时期，国人抵制日货，前段时期，一些城市抵制日货，&lt;br /&gt;早在十几年之前，著名作家张贤亮提出抵制日货。日货非抵制不可，&lt;br /&gt;日本人欺人太甚。购买一件日货，就是增加一分日本人的国力。&lt;br /&gt;如果中国人像韩国人一样，万众一心不买日货，&lt;br /&gt;日本人就不会象现在这样嚣张，中国也就多一点国家安全。&lt;br /&gt;&lt;br /&gt;我们写文章时，一般会引用名人名言，以增加说服力。&lt;br /&gt;今天笔者还要引用一个普通姑娘淼逸冰的话：“让中国人抵制日货成为习惯”。&lt;br /&gt;韩国人抵制日货已经成为习惯，为什么中国人抵制日货不能成为习惯？？？&lt;br /&gt;&lt;br /&gt;作为一个清醒的领导人朱鎔基，在当上海市委书记的时候，&lt;br /&gt;其时日本轿车在中国大行其道，其他省、市政府大买日本车，&lt;br /&gt;朱鎔基就明确规定，上海市直机关一律不得购买外国轿车。&lt;br /&gt;&lt;br /&gt;在当了总理以后，一次大会上呼吁代表，买一点国货带回去。&lt;br /&gt;&lt;br /&gt;为什么不能买日货？因为：“中国在加入wto以后，要遵守共同的游戏规则，&lt;br /&gt;政府无法再用关税壁垒的办法，阻挡外国商品的入侵。”&lt;br /&gt;这个时候，就更需要全体中国人一致的自觉行动， 像韩国人一样一致的自觉行动。&lt;br /&gt;&lt;br /&gt;为什么不能买日货？因为：“日本人将有毒、有害、过时的商品、残次的商品卖往中国。”&lt;br /&gt;据政府的《国际金融报》十月十四日第一版载，日本人将有毒致癌的食品保鲜膜倾销中国市场，&lt;br /&gt;已占中国市场的百分之八十。此种保鲜膜，日本国内早已禁止使用，&lt;br /&gt;国际上早已禁止生产。难道国内连冰箱里用的保鲜膜都不能生产了？&lt;br /&gt;难道国人连国产的保鲜膜都不能相信了？这样的例子，无法一一列举。&lt;br /&gt;日人可恨、可气，国人可悲、可叹。&lt;br /&gt;&lt;br /&gt;为什么不能买日货？因为：“日本人有他的心理特点。”&lt;br /&gt;他在中国赚的钱越多，就越是嘲笑你中国人，鄙视你中国人，仇恨你中国人。&lt;br /&gt;中国的原当权者不遵从国际惯例，不考虑中国人的生命财产损失和老百姓的生活，&lt;br /&gt;不取得中国人民的同意，大喊不要日本人的战争赔款，那可是一笔天文数字的战争赔款。&lt;br /&gt;结果怎么样，非但日本人没有一俩感激的意思，而是相反，中日关系越来越紧张，&lt;br /&gt;五十年来日本人哪一天忘记了欺侮中国，&lt;br /&gt;小泉哪一天不是一天二十六个小时在盘算着如何和中国人过不去，就是典型例证。&lt;br /&gt;&lt;br /&gt;为什么不能买日货 ？因为：“安不忘危”。和平时期万众一心抵制日货，&lt;br /&gt;形成国人的坚定信念和爱国氛围，战争时期才能少有汉奸。&lt;br /&gt;为了减轻将来中国人可能蒙受的苦难，必须现在就着手铲除滋生汉奸的土壤。&lt;br /&gt;再说了，中国还没有那么“安”，反而给人的感觉是虎狼环视。&lt;br /&gt;为什么中国内奸的数量世界第一？&lt;br /&gt;不能不深思，不把这一层说破，有害无益。不把这一层说破，就是讳疾忌医。&lt;br /&gt;“知耻近乎勇”，国人焉能不知耻？二战期间，前苏联就没有那么多的俄奸，&lt;br /&gt;俄国也有投降的个别将军，就无法组织起俄国的“和平军”，这是为什么？&lt;br /&gt;这一点，也值得国人深思。&lt;br /&gt;&lt;br /&gt;为什么不能买日货？&lt;br /&gt;因为：“平头百姓、有识之士，反击日人攻势，奔走呼号，&lt;br /&gt;抵制日货，雪心头之耻、胸中之恨，别无它途。&lt;br /&gt;&lt;br /&gt;为什么不能买日货？因为：“日本人对中国政府每一次成功&lt;br /&gt;的破坏，所造成的经济损失，归根到底是由基层的群众来承担。”&lt;br /&gt;那些贪官污吏，动辄收贿贪污几百万、几千万，他们的奢靡生活，&lt;br /&gt;不论何时都不会受到影响，而明显受到影响的，只会是最广大的平民阶层。&lt;br /&gt;贪官污吏不会知道，也根本不需要知道,一年之内大米会&lt;br /&gt;以每市斤百分之六十五的通货膨胀率增长。&lt;br /&gt;所以，首先要求抵制日货的，不可能是官吏阶层，只能是平民阶层、也只会是平民 阶层。&lt;br /&gt;而且，由于教育、文化等等方面的原因，也只是平民阶层中的一部分清醒者&lt;br /&gt;和属于他们的知识分子。这不是平民阶层一个阶层的悲哀，而是一个民族的悲哀。&lt;br /&gt;&lt;br /&gt;为什么不能买日货？因为：“当今争于力”。那个会打仗的&lt;br /&gt;秃子林彪，倾向于中日还有一战，万一有了战事，&lt;br /&gt;你今天手底下买进一件日本商品，为日本人增加一分国力，&lt;br /&gt;你明天头顶上就多出一枚日本炸弹，而炸弹带来的，只能是尸体和废墟。&lt;br /&gt;没准，落在你头顶上的那枚日本品牌的炸弹，确好是用你购买日本品牌的商品，&lt;br /&gt;进而产生的利润生产的。&lt;br /&gt;&lt;br /&gt;为什么不能买日货? 因为：“日货、日货， 日本之祸。”&lt;br /&gt;&lt;br /&gt;为什么不能买日货？因为：“我们的身后, 三千五百万冤魂在哭诉。”&lt;br /&gt;&lt;br /&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-1635216937686908737?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/1635216937686908737/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=1635216937686908737' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1635216937686908737'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1635216937686908737'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/09/why-beat-rb.html' title='为什么不能买日货 why beat rb'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-8191377480351579277</id><published>2009-09-22T17:34:00.000-07:00</published><updated>2009-09-22T22:07:42.982-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='agile'/><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>Agile 敏捷软件开发学习心得</title><content type='html'>上周六在维多利亚IT Club聆听了GuoLei两个小时关于&lt;a href="http://groups.google.ca/group/victoria_it/t/8d6516373236ad76?hl=en"&gt;Agile Software Development&lt;/a&gt; 的精彩演讲.&lt;br /&gt;这是维多利亚IT Club挂牌以来不多见的高品质技术交流.&lt;br /&gt;GuoLei关于Agile Software Design的演讲很成功,内容丰富,观众积极发言,反响热烈. 鄙人也有不小的收获.&lt;br /&gt;没来的同行一定会后悔的, 读完此文,您一定更后悔, 鄙人就不会后悔.&lt;br /&gt;&lt;br /&gt;这里谈一些鄙人的心得体会.&lt;br /&gt;&lt;br /&gt;. 设计和制造(manufacture)&lt;br /&gt;GuoLei举了一个宝马制造汽车的例子, 造一辆新汽车, 制造过程占了整个流程的很大比重, 超过50%.&lt;br /&gt;而软件开发99.9%的时间是在设计, 包括传统的需求分析,设计,编码,测试, 而制造(build)过程在一瞬间就完成了.&lt;br /&gt;所以鄙人鄙视那些号称软件工人的家伙. 作为软件开发人员,要把自己当作设计师来看待,才能生产出优秀的软件.&lt;br /&gt;也就是High Available and Scalable application system.&lt;br /&gt;&lt;br /&gt;. Communication over documentation&lt;br /&gt;代码一定要清晰可读, 多行代码也没有关系, 忌讳使用一个高深的表达式,上午写的,到了下午,自己都看不懂了,窘迫.&lt;br /&gt;写在代码中间的备注是没有多少人看的,而且很可能已经过期了,说的完全不是代码要做的事.&lt;br /&gt;尽可能面对面交流, Email/电话 均不提倡. 80%的沟通是通过表情和肢体语言来完成的.比如,当你解释完一个处理模型以后,观众回答听懂了,可是难以掩盖他们木然的表情,依然处在疑惑当中,而打电话时,你是看不到对方表情的.&lt;br /&gt;&lt;br /&gt;. 积累和完善测试案例, TDD(Test Driven Design)&lt;br /&gt;一开始,不需要覆盖100%的测试案例; 而是使用测试案例帮助设计原型,逐步完善我们的设计方案.&lt;br /&gt;开发一个新功能,就累积一个新的测试案例,&lt;br /&gt;发现一个新的bug,就累积一个新的测试案例,逐渐完善测试案例库的涵盖程度.&lt;br /&gt;&lt;br /&gt;. 左脑和右脑&lt;br /&gt;左脑负责常规约束活动,&lt;br /&gt;右脑具有创造力,&lt;br /&gt;也就是为什么工作累了以后,会卡在一个貌似棘手的问题,苦苦找不到解决方案,然后走开喝杯水,上个厕所,散散步,抽根烟,立马就有了解决问题的眉目,好点子不断. 因此,每隔一小时,出去散散步,使用一下右脑,发挥创造力. 即对健康有利,又能提高工作效率,我们出去散步吧.&lt;br /&gt;&lt;br /&gt;. 人是关键&lt;br /&gt;再好的软件开发流程没有人的积极参与是不行的,而且软件行业人与人之间的差别太大,好的杰出的程序员的开发效率常常高出普通程序员的十倍以上. 点背不能怪社会,只能怪自己天赋不够, 嘻嘻.&lt;br /&gt;&lt;br /&gt;参考: &lt;a href="http://www.blogger.com/%E5%A6%82%E4%BD%95%E7%A9%BF%E8%B6%8A%E5%9B%A2%E9%98%9F%E5%8D%8F%E4%BD%9C%E7%9A%84%E4%BA%94%E9%87%8D%E9%9A%9C%E7%A2%8D"&gt;如何穿越团队协作的五重障碍&lt;/a&gt;&lt;br /&gt;http://hi.baidu.com/sunguangran/blog/item/2ab0e5cce64d121900e9286f.html&lt;br /&gt;信任缺失&lt;br /&gt;“第一重机能障碍是团队成员间的信任缺失。这实质上源于他们不愿在团体中轻易受到攻击的心态。团队成员如果不对其失误和弱点真正地开诚布公，就不可能打下信任的基础。”&lt;br /&gt;惧怕冲突&lt;br /&gt;承诺不足&lt;br /&gt;逃避担责&lt;br /&gt;漠视结果&lt;br /&gt;&lt;br /&gt;未完待续...&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-8191377480351579277?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/8191377480351579277/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=8191377480351579277' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/8191377480351579277'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/8191377480351579277'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/09/agile.html' title='Agile 敏捷软件开发学习心得'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-2784429144369930374</id><published>2009-09-18T12:39:00.000-07:00</published><updated>2009-09-18T12:46:56.577-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>918国耻日警钟与反省</title><content type='html'>在&lt;a href="http://www.cnoug.net"&gt;cnoug.net&lt;/a&gt; 和 &lt;a href="http://www.askdba.net"&gt;askdba.net&lt;/a&gt; 竟然看不到一篇纪念国耻日的贴, 那么鄙人就转摘一篇吧.&lt;br /&gt;&lt;br /&gt;送给那些继续支持日本经济建设的同胞, 醒醒吧.&lt;br /&gt;&lt;br /&gt;引自: &lt;a href="http://www.victoriabbs.com/bbs/viewthread.php?tid=19255&amp;pid=99346&amp;page=1&amp;extra=page%3D1#pid99346"&gt;http://www.victoriabbs.com/bbs/viewthread.php?tid=19255&amp;pid=99346&amp;page=1&amp;extra=page%3D1#pid99346&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;回顾中日历史，与其说是一衣带水，倒不如说是一衣带血倒更为贴切。自龙翔三年（公元663年唐高宗时代），日本占领朝鲜锦江口始，中日间就拉开了兵戈相见的序幕（至于那个携大量珍贵文物东渡的汉奸和尚鉴真，不明白历史书上为什么还要对他大加褒扬），明太祖洪武年，肆虐达七十八年之久。万历年,丰臣秀吉出兵二十一万，攻占朝鲜，明大将李如松出兵援朝，在付出较大牺牲后一举击败日本。然而。从那时起，日本的战略家们就已经开始处心积虑地研究和制订灭亡中国的计划。到了近代，甲午战争的惨败彻底暴露了老大帝国的颓弱本质，倭寇的帝国梦，就是那时开始于中华民族的血泊与白骨之中的。&lt;br /&gt;&lt;br /&gt;　　56年前的8月6日和8月9日，曾经不可一世的日本在屡受挫败后，遭到的真正的天谴。上帝说：伸冤在我，我必报应。果然，那动人心魄的一瞬间的闪光与冲天而起的蘑菇云，让日本人第一次感到了死亡的恐惧。但今天，当废墟再一次成为繁华的大都市的时候，我们看到的是：今天的日本人，爪牙更锋利，气焰更嚣张，而记忆却更差了。在一部叫《漂流街》的电影里，一个爱打乒乓球的中国黑帮老大，曾对日本人说过这样一段话：从前，一个岛上生活着一群猿猴，后来有中国人去教他们写字，猿猴们学会了，但却不懂得字的含义，不懂得什么叫诚实，什么叫善良，什么叫认罪......（大意）&lt;br /&gt;&lt;br /&gt;　　日本一直流行这这样一种调子，中国并没有战胜日本。的确，面对"8.15"，中国的确不是那么理直气壮。有一篇介绍苏军攻打柏林的文章写到，"巨大的仇恨使苏军进攻柏林时没有溶入丝毫的怜悯，他们动用了所有可以拉到柏林的重武器，而根本不考虑平民的伤亡"。苏军也曾经拒绝一支杀害过卓娅的德军投降，而坚持把他们全部消灭。壮哉！这才是真正的大国之魂！而我们呢，做为战胜国却从未有过一兵一卒踏上过日本的领土，与量浴血奋战的国民党高级将领们，却作为内战的牺牲品与昔日的敌人同处牢狱。据我所知，全国各地的纪念内战的纪念馆要远比抗日的纪念馆数量多，规模也大得多。政府对日本宽厚，一来只是目光短浅的只考虑短期的国际形式，二来无非因为日本自78年以来给中国的两兆多日元的贷款（不用还的吗？）。可有谁想过，与这些低三下四争来的贷款相比，马关条约赔出去的二万万两白银价值几许？仅仅8年抗战中中国600多亿美元的财产损失价值几许？永难重生的文物古迹，自然资源价值几许？而千年来无数在对日战争中牺牲的中国军民的冤魂，一个拥有12亿人口的东方大国的民族尊严又价值几许？！&lt;br /&gt;&lt;br /&gt;　　总是有人对日本报有幻想，"军国主义是一小部分，广大日本人民对中国是友好的"的声音不时响起，奴才的腔调，自上而发。看过日本兵出征前在街上请路人给他们的吉祥物上缝一针以祈求平安吉祥的资料片吗？看过那些身穿和服的年轻女子，在疯狂地叫喊着反华的口号的资料片吗？看看吧，你可以知道"广大日本人民"的真实嘴脸。中国的一艘考察船去钓岛附近探了一下．随之而来的是日本外交部的警告:未经日本政府允许不得进入日本领海。日本青年纷纷要求与中国一战。日本人对中国的敌意，是全民族的，是发自骨子里的。今天小泉的种种行径，每个中国人都看在眼里，不需冗言。小泉，不仅仅代表他自己，他是两亿日本人一票一票选出来的！日本人聪明、勇敢、坚忍、团结，但他们更变态、畸形、极端、怪异（这些贬义词并非凭空捏造，如果你领略过那些深受日本人喜爱的病态的艺术，你就会感受到，日本人性最深处的丑陋与邪恶），这样一群有着人的思维的高级禽兽，要远比头脑简单，只是知道嗜血的豺狼可怕的多。&lt;br /&gt;&lt;br /&gt;　　中华民族，不是狭隘的种族，在她的怀抱中，56个民族能够亲密无间，和睦相处；中国人，更不是狭隘的民族主义者，我们在全世界有这数不清的不同语言，不同肤色的朋友。但唯一的例外，就是太平洋上的四个小岛，那里生活着地球上最凶残与可怕的动物，中华民族永远的心腹之患。中日世仇，不共戴天！每一个中国人永远都不应该忘记日本曾经对我们做过什么！对于一个应该在地球上消失的种群，对于一个人人可以诛之的国家，对于一个极端变态的民族，我们永远也不要再对他们抱有丝毫幻想。抗战期间的一首小诗，叫做《假如我们不去打仗》：假如我们不去打仗/那么敌人杀死了我们/还要用刺刀指着我们的骨头说/看哪，这是奴隶！&lt;br /&gt;&lt;br /&gt;　　中日之间，没有任何友谊可言，有的只有连绵千年的仇恨！先辈的英灵，每天都在半空中凝视我们这些至今依然无所作为的不肖的子孙，他们焦虑，他们失望......但我们忍耐终将会有尽头，厉兵秣马，做好准备吧，犯强汉者，虽远必诛！浑浊的小泉，永远也别想再一次兴风作浪！"巨浪"和"东风"就是我们的怒吼，我们期待着，铭刻着中国制造的蘑菇云再次生起，在东京，在京都，在大版，在每一个孳生着量艿巢穴。中华民族的千年梦魇，永远沉入太平洋底，累劫不复超生！也许很快，也许还要等很久，但血债必用血来还!大直若屈，大巧若拙，大辩若讷。&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;&lt;br /&gt;"巨大的仇恨使苏军进攻柏林时没有溶入丝毫的怜悯，他们动用了所有可以拉到柏林的重武器，而根本不考虑平民的伤亡"。苏军也曾经拒绝一支杀害过卓娅的德军投降，而坚持把他们全部消灭。壮哉！这才是真正的大国之魂！&lt;/span&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-2784429144369930374?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/2784429144369930374/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=2784429144369930374' title='2 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/2784429144369930374'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/2784429144369930374'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/09/918.html' title='918国耻日警钟与反省'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>2</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-1483038973255509818</id><published>2009-09-17T09:11:00.000-07:00</published><updated>2009-09-17T09:15:33.471-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>维多利亚IT club topic: Agile software development</title><content type='html'>本周主题: 敏捷软件开发 (Agile software development).&lt;br /&gt;&lt;br /&gt;时间: Sept 19th 2:30pm, that is 3rd Saturday 2:30pm every month&lt;br /&gt;&lt;br /&gt;地点: EBC church second floor meeting room.&lt;br /&gt;Address: 2121 Cedar Hill Cross Rd. &lt;br /&gt;&lt;br /&gt;主讲人: GuoLei(Lawrence), 此人来自油都 卡尔加里. Java 开发经验丰富, 搬到维多利亚后,一周内找到了合适的新工作. 然而最牛的是已经走了两次West Coast Trail, 鄙人深表敬仰, 希望五年内有机会走一趟.&lt;br /&gt;&lt;br /&gt;会后,有 GengLi 组织的高尔夫球活动,有兴趣的带上球杆.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;另外, 九一八国耻日到了, 作为国民,自己敲个警钟,反省一下.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;多谢,&lt;br /&gt;木匠&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-1483038973255509818?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/1483038973255509818/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=1483038973255509818' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1483038973255509818'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1483038973255509818'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/09/it-club-topic-agile-software.html' title='维多利亚IT club topic: Agile software development'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-8806194185385449633</id><published>2009-08-18T15:22:00.000-07:00</published><updated>2009-08-18T15:26:44.626-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>生活琐事3则 trifles</title><content type='html'>上周末去Parksville的一个私 人capming site露营了,有水有电,设施齐全,就是太过于拥挤,无隐私可言;鄙人还是喜欢在国家公园/省立公园的密林从中露营. 带着朱丽叶狂奔了两个瀑布,周六Little qualicum fall,周日是English man fall.&lt;br /&gt;&lt;br /&gt;刚才跟一伙LAMP(Linux,Apache,MySQL,PHP/Perl/Python)人员开了个会,这伙人个个打扮的像艺术家,感觉他们并非都是Geek, 大多技术粗糙,开发的软件也是稀里糊涂,东拼西凑.&lt;br /&gt;&lt;br /&gt;--&lt;br /&gt;最近有一个骗局在维多利亚出现了, 号称Advance air supply company, 打着调查空气质量的幌子, 然后送你一个抽奖的卡片,随后两三天,就打电话说你中奖了,然后就要去你家送奖品,比如三天旅馆住宿,后面的骗局还不知道怎么发展,大家留意了,有危险, 就赶紧911报警.&lt;br /&gt;&lt;br /&gt;趁早给大伙提个醒, 谨防受骗!  鄙人因为爱占小便宜,差点上当.&lt;br /&gt;&lt;br /&gt;http://www.chinasmile.net/forums/showthread.php?t=420621&lt;br /&gt;&lt;br /&gt;...&lt;br /&gt;&lt;br /&gt;Calgary这里有一家类似的Breathe E-Z Home...送奖品的后招 - 据说是，和奖品一起带一台超级吸尘器（有改善空气质量之特殊功效）到你家，如果你开门给他们进来了，就别指望他们把吸尘器带走．他们会极力吹嘘该吸尘器之奇效（据用过的人说确实不错），该吸尘器售价大概是&lt;br /&gt;＄600，会给你免费试用多久，然后骗你签一份免费试用的合约．拿到你的签名后，他们会单方面把合同的一些条款改掉．不久后，你就等着收他们的上千元的欠单了.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-8806194185385449633?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/8806194185385449633/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=8806194185385449633' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/8806194185385449633'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/8806194185385449633'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/08/3-trifles.html' title='生活琐事3则 trifles'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-1266874567306907745</id><published>2009-07-07T16:30:00.000-07:00</published><updated>2009-07-07T16:45:53.616-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='PL/SQL'/><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>奇怪的Strange PL/SQL complier bug编译臭虫</title><content type='html'>今天终于完成了数据上载的智能修改, 就是说只修改数据有变化的列.&lt;br /&gt;&lt;br /&gt;比如我们的库存表, 有50个列, 52% 的UPDATE仅修改"价格/price"一列.&lt;br /&gt;&lt;br /&gt;可是遇到了一个极其古怪的臭虫, 如下所示, 一个简单的Loop循环, 漏掉了End Loop后面的分号";", 程序居然通过了编译,而且运行时也没有报错, 就是 End Loop 后面的语句被当成注释一样给跳过了. 这样的错误太难debug了, 幸好我充分的运用了code  instrument技术, 几乎每一行代码都跟了一句debug (类似log4j), 很快找到了错误所在.&lt;br /&gt;...&lt;br /&gt;&lt;br /&gt;     run_bulk_update;&lt;br /&gt;&lt;br /&gt;     FOR i in 1 .. lt_top_pattern.Count&lt;br /&gt;&lt;span style="color: rgb(51, 51, 255);"&gt;     Loop&lt;/span&gt;&lt;br /&gt;&lt;span style="color: rgb(51, 51, 255);"&gt;        run_bulk_update_tophit(p_hit_cols =&gt; lt_top_pattern(i));&lt;/span&gt;&lt;br /&gt;&lt;span style="color: rgb(51, 51, 255);"&gt;     End Loop&lt;/span&gt;&lt;span style="font-weight: bold; color: rgb(255, 0, 0);"&gt;&lt;span style="color: rgb(51, 51, 255);"&gt; &lt;/span&gt;;&lt;/span&gt;&lt;br /&gt;&lt;br /&gt;     run_bulk_insert;&lt;br /&gt;     save_col_upd_pattern;&lt;br /&gt;...&lt;br /&gt;&lt;br /&gt;数据库版本是11.1.0.7.0, SunOS 5.10&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-1266874567306907745?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/1266874567306907745/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=1266874567306907745' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1266874567306907745'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1266874567306907745'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/07/strange-plsql-complier-bug.html' title='奇怪的Strange PL/SQL complier bug编译臭虫'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-6436955050063284742</id><published>2009-07-03T13:11:00.000-07:00</published><updated>2009-07-03T13:18:42.183-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>可以少开会吗 Meetings are indispensable?</title><content type='html'>鄙人非常讨厌开会, 不过开会的时间是一个很好的打瞌睡休息时间.&lt;br /&gt;&lt;br /&gt;除非你啥都不想干, 就去开会吧.&lt;br /&gt;&lt;br /&gt;"Meetings are indispensable when you don't want to do anything."&lt;br /&gt;-- John Kenneth Galbraith&lt;br /&gt;&lt;br /&gt;Meetings (usually) suck. The traditional way of doing business includes company meetings throughout the day, taking an hour or more usually. This can eat up half of your day or more. Add to that individual meetings at lunch, or having drinks, or just a one-on-one in the office and you're meeting more than you re producing.&lt;br /&gt;&lt;br /&gt;If you've sat through a lot of meetings, like I have, you know they're almost always useless. Sure, sometimes they're good, but most of the time they're boring, full of chit-chat or useless information, and really can be accomplished through a simple email or phone call. They're a waste of everyone's time, and worse yet, most people know it. And nothing changes.&lt;br /&gt;&lt;br /&gt;有很多情况可以不用开会, 使用有效的替代方案:&lt;br /&gt;&lt;br /&gt;Instead, learn to accomplish the tasks of a meeting through an email, a quick phone call, a quick and focused IM, an online group chat if necessary. Collaborate through online tools, such as those mentioned above. Keep meetings to a bare minimum. Sure, you still need to socialize with people, and have actual conversations, but boring and useless meetings aren't the best way to do that. If you control your company or division, do yourself and your company a favor by eliminating most of your meetings.&lt;br /&gt;&lt;br /&gt;那么啥时候需要开会呢?&lt;br /&gt;&lt;br /&gt;Only meeting after 3 round trip emails and the goal is still not clear.&lt;br /&gt;&lt;br /&gt;以上摘自公司内部Email.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-6436955050063284742?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/6436955050063284742/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=6436955050063284742' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6436955050063284742'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6436955050063284742'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/07/meetings-are-indispensable.html' title='可以少开会吗 Meetings are indispensable?'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-4952026997896934561</id><published>2009-06-17T15:25:00.000-07:00</published><updated>2009-06-17T15:34:22.010-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>Cowichan River Tube Trip 漂流</title><content type='html'>一年一度的温哥华岛自然水域漂流又要开始啦! 欢迎留言报名. 跟我的&lt;a href="http://twitter.com/mujiang"&gt;http://twitter.com/mujiang&lt;/a&gt;也行.&lt;br /&gt;在这里,您可以接受加拿大成人仪式, 品尝杂草(weed), 根据个人喜好选择,不存在任何强迫. 嘻嘻.&lt;br /&gt;&lt;br /&gt;上甘岭河(Cowichan River)是我平生见到的最好玩的漂流, 水质纯天然,清澈,水量充足,安全,偶然有一些激流(一共两处),有惊无险,赶紧靠岸就行了,胆大的可以冒进. 去年鄙人躲了,今年一定要尝试一下激流速降.&lt;br /&gt;&lt;br /&gt;&lt;h1 class="pagetitle" id="title-heading"&gt;&lt;span id="title-text"&gt;&lt;a href="/confluence/display/RND/Cowichan+River+Tube+Trip"&gt;Cowichan River Tube  Trip&lt;/a&gt; &lt;/span&gt;&lt;/h1&gt;&lt;!--     Root decorator: this is a layer of abstraction that Confluence doesn't need. It will be removed eventually. --&gt; &lt;div class="page view" id="content"&gt; &lt;div class="page-metadata"&gt; Added by &lt;a href="/confluence/display/%7Edchase"&gt;Doug Chase&lt;/a&gt;, last edited by &lt;a href="/confluence/display/%7Eczhu"&gt;Charlie Zhu&lt;/a&gt; on Jun 17, 2009&lt;span class="noprint"&gt;&lt;/span&gt; &lt;/div&gt; &lt;div class="wiki-content"&gt;&lt;!-- wiki content --&gt; &lt;h3&gt;&lt;a name="CowichanRiverTubeTrip-TheDate"&gt;&lt;/a&gt;The Date&lt;/h3&gt; &lt;p&gt;June 28th 2009&lt;/p&gt; &lt;h3&gt;&lt;a name="CowichanRiverTubeTrip-TheFloat"&gt;&lt;/a&gt;The Float&lt;/h3&gt; &lt;p&gt;&lt;b&gt;Skutz Falls to Marie Canyon&lt;/b&gt; - 2hr ride, not including optional time  spent beached&lt;/p&gt; &lt;h3&gt;&lt;a name="CowichanRiverTubeTrip-Equipmentneeded"&gt;&lt;/a&gt;Equipment needed&lt;/h3&gt; &lt;ol&gt;&lt;li&gt;&lt;b&gt;Tube&lt;/b&gt; - If you don't have one, we can buy them at the local tire shop  in Duncan for $20 or Zellers in Tillicum Mall has &lt;a href="http://www.kidstoychest.com/images/wet58825lg.jpg" rel="nofollow"&gt;These&lt;/a&gt;  for $24 (BESTEST TUBE EVEEER!!!!)  &lt;/li&gt;&lt;li&gt;&lt;b&gt;Beverages&lt;/b&gt; - What ever you feel like drinking (&lt;span style="color:red;"&gt;&lt;b&gt;NO  GLASS BOTTLES ALLOWED&lt;/b&gt;&lt;/span&gt;)  &lt;/li&gt;&lt;li&gt;&lt;b&gt;Cooler(s)&lt;/b&gt; - Communal, if anybody has a big cooler that would be great   &lt;/li&gt;&lt;li&gt;&lt;b&gt;Cooler Tube&lt;/b&gt; - Gets blown up around the cooler to keep it a float and  safe (also acts as an emergency spare)  &lt;/li&gt;&lt;li&gt;&lt;b&gt;River Shoes&lt;/b&gt; - I use a old pair of runners, some sort of footware is a  must(IMO)  &lt;/li&gt;&lt;li&gt;&lt;b&gt;Rope&lt;/b&gt; - Or bungy to tie tubes to the trucks  &lt;/li&gt;&lt;li&gt;&lt;b&gt;Sunscreen!!&lt;/b&gt;  &lt;/li&gt;&lt;li&gt;&lt;b&gt;What ever else you might want to bring&lt;/b&gt; &lt;/li&gt;&lt;/ol&gt; &lt;h3&gt;&lt;a name="CowichanRiverTubeTrip-TheTimeLine"&gt;&lt;/a&gt;The Time Line&lt;/h3&gt; &lt;ul&gt;&lt;li&gt;9 AM - Meet at ABE  &lt;/li&gt;&lt;li&gt;9:30 AM - Leave for Duncan  &lt;/li&gt;&lt;li&gt;10:15 AM - Buy Tires and Snacks if wanted  &lt;/li&gt;&lt;li&gt;10:30 AM - Buy Beverages and head off  &lt;/li&gt;&lt;li&gt;11:00ish AM - Start Tube ride  &lt;/li&gt;&lt;li&gt;Enter time warp time can not be quantified &lt;/li&gt;&lt;/ul&gt; &lt;h3&gt;&lt;a name="CowichanRiverTubeTrip-TheTubers"&gt;&lt;/a&gt;The Tubers&lt;/h3&gt; &lt;ol&gt;&lt;li&gt;Doug - Have Car will drive  &lt;/li&gt;&lt;li&gt;Megan - Has Car if needed  &lt;/li&gt;&lt;li&gt;Charlie - Will go if I can find someone take care of my puppy and my shin  wound recovered. &lt;/li&gt;&lt;/ol&gt;&lt;/div&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-4952026997896934561?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/4952026997896934561/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=4952026997896934561' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/4952026997896934561'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/4952026997896934561'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/06/cowichan-river-tube-trip.html' title='Cowichan River Tube Trip 漂流'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-6098782469326840332</id><published>2009-06-10T17:01:00.000-07:00</published><updated>2009-06-10T17:12:25.476-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>scrum 群殴扭打</title><content type='html'>如果你们也在实施敏捷(Agile)软件开发,你就知道scrum是啥意思了, 就是在一个开发小组里面,每人每天早晨简短汇报工作进度.&lt;br /&gt;&lt;br /&gt;每天早上的Scrum都会讲昨天干了什么,今天要干什么. 周一早上,我就说昨天我去沃尔玛采购了幼犬用品,今天继续开发在线库存系统的Database API.&lt;br /&gt;&lt;br /&gt;大家沉默了三秒钟,突然开始集体爆笑. 原来每天的Scrum大伙都是来报到凑个数,没几个人关心别人干了什么.&lt;br /&gt;就是做和尚撞钟,混个工分.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-6098782469326840332?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/6098782469326840332/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=6098782469326840332' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6098782469326840332'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6098782469326840332'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/06/scrum.html' title='scrum 群殴扭打'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-9200051629297508709</id><published>2009-05-29T11:00:00.000-07:00</published><updated>2009-05-29T11:54:44.101-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='PL/SQL'/><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>PL/SQL代码可以有多大size limit</title><content type='html'>PL/SQL程序块的最大尺寸是67108864 (2**26) DIANA节点, 主要是受shared memory pool的限制.&lt;br /&gt;PL/SQL程序块包括(Package)包头,包体,独立存储过程,或者匿名程序块. eBay好像是统统使用匿名PL/SQL块.&lt;br /&gt;&lt;br /&gt;但是对于DIANA节点,我们只能获取一个大概的数字,通过查询视图USER_OBJECT_SIZE,PARSED_SIZE列里面是"扁平化的flattened" DIANA节点数:&lt;br /&gt;&lt;br /&gt;&lt;pre&gt;&lt;br /&gt;SQL&gt; SELECT * FROM user_object_size WHERE name = 'PKG1';&lt;br /&gt;&lt;br /&gt;NAME TYPE        SOURCE_SIZE  PARSED_SIZE  CODE_SIZE  ERROR_SIZE&lt;br /&gt;----------------------------------------------------------------&lt;br /&gt;PKG1 PACKAGE              46          165        119           0&lt;br /&gt;PKG1 PACKAGE BODY         82            0        139           0&lt;br /&gt;&lt;/pre&gt;&lt;br /&gt;&lt;br /&gt;根据Tom和Tim(&lt;a href="http://oracle-base.com"&gt;http://oracle-base.com&lt;/a&gt;/)的理想境界,去除Java/C/.Net等前端应用代码里面的所有SELECT/INSERT/UPDATE/DELETE/MERGE,把那些丑陋的SQL扔到九霄云外.&lt;br /&gt;--不是说Java Developer不会写SQL, 而是他们的强项不在数据库. 模块化,专业分工,高效合作,&lt;br /&gt;&lt;br /&gt;鄙人最近三个月奋发图强,努力工作,大力推行Database API, 消灭Java应用里面的SQL代码,书写了很多PL/SQL代码,有一个接近100K,编译一遍耗时数秒, 就开始担心最大尺寸问题. 结果PARSED_SIZE只有6115, 离67108864(64M)还差点远着哩.&lt;br /&gt;&lt;br /&gt;当然鄙人也在认真学习Agile编程里面的Refactoring代码重构, 尽量将重复使用的代码段抽象成子过程,或者工具包.&lt;br /&gt;&lt;br /&gt;参考:&lt;br /&gt;Oracle® Database PL/SQL Language Reference&lt;br /&gt;11g Release 1 (11.1)&lt;br /&gt;&lt;br /&gt;Appendix C PL/SQL Program Limits&lt;br /&gt;.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-9200051629297508709?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/9200051629297508709/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=9200051629297508709' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/9200051629297508709'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/9200051629297508709'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/05/plsqlsize-limit.html' title='PL/SQL代码可以有多大size limit'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-7682320054437470199</id><published>2009-05-24T21:13:00.000-07:00</published><updated>2009-05-24T21:15:12.152-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>Give and Take - IT Club聚会主题征集</title><content type='html'>眼看五月份要交白卷了, 转一篇我在维多利亚IT俱乐部的帖子:&lt;br /&gt;&lt;br /&gt;鄙人有一个想法:&lt;br /&gt;&lt;br /&gt;就是大伙罗列出你关心/感兴趣的主题, 和你能够共享/贡献的主题.&lt;br /&gt;把答案发给木匠,然后鄙人整理筛选,协助GengLi 和 老Shan协调安排, 使以后的聚会更加有针对性.&lt;br /&gt;&lt;br /&gt;好了, 举个例子, 比如 木匠的共享和兴趣:&lt;br /&gt;&lt;br /&gt;贡献&lt;br /&gt;----&lt;br /&gt;*) 给IT老兵的六点建议&lt;br /&gt;*) 数据库应用开发的糟糕模式与实践 Performance Anti-Patterns in Database-Driven&lt;br /&gt;Applications&lt;br /&gt;*) JDBC/.Net应用的高效数据库存取&lt;br /&gt;*) GTD 时间管理&lt;br /&gt;&lt;br /&gt;*) 自由泳 训练&lt;br /&gt;*) 露营 + 密林狂奔&lt;br /&gt;*) 训练小狗&lt;br /&gt;*) Cowichan lake 轮胎漂流&lt;br /&gt;&lt;br /&gt;感兴趣&lt;br /&gt;-- -- ---&lt;br /&gt;如和构建易于线性扩展的Web应用系统架构 (Scale out)&lt;br /&gt;Agile项目管理&lt;br /&gt;Agile软件开发流程&lt;br /&gt;&lt;br /&gt;户外露营 + 密林狂奔&lt;br /&gt;小狗训练&lt;br /&gt;川菜烹饪&lt;br /&gt;划船 及 安全&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;- MJ&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-7682320054437470199?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/7682320054437470199/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=7682320054437470199' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7682320054437470199'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7682320054437470199'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/05/give-and-take-it-club.html' title='Give and Take - IT Club聚会主题征集'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-3710989597487294314</id><published>2009-04-30T13:42:00.001-07:00</published><updated>2009-04-30T13:44:02.752-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>今日好图 流感传染途径How swine flu gets transmitted….</title><content type='html'>猪流感是这样传染的:&lt;br /&gt;&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://2.bp.blogspot.com/_Wv9Lui_cURQ/SfoNTWBQe4I/AAAAAAAAAKE/svoP236yCu8/s1600-h/pig_and_boy.JPG"&gt;&lt;img style="cursor:pointer; cursor:hand;width: 400px; height: 299px;" src="http://2.bp.blogspot.com/_Wv9Lui_cURQ/SfoNTWBQe4I/AAAAAAAAAKE/svoP236yCu8/s400/pig_and_boy.JPG" border="0" alt=""id="BLOGGER_PHOTO_ID_5330587734925933442" /&gt;&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-3710989597487294314?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/3710989597487294314/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=3710989597487294314' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/3710989597487294314'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/3710989597487294314'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/how-swine-flu-gets-transmitted.html' title='今日好图 流感传染途径How swine flu gets transmitted….'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://2.bp.blogspot.com/_Wv9Lui_cURQ/SfoNTWBQe4I/AAAAAAAAAKE/svoP236yCu8/s72-c/pig_and_boy.JPG' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-7028019972582176336</id><published>2009-04-29T09:18:00.000-07:00</published><updated>2009-04-29T09:24:20.865-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>SQL Server技术讲座-维多利亚IT Club</title><content type='html'>[IT Club] IT 技术讲座--5月16日，星期六，下午2：30&lt;br /&gt;Address: 2121 Cedar Hill Cross Rd.&lt;br /&gt;&lt;br /&gt;欢迎IT及各界人士前来捧场,结交新朋友,拓展人脉网络, 一定会帮助到您的职业发展和生活琐事.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;以下是来自 John 黄 的介绍:&lt;br /&gt;&lt;br /&gt;***&lt;br /&gt;&lt;br /&gt;大家好！5月份的讲座由我来说说。 N多个月前讲SQL Replication，弄了60多页，讲得口干舌燥，我想听的人也很辛苦。 这一次我准备了30多页和一些Demo， 希望不要太枯燥，也不要给大家和我带来什么负担。。。。。。&lt;br /&gt;&lt;br /&gt;这一次的话题是SQL Server 的 Locking and Blocking。听这个名字就不像一个有意思的话题， 但是只要牵扯到SQL Server 编程就无法逃避。内容还会涉及到由于Locking and Blocking 所引申出的其他话题，如数据库的设计，编程，性能调整，管理, 和SQL Server 2008 新特性等等，但是不会很多，主要还是集中精力论述Locking and Blocking。我真心邀请Orcle或者其他数据库专家们到场能给我们对应的功能实现。这样能让我们的讲座更加丰富一些。最后如果有时间，我给大家演示SQL Serer Application Locks的应用。&lt;br /&gt;&lt;br /&gt;时间：5月16日，星期六，下午2：30&lt;br /&gt;地点: UVIC大学旁边那个教堂（谁知道具体地址请补充）&lt;br /&gt;&lt;br /&gt;下面的连接是给大家做参考。与讲座关系不大，但是在讲座中有可能会提及但是不会详尽描述。&lt;br /&gt;&lt;br /&gt;Troubleshooting Performance Problems in SQL Server 2005&lt;br /&gt;&lt;br /&gt;    [url]http://www.microsoft.com/technet/prodtechnol/sql/2005/tsprfprb.mspx[/url]&lt;br /&gt;&lt;br /&gt;PSS SQL Server Engine Blog&lt;br /&gt;&lt;br /&gt;    [url]http://blogs.msdn.com/psssql/default.aspx[/url]&lt;br /&gt;&lt;br /&gt;Performance Stats Script&lt;br /&gt;&lt;br /&gt;    [url]http://blogs.msdn.com/psssql/archive/2007/02/21/sql-server-2005-performance-statistics-script.aspx[/url]&lt;br /&gt;&lt;br /&gt;MSDN Webcast: SQL Server 2008 Advanced Troubleshooting with Extended Events&lt;br /&gt;&lt;br /&gt;    [url]http://msevents.microsoft.com/cui/WebCastEventDetails.aspx?culture=en-US&amp;EventID=1032356291&amp;CountryCode=US[/url]&lt;br /&gt;&lt;br /&gt;Bob Beauchemin's Blog: Series in August 2007&lt;br /&gt;&lt;br /&gt;    [url]http://www.sqlskills.com/blogs/bobb/default,month,2007-08.aspx[/url]&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;KB 271509: INF: How to Monitor SQL Server 2000 Blocking&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;黄志勇&lt;br /&gt;John H&lt;br /&gt;Microsoft Certified Master -- SQL Server 2008&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-7028019972582176336?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/7028019972582176336/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=7028019972582176336' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7028019972582176336'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7028019972582176336'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/sql-server-it-club.html' title='SQL Server技术讲座-维多利亚IT Club'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-7675128286178375321</id><published>2009-04-24T16:07:00.000-07:00</published><updated>2009-04-24T16:09:50.635-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><category scheme='http://www.blogger.com/atom/ns#' term='twitter'/><title type='text'>Twitter guide使用指南</title><content type='html'>自从上个月注册了一个Twitter用户以后,把个Twitter用的不亦乐乎,基本没有功夫更新博客了.&lt;br /&gt;木匠的鸟鸣: &lt;a href="http://twitter.com/mujiang"&gt;http://twitter.com/mujiang&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;这里就引用一篇Twitter使用指南,给鄙人的博客凑个数.&lt;br /&gt;&lt;br /&gt;&lt;a href="TrackBack: http://www.yeeyan.com/articles/view/16551/36190"&gt;TrackBack: http://www.yeeyan.com/articles/view/16551/36190&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;利用它来与你的同行取得联系&lt;br /&gt;&lt;br /&gt;除了Twitter外网上有一大堆社区和社交网络型站点，但Twitter仍是我的最爱之一！事实上在Twitter上follow我的人数比我那个设计博客的订阅用户数还要多。&lt;br /&gt;&lt;br /&gt;假设你是一位设计师，我确信总有一些网站和博客是你会定期访问的，我也确信你喜欢通过查看他人的作品和个人履历站点来获得灵感。只需找到 Twitter上的徽章或按钮并follow这些人。很可能发生的情况是他们也会follow你。然后就只是加入或开启一段对话的问题了。&lt;br /&gt;&lt;br /&gt;在Twitter上有许多设计师和网络工作者（当然也有很多自由撰稿人和博客发布者）。前段时间来自Vandelay Design的Steven写了“Twitter上值得follow的50名设计师”这篇文章，而NETTUTS的Jeffrey将“你应该follow 的9位网页设计师”汇编到了这一清单中。我想这些信息对你开始使用Twitter都将有所帮助。&lt;br /&gt;&lt;br /&gt;花些时间去帮助他人&lt;br /&gt;&lt;br /&gt;最近Go Media的工作人员开始通过Twitter来给他人提供设计帮助。我认为这是一个绝妙的点子！这是多么好的一种回馈社会和帮助他人的方法啊！&lt;br /&gt;&lt;br /&gt;还有很多其他设计师也在做相同的事情 - 比方说，当我看见某人在CSS,PHP甚至发布博客方面存在疑问时，我会尝试着给出最佳答案！当我有疑问时我知道有些人也会尽量帮助我。如果我们都能互相学习那将是一种双赢的局面。&lt;br /&gt;&lt;br /&gt;添加链接到你的个人简历式站点或博客&lt;br /&gt;&lt;br /&gt;Twitter当然不是一个像Behance或Carbonmade那种能上传以前作品的网站，但你可以添加链接到你的个人站点并发布关于你目前的设计项目的信息并邀请别人对你的设计作品做出评价。&lt;br /&gt;&lt;br /&gt;你可以在侧栏上或你发布的信息中添加你个人站点的链接。当然不是每个人都会点开你的个人站点，但那些点开的人将更有可能会联系你并有可能雇佣你因为他们已经在Twitter“听说过”你了。&lt;br /&gt;&lt;br /&gt;谈论一些和你所在行业相关的话题&lt;br /&gt;&lt;br /&gt;你是否读到了一篇和自由职业、设计、写作或博客相关的好文章？为什么不谈论它并让你的朋友知道你喜欢这篇文章呢？IE6下PNG的兼容问题有了新的解决方法？嘿，我想知道相关的信息！&lt;br /&gt;&lt;br /&gt;    如果我在某个时候需要将部分工作外包，我也许会联系Twitter上的那个人，因为他以前帮助过我，他很友善，我也把他视为专家，因为看起来他对自己所在的行业很了解。&lt;br /&gt;&lt;br /&gt;回复他人的信息&lt;br /&gt;&lt;br /&gt;我喜欢收到潜在客户发来的邮件，说他们在Twitter上发现了我并且需要为某个项目寻找一名网页设计师。我认为这真的很棒，因为实际上我并没有在Twitter花太多时间，我只不过是时不时地在上面发布些信息。&lt;br /&gt;&lt;br /&gt;有些人会很直接地给你发信息来询问你是否有时间替他工作。你要确保阅读并回复这些信息！我知道，你已经需要查看电子邮件，也许你并不想在Twitter回复更多的人了，但如果回复这些信息能给你带来一份很酷的设计任务或很棒的薪酬呢？这种好事情已经多次在我身上发生了！&lt;br /&gt;&lt;br /&gt;你也来分享下经验吧&lt;br /&gt;&lt;br /&gt;你是如何利用Twitter来寻找客户的？你是把Twitter视为一个非常酷的营销和客户网络拓展工具还是说纯粹只是把它作为一个消磨时间的站点呢？曾有潜在客户通过Twitter联系过你么？你接到那个项目了么？请利用留言系统和大家分享下你的使用技巧以及在Twitter上发生的成功的案例。:)&lt;br /&gt;&lt;br /&gt;推荐&lt;br /&gt;---&lt;br /&gt;&lt;a href="http://www.yeeyan.com/groups/show/twitter"&gt;http://www.yeeyan.com/groups/show/twitter&lt;/a&gt;  译言twitter小组&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-7675128286178375321?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/7675128286178375321/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=7675128286178375321' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7675128286178375321'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7675128286178375321'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/twitter-guide.html' title='Twitter guide使用指南'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-2391354288737734997</id><published>2009-04-13T16:54:00.000-07:00</published><updated>2009-06-17T15:50:21.700-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><category scheme='http://www.blogger.com/atom/ns#' term='movie'/><title type='text'>电影推荐 The god must be crazy</title><content type='html'>复活节长周末,看完了电影[The god must be crazy]的一集和二集. 觉得该强烈推荐给各位.&lt;br /&gt;虽然是九十年代初拍摄的,故事以情节取胜,紧凑,幽默,而且富有教育意义.&lt;br /&gt;如果您觉得没有[疯狂的石头]好看,鄙人按当地的平均小时工资偿还您,大概三个小时. 瞧瞧,到底是研究数据库的,这么精确的数字和逻辑.&lt;br /&gt;&lt;br /&gt;故事是这样的,在非洲大陆内部依然依然生活着一群原始部落族群 bushman,他们有着极强的自然适应能力,轻松的适应了非洲的干旱季节,而不是现代化人类的破坏能力,让自然适应人.&lt;br /&gt;电影讲述了一群现代人闯入bushman人的生活,以及后面引发的一系列有趣的故事.&lt;br /&gt;&lt;br /&gt;也暗示的讽刺了人对不能理解事物的盲目崇拜,如第一集里面的一个玻璃可乐瓶子.&lt;br /&gt;&lt;br /&gt;一群现代人的复杂矛盾,却被原始人用极其简单的方法给解决了.&lt;br /&gt;&lt;br /&gt;鄙人无法道出所有精髓,您自己慢慢欣赏吧.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-2391354288737734997?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/2391354288737734997/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=2391354288737734997' title='1 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/2391354288737734997'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/2391354288737734997'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/god-must-be-crazy.html' title='电影推荐 The god must be crazy'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>1</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-1147424603620953864</id><published>2009-04-10T11:13:00.000-07:00</published><updated>2009-04-10T12:07:21.513-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>swim in wild lake 畅游天然湖泊</title><content type='html'>过了下个长周末,五月份的维多利亚日,就正式宣告进入夏季,也是维多利亚的天堂季节和旅游旺季,世界各地人民呼呼涌来.&lt;br /&gt;&lt;br /&gt;为了帮助新来的喜欢游泳的华人少走弯路,鄙人在这里介绍一下维多利亚和温哥华的适合游泳的天然湖泊.&lt;br /&gt;淡水湖泊里面游泳肯定比游泳池里面舒服,也比海水温暖,不用穿保暖泳衣.&lt;br /&gt;&lt;br /&gt;维多利亚:&lt;br /&gt;&lt;br /&gt;1) Durrance lake&lt;br /&gt;&lt;iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="http://maps.google.ca/?ie=UTF8&amp;amp;ll=48.548745,-123.47796&amp;amp;spn=0.020511,0.049052&amp;amp;z=15&amp;amp;output=embed"&gt;&lt;/iframe&gt;&lt;br /&gt;&lt;small&gt;&lt;a href="http://maps.google.ca/?ie=UTF8&amp;amp;ll=48.548745,-123.47796&amp;amp;spn=0.020511,0.049052&amp;amp;z=15&amp;amp;source=embed" style="color:#0000FF;text-align:left"&gt;View Larger Map&lt;/a&gt;&lt;/small&gt;&lt;br /&gt;&lt;br /&gt;2) Matheson lake&lt;br /&gt;&lt;iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="http://maps.google.ca/?ie=UTF8&amp;amp;ll=48.363663,-123.604259&amp;amp;spn=0.041173,0.098104&amp;amp;z=14&amp;amp;output=embed"&gt;&lt;/iframe&gt;&lt;br /&gt;&lt;small&gt;&lt;a href="http://maps.google.ca/?ie=UTF8&amp;amp;ll=48.363663,-123.604259&amp;amp;spn=0.041173,0.098104&amp;amp;z=14&amp;amp;source=embed" style="color:#0000FF;text-align:left"&gt;View Larger Map&lt;/a&gt;&lt;/small&gt;&lt;br /&gt;&lt;br /&gt;维多利亚的名气大,但是不适合游泳的湖泊:&lt;br /&gt;&lt;br /&gt;1) Elk lake and Beaver lake&lt;br /&gt;2) Thetis lake&lt;br /&gt;&lt;br /&gt;因为人多,把冷水都给搅上来了,而且脏.&lt;br /&gt;&lt;br /&gt;温哥华&lt;br /&gt;&lt;br /&gt;1) Buntzen lake &lt;br /&gt;&lt;iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="http://maps.google.ca/maps?f=q&amp;amp;source=s_q&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=bonson+lake&amp;amp;sll=49.368849,-123.11348&amp;amp;sspn=0.161415,0.261955&amp;amp;ie=UTF8&amp;amp;ll=49.351519,-122.860107&amp;amp;spn=0.078276,0.145912&amp;amp;z=12&amp;amp;output=embed"&gt;&lt;/iframe&gt;&lt;br /&gt;&lt;small&gt;&lt;a href="http://maps.google.ca/maps?f=q&amp;amp;source=embed&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=bonson+lake&amp;amp;sll=49.368849,-123.11348&amp;amp;sspn=0.161415,0.261955&amp;amp;ie=UTF8&amp;amp;ll=49.351519,-122.860107&amp;amp;spn=0.078276,0.145912&amp;amp;z=12" style="color:#0000FF;text-align:left"&gt;View Larger Map&lt;/a&gt;&lt;/small&gt;&lt;br /&gt;&lt;br /&gt;2) 可能是Rice lake, 过两天找温哥华的同学确认一下.&lt;br /&gt;&lt;iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="http://maps.google.ca/maps?f=q&amp;amp;source=s_q&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=bonson+lake&amp;amp;sll=49.368849,-123.11348&amp;amp;sspn=0.161415,0.261955&amp;amp;ie=UTF8&amp;amp;t=p&amp;amp;ll=49.35616,-123.013315&amp;amp;spn=0.019567,0.036478&amp;amp;z=14&amp;amp;output=embed"&gt;&lt;/iframe&gt;&lt;br /&gt;&lt;small&gt;&lt;a href="http://maps.google.ca/maps?f=q&amp;amp;source=embed&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=bonson+lake&amp;amp;sll=49.368849,-123.11348&amp;amp;sspn=0.161415,0.261955&amp;amp;ie=UTF8&amp;amp;t=p&amp;amp;ll=49.35616,-123.013315&amp;amp;spn=0.019567,0.036478&amp;amp;z=14" style="color:#0000FF;text-align:left"&gt;View Larger Map&lt;/a&gt;&lt;/small&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Enjoy the swimming in natural wild lake !&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-1147424603620953864?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/1147424603620953864/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=1147424603620953864' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1147424603620953864'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1147424603620953864'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/swim-in-wild-lake.html' title='swim in wild lake 畅游天然湖泊'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-1470260431876606053</id><published>2009-04-09T21:33:00.000-07:00</published><updated>2009-04-10T12:20:48.795-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>Easter day复活节</title><content type='html'>在加拿大生活,基本上每个月有一个公众假日.&lt;br /&gt;&lt;br /&gt;明天是美好星期五(Good Friday),下周一是复活节(Easter Day),两个公众假日连在了一起, 还没想好咋玩呢.&lt;br /&gt;&lt;br /&gt;我在加拿大度过的第一个复活节是在2006年四月,四月是加拿大西海岸的雨季,当时下着连阴雨,组织了本地一帮朋友开车4小时去了Tofino,一个著名的冲浪胜地,并且以广阔的海滩著称,最大的一个海滩长11公里. Tofino是加拿大国家公园 Pacific rim的一部分, 我们都不会冲浪,就穿越森林,溜海滩,观巨浪.&lt;br /&gt;"West Coast lifestyle Victoria" 此句经常出现在各种地处维多利亚的公司的招聘广告上,用来吸引外地人士, 听着是很惬意.&lt;br /&gt;&lt;br /&gt;我是大菠萝迷(Diablo II), 听说3.0 在三月发行了,明天去FutureShop看看有没有到货.&lt;br /&gt;&lt;br /&gt;今天在牙医诊所修理了最后两颗牙冠, 如果您刚从中国国内过来,这里牙医服务会让你倍感震撼 (服务质量过于上乘),下文详解. 牙医给我讲了复活节的缩减版故事: 耶稣出生了,走了,又来了,故事完了.&lt;br /&gt;&lt;br /&gt;祝各位节日快乐,赶紧出门享受好天气, 今年四月份没有下雨,多难得.&lt;br /&gt;...&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://4.bp.blogspot.com/_Wv9Lui_cURQ/Sd-Z8q0QcXI/AAAAAAAAAJk/ZjglCAMw8w4/s1600-h/PICT1956.JPG"&gt;&lt;img style="margin: 0px auto 10px; width: 400px; height: 300px;" src="http://4.bp.blogspot.com/_Wv9Lui_cURQ/Sd-Z8q0QcXI/AAAAAAAAAJk/ZjglCAMw8w4/s400/PICT1956.JPG" alt="" id="BLOGGER_PHOTO_ID_5323142552139886962" /&gt;&lt;/a&gt;&lt;br /&gt;长滩.&lt;br /&gt;...&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://1.bp.blogspot.com/_Wv9Lui_cURQ/Sd-bDbUKUrI/AAAAAAAAAJs/6aFRaR65VwY/s1600-h/PICT1973.JPG"&gt;&lt;img style="cursor: pointer; width: 400px; height: 300px;" src="http://1.bp.blogspot.com/_Wv9Lui_cURQ/Sd-bDbUKUrI/AAAAAAAAAJs/6aFRaR65VwY/s400/PICT1973.JPG" alt="" id="BLOGGER_PHOTO_ID_5323143767749448370" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;长滩北段.&lt;br /&gt;.&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://3.bp.blogspot.com/_Wv9Lui_cURQ/Sd-bi9hy5JI/AAAAAAAAAJ0/l7dtZs7x8wY/s1600-h/PICT1958.JPG"&gt;&lt;img style="cursor: pointer; width: 400px; height: 300px;" src="http://3.bp.blogspot.com/_Wv9Lui_cURQ/Sd-bi9hy5JI/AAAAAAAAAJ0/l7dtZs7x8wY/s400/PICT1958.JPG" alt="" id="BLOGGER_PHOTO_ID_5323144309509383314" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;林中木板路(board walk)&lt;br /&gt;.&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://4.bp.blogspot.com/_Wv9Lui_cURQ/Sd-b0pjAipI/AAAAAAAAAJ8/Ruw5bknQGjc/s1600-h/PICT1975.JPG"&gt;&lt;img style="cursor: pointer; width: 400px; height: 300px;" src="http://4.bp.blogspot.com/_Wv9Lui_cURQ/Sd-b0pjAipI/AAAAAAAAAJ8/Ruw5bknQGjc/s400/PICT1975.JPG" alt="" id="BLOGGER_PHOTO_ID_5323144613383408274" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;太平洋西海岸原始森林.&lt;br /&gt;.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-1470260431876606053?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/1470260431876606053/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=1470260431876606053' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1470260431876606053'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/1470260431876606053'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/easter-day.html' title='Easter day复活节'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://4.bp.blogspot.com/_Wv9Lui_cURQ/Sd-Z8q0QcXI/AAAAAAAAAJk/ZjglCAMw8w4/s72-c/PICT1956.JPG' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-6405620544056265488</id><published>2009-04-06T10:16:00.000-07:00</published><updated>2009-04-06T16:11:02.574-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='life'/><title type='text'>Soccer fans needed温哥华岛IT公司足球联赛</title><content type='html'>&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://3.bp.blogspot.com/_Wv9Lui_cURQ/Sdo84ssobfI/AAAAAAAAAI0/WJbCMwj9Opg/s1600-h/ball.JPG"&gt;&lt;img style="margin: 0pt 10px 10px 0pt; float: left; cursor: pointer; width: 262px; height: 175px;" src="http://3.bp.blogspot.com/_Wv9Lui_cURQ/Sdo84ssobfI/AAAAAAAAAI0/WJbCMwj9Opg/s400/ball.JPG" alt="" id="BLOGGER_PHOTO_ID_5321632854460362226" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;温哥华岛高科技公司的足球联赛在沉寂两年后又开始啦. 各位维多利亚的足球爱好者,赶紧出来,享受阳光,驰骋绿茵场.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Your very own AbeBooks soccer players have 2 upcoming matches against our friends at Genologics…&lt;br /&gt;&lt;br /&gt;AbeBooks VS. GenoLogics&lt;br /&gt;&lt;br /&gt;Come out and enjoy the weather and support your co-workers for these 2 fun games.&lt;br /&gt;&lt;br /&gt;Game 1&lt;br /&gt;&lt;br /&gt;When: Wednesday, April 8th 2009&lt;br /&gt;&lt;br /&gt;Time: 11:45am kickoff&lt;br /&gt;&lt;br /&gt;Where: Vancouver Island Tech Park turf – Layritz&lt;br /&gt;behind Camosun College Interurban Campus, accessible from Interurban Rd and West Saanich Rd&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Game 2&lt;br /&gt;&lt;br /&gt;When: Wednesday, April 15th 2009&lt;br /&gt;&lt;br /&gt;Time: 12:15pm kickoff&lt;br /&gt;&lt;br /&gt;Where: Finlayson turfTopaz Park, Blanshard St + Finlayson St.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://2.bp.blogspot.com/_Wv9Lui_cURQ/Sdo8-826TzI/AAAAAAAAAI8/IPwH983D8YY/s1600-h/play_soccer.JPG"&gt;&lt;img style="margin: 0px auto 10px; display: block; text-align: center; cursor: pointer; width: 527px; height: 177px;" src="http://2.bp.blogspot.com/_Wv9Lui_cURQ/Sdo8-826TzI/AAAAAAAAAI8/IPwH983D8YY/s400/play_soccer.JPG" alt="" id="BLOGGER_PHOTO_ID_5321632961877659442" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;周三中午占用上班时间踢球是我们公司的传统,差不多10年了.&lt;br /&gt;.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-6405620544056265488?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/6405620544056265488/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=6405620544056265488' title='1 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6405620544056265488'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/6405620544056265488'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/soccer-fans-neededit.html' title='Soccer fans needed温哥华岛IT公司足球联赛'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://3.bp.blogspot.com/_Wv9Lui_cURQ/Sdo84ssobfI/AAAAAAAAAI0/WJbCMwj9Opg/s72-c/ball.JPG' height='72' width='72'/><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>1</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-443028064481949410</id><published>2009-04-05T22:07:00.000-07:00</published><updated>2009-04-06T09:17:36.111-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>Talk to COO 合理化建议和沟通</title><content type='html'>2009年初,我们公司开始了重新设计和开发库存管理系统,可以用革命(Revolution)来形容,有点背离了Agile提倡的进化(Evolution)主旋律.&lt;br /&gt;&lt;br /&gt;基调比较简单:&lt;br /&gt;&lt;br /&gt;1) 改变Slow-by-slow(row-by-row)慢之又慢的数据处理模式, 启用(bulk loading)打包成批处理.&lt;br /&gt;2) 合理denormalization,减少不必要的表连接.&lt;br /&gt;3) &lt;a href="http://zhu1.blogspot.com/search/label/consistency"&gt;BASE&lt;/a&gt;第一步: Function split功能拆分 和 Asynchronous process 异步处理.&lt;br /&gt;异步处理,必然引出数据复制和消息系统, 我们的消息系统数据量一大,就会僵死. 我选择了数据库staging table(数据驿站)来缓存修改的数据,对于staging堆栈表,根据简单处理过的时间键,做列表分区,做到冗余数据的最高效利用 (我一向认为队列消息属于被复制的冗余数据).&lt;br /&gt;关于设计时间相关的历史数据模型,数据建模宝典(&lt;a href="http://www.abebooks.com/servlet/SearchResults?sts=t&amp;amp;tn=Data+Modeling+Essentials+3rd&amp;amp;x=47&amp;amp;y=9"&gt;Data Modeling Essentials - Third Edition&lt;/a&gt;)推荐了两种方法,一种是Audit Trail(记录数据偏移,从起点累积),一种是Snapshot(历史镜像),我在不同场景都有采用,以后找机会做细节示范.&lt;br /&gt;&lt;br /&gt;有一个业务逻辑的改革遇到了较大的阻力,最后决定直接找COO商议,结果还是很理想的,清除了数据处理设计的最后一道障碍.&lt;br /&gt;跟产品经理和项目经理谈了很多次,结果是"多一事不如少一事,事不关己,高高挂起",这伙人才懒得从公司盈利的高度考虑问题,所以要转向那些能做决定,能从大局着眼的人士.&lt;br /&gt;&lt;br /&gt;下面简单介绍一下这个高投入低回报的业务功能:&lt;br /&gt;&lt;br /&gt;就是维护书商的产品分类,上传图书数据的时候,捎带检查图书分类表. 每行图书数据里面,包含了图书分类,一个或者多个,如果是新的分类,就在书商图书分类表里增加一行.&lt;br /&gt;如果删除了某个图书分类包含的所有书籍,就在书商图书分类表里删除掉这个图书分类.&lt;br /&gt;&lt;br /&gt;经常是上传几百万本图书信息,却对书商图书分类未动毫毛,白白浪费掉系统处理能量 来做无谓的检查.&lt;br /&gt;&lt;br /&gt;为啥雅虎没落了,谷歌兴旺了.因为Yahoo在做分类目录,Google再做搜索.&lt;br /&gt;这个年代,很少有人再通过分类目录一层一层的下钻去找到感兴趣的内容了,一个关键字查询,结果根据相关性排序,一下找到结果.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;有兴趣的产品经理,数据处理设计师和开发人员, 可以看看这个功能的链接:&lt;br /&gt;&lt;a href="http://www.abebooks.com/servlet/BooksBrowse?vendorclientid=65646&amp;amp;page=CLIENT"&gt;http://www.abebooks.com/servlet/BooksBrowse?vendorclientid=65646&amp;amp;page=CLIENT&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-443028064481949410?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/443028064481949410/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=443028064481949410' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/443028064481949410'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/443028064481949410'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/04/talk-to-coo.html' title='Talk to COO 合理化建议和沟通'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-5677266441726583983</id><published>2009-03-31T11:54:00.000-07:00</published><updated>2009-04-01T11:52:25.154-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='tool'/><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>另一种方法显示ROWID扩充信息-table function</title><content type='html'>TrackBack: &lt;a href="http://www.ningoo.net/html/2009/how_to_get_extent_id_from_rowid.html"&gt;http://www.ningoo.net/html/2009/how_to_get_extent_id_from_rowid.html&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;NinGoo的把常用工具打包进工具箱的方法很好.&lt;br /&gt;然而木匠天生缺乏分类和组织能力,一路坚持学习,持续遗忘,自身却没有留下啥积累;好比猴子搬苞谷,抱在怀里的玉米棒永远也不会增多,郁闷.&lt;br /&gt;所以鄙人决定依靠GTD方法,每周总结学到的新知识,然后放进自己的便携工具箱.&lt;br /&gt;&lt;br /&gt;好了,鉴于本人不喜欢dbms_output.put_line,索性把NinGoo的RowID工具改造成了Table Function.&lt;br /&gt;通过简单的查询,可以在任何地方使用.&lt;br /&gt;&lt;br /&gt;后面附的PL/SQL Package源代码,包含了许多PL/SQL编程优秀实践,将来找机会慢慢展开来讲.&lt;br /&gt;&lt;br /&gt;用法:&lt;br /&gt;&lt;pre&gt;&lt;br /&gt;SQL&gt; select * from table(UTILITY.tb_obj.rowid_info('AAARUtAAEAAABm2AAA'));&lt;br /&gt;&lt;br /&gt;COLUMN_VALUE&lt;br /&gt;--------------------------------------------------------------------------------&lt;br /&gt;        rowid: AAARUtAAEAAABm2AAA&lt;br /&gt;      file_id: 4&lt;br /&gt;     block_id: 6582&lt;br /&gt;data_object_id: 70957&lt;br /&gt;        owner: INVDB&lt;br /&gt;  object_name: BOOK_UPLOAD_LOG&lt;br /&gt;    extent_id: 0&lt;br /&gt;&lt;br /&gt;7 rows selected.&lt;br /&gt;&lt;br /&gt;tb_ 是toolbox的缩写.&lt;br /&gt;&lt;br /&gt;&lt;/pre&gt;&lt;br /&gt;&lt;br /&gt;工具用户需要的对象权限:&lt;br /&gt;&lt;br /&gt;grant select on dba_objects to utility;&lt;br /&gt;grant select on dba_extents to utility;&lt;br /&gt;&lt;br /&gt;源代码:&lt;br /&gt;&lt;br /&gt;注意: 如果你还没有安装捕获错误工具包u$err和(instrument)代码跟踪包debug, 可以先用备注屏蔽掉相关的代码.&lt;br /&gt;&lt;br /&gt;&lt;pre&gt;&lt;br /&gt;CREATE OR REPLACE PACKAGE UTILITY.tb_obj&lt;br /&gt;/*&lt;br /&gt;| Copyright Information Here&lt;br /&gt;|&lt;br /&gt;| File name:&lt;br /&gt;|&lt;br /&gt;| Overview:&lt;br /&gt;|&lt;br /&gt;| Author(s):&lt;br /&gt;|&lt;br /&gt;| Modification History:&lt;br /&gt;|   Date        Who         What&lt;br /&gt;|&lt;br /&gt;*/&lt;br /&gt;IS&lt;br /&gt;&lt;br /&gt;  TYPE print_tab     IS TABLE OF varchar2(200);&lt;br /&gt;&lt;br /&gt;  FUNCTION rowid_info (p_rowid in varchar2) return print_tab PIPELINED DETERMINISTIC;&lt;br /&gt;  PROCEDURE subprogram_name;&lt;br /&gt;&lt;br /&gt;END tb_obj;&lt;br /&gt;/&lt;br /&gt;&lt;br /&gt;CREATE OR REPLACE PACKAGE BODY UTILITY.tb_obj&lt;br /&gt;/*&lt;br /&gt;| Copyright Information Here&lt;br /&gt;|&lt;br /&gt;| File name:&lt;br /&gt;|&lt;br /&gt;| Overview:&lt;br /&gt;Tool box to get object information.&lt;br /&gt;&lt;br /&gt;| Author(s):&lt;br /&gt;|&lt;br /&gt;| Modification History:&lt;br /&gt;|   Date        Who         What&lt;br /&gt;31-Mar-2009   Charlie (Yi): Create the package.&lt;br /&gt;&lt;br /&gt;It meets user requirements&lt;br /&gt;It is maintainable&lt;br /&gt;It runs fast enough to minimize user frustration&lt;br /&gt;&lt;br /&gt;**) Pl/SQL development workflow, Four steps of preparing an application&lt;br /&gt;&lt;br /&gt; - Validate program requirements&lt;br /&gt;  # ask lots of questions&lt;br /&gt;  # what users ask for is not always the easiest way to solve a problem&lt;br /&gt;  # consider other approaches, include business processes and programming algorithms&lt;br /&gt; - Implement header of the program&lt;br /&gt;  # good name for the program, accurately represent the purpose of the program&lt;br /&gt;  # inputs and outputs&lt;br /&gt;  # overload sub-procedure ?&lt;br /&gt; - Define the test cases&lt;br /&gt;  # Verify it works&lt;br /&gt;  # how will I know when I am done with this program&lt;br /&gt; - Build test code&lt;br /&gt;&lt;br /&gt;|&lt;br /&gt;|&lt;br /&gt;*/&lt;br /&gt;IS&lt;br /&gt; PROCEDURE initialize_pkg&lt;br /&gt; IS&lt;br /&gt; BEGIN&lt;br /&gt;   DBMS_APPLICATION_INFO.SET_MODULE( 'tb_obj','init' );&lt;br /&gt; END initialize_pkg;&lt;br /&gt;&lt;br /&gt; FUNCTION rowid_info (p_rowid in varchar2)&lt;br /&gt;  return print_tab PIPELINED DETERMINISTIC&lt;br /&gt; /*&lt;br /&gt; | Copyright Information Here&lt;br /&gt; |&lt;br /&gt; | File name:&lt;br /&gt; |&lt;br /&gt; | Overview: Display extended rowid information.&lt;br /&gt; |&lt;br /&gt; | Author(s): Charlie MuJiang &lt;br /&gt; |&lt;br /&gt; | Modification History:&lt;br /&gt; |   Date        Who         What&lt;br /&gt;31-Mar-2009   Charlie (Yi): Create the function.&lt;br /&gt;&lt;br /&gt;Privilege: &lt;br /&gt;&lt;br /&gt;grant select on dba_objects to utility; &lt;br /&gt;grant select on dba_extents to utility; &lt;br /&gt;&lt;br /&gt;Call example: &lt;br /&gt;&lt;br /&gt;SQL&gt; select * from table(UTILITY.tb_obj.rowid_info('AAARUtAAEAAABm2AAA'));&lt;br /&gt;&lt;br /&gt;COLUMN_VALUE&lt;br /&gt;--------------------------------------------------------------------------------&lt;br /&gt;         rowid: AAARUtAAEAAABm2AAA&lt;br /&gt;       file_id: 4&lt;br /&gt;      block_id: 6582&lt;br /&gt;data_object_id: 70957&lt;br /&gt;         owner: INVDB&lt;br /&gt;   object_name: BOOK_UPLOAD_LOG&lt;br /&gt;     extent_id: 0&lt;br /&gt;&lt;br /&gt;7 rows selected.&lt;br /&gt;&lt;br /&gt; |&lt;br /&gt; */&lt;br /&gt; IS&lt;br /&gt;&lt;br /&gt;  ln_block_id number;&lt;br /&gt;  ln_file_id number;&lt;br /&gt;  ln_object_id number;&lt;br /&gt;  ln_extent_id number;&lt;br /&gt;  ls_object_name varchar2(30);&lt;br /&gt;  ls_owner varchar2(30);&lt;br /&gt;&lt;br /&gt;  PROCEDURE initialize&lt;br /&gt;  IS&lt;br /&gt;  BEGIN&lt;br /&gt;    DBMS_APPLICATION_INFO.SET_ACTION( 'rowid_info' );&lt;br /&gt;  END initialize;&lt;br /&gt;&lt;br /&gt;  PROCEDURE cleanup&lt;br /&gt;  IS&lt;br /&gt;  BEGIN&lt;br /&gt;     DBMS_APPLICATION_INFO.SET_MODULE(Null,Null);&lt;br /&gt;  END cleanup;&lt;br /&gt; BEGIN&lt;br /&gt;  initialize;&lt;br /&gt;  /*&lt;br /&gt;  Main body of program&lt;br /&gt;  */&lt;br /&gt;  debug.f('start by user %s', user);&lt;br /&gt;&lt;br /&gt;  select dbms_rowid.ROWID_BLOCK_NUMBER(p_rowid),&lt;br /&gt;       dbms_rowid.ROWID_RELATIVE_FNO(p_rowid),&lt;br /&gt;       dbms_rowid.ROWID_OBJECT(p_rowid)&lt;br /&gt;   into ln_block_id,ln_file_id,ln_object_id&lt;br /&gt;  from dual;&lt;br /&gt;&lt;br /&gt;  select owner,object_name&lt;br /&gt;   into ls_owner,ls_object_name&lt;br /&gt;  from dba_objects&lt;br /&gt;  where data_object_id=ln_object_id;&lt;br /&gt;&lt;br /&gt;  PIPE ROW('         rowid: '||p_rowid);&lt;br /&gt;  PIPE ROW('       file_id: '||ln_file_id);&lt;br /&gt;  PIPE ROW('      block_id: '||ln_block_id);&lt;br /&gt;  PIPE ROW('data_object_id: '||ln_object_id);&lt;br /&gt;&lt;br /&gt;  for c in (&lt;br /&gt;  select extent_id,&lt;br /&gt;   owner, segment_name,partition_name, segment_type,tablespace_name&lt;br /&gt;  from dba_extents&lt;br /&gt;  where&lt;br /&gt;   owner=ls_owner and&lt;br /&gt;   segment_name=ls_object_name and&lt;br /&gt;   file_id=ln_file_id and&lt;br /&gt;   ln_block_id between block_id and block_id + blocks - 1&lt;br /&gt;  )&lt;br /&gt;  loop&lt;br /&gt;   PIPE ROW('         owner: '||c.owner);&lt;br /&gt;   PIPE ROW('   object_name: '||c.segment_name);&lt;br /&gt;   PIPE ROW('partition_name: '||c.partition_name);&lt;br /&gt;   PIPE ROW('  segment_type: '||c.segment_type);&lt;br /&gt;   PIPE ROW('      tbs_name: '||c.tablespace_name);&lt;br /&gt;   PIPE ROW('     extent_id: '||c.extent_id);&lt;br /&gt;  end loop;&lt;br /&gt;&lt;br /&gt;  debug.f('process %s rows', SQL%RowCount);&lt;br /&gt;&lt;br /&gt;  cleanup;&lt;br /&gt; EXCEPTION&lt;br /&gt;  WHEN NO_DATA_NEEDED THEN&lt;br /&gt;    cleanup;&lt;br /&gt;    return;&lt;br /&gt;  WHEN OTHERS&lt;br /&gt;  THEN&lt;br /&gt;     /* Don't forget to clean up here, too! */&lt;br /&gt;     cleanup;&lt;br /&gt;&lt;br /&gt;     /* Standard error logging mechanism */&lt;br /&gt;     u$err.err;&lt;br /&gt;     RollBack;&lt;br /&gt;     raise;&lt;br /&gt; END rowid_info;&lt;br /&gt;&lt;br /&gt; PROCEDURE subprogram_name&lt;br /&gt; /*&lt;br /&gt; | Copyright Information Here&lt;br /&gt; |&lt;br /&gt; | File name:&lt;br /&gt; |&lt;br /&gt; | Overview:&lt;br /&gt; |&lt;br /&gt; | Author(s):&lt;br /&gt; |&lt;br /&gt; | Modification History:&lt;br /&gt; |   Date        Who         What&lt;br /&gt; |&lt;br /&gt; */&lt;br /&gt; IS&lt;br /&gt;  PROCEDURE initialize&lt;br /&gt;  IS&lt;br /&gt;  BEGIN&lt;br /&gt;    DBMS_APPLICATION_INFO.SET_ACTION( 'subprogram_name' );&lt;br /&gt;  END initialize;&lt;br /&gt;&lt;br /&gt;  PROCEDURE cleanup&lt;br /&gt;  IS&lt;br /&gt;  BEGIN&lt;br /&gt;     DBMS_APPLICATION_INFO.SET_MODULE(Null,Null);&lt;br /&gt;  END cleanup;&lt;br /&gt; BEGIN&lt;br /&gt;  initialize;&lt;br /&gt;  /*&lt;br /&gt;  Main body of program&lt;br /&gt;  */&lt;br /&gt;  debug.f('update %s rows', SQL%RowCount);&lt;br /&gt;&lt;br /&gt;  cleanup;&lt;br /&gt; EXCEPTION&lt;br /&gt;  WHEN OTHERS&lt;br /&gt;  THEN&lt;br /&gt;     /* Don't forget to clean up here, too! */&lt;br /&gt;     cleanup;&lt;br /&gt;&lt;br /&gt;     /* Standard error logging mechanism */&lt;br /&gt;     u$err.err;&lt;br /&gt;     --RollBack;&lt;br /&gt;     raise;&lt;br /&gt; END subprogram_name;&lt;br /&gt;&lt;br /&gt;BEGIN&lt;br /&gt;  initialize_pkg;&lt;br /&gt;END tb_obj; &lt;br /&gt;/&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;/pre&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-5677266441726583983?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/5677266441726583983/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=5677266441726583983' title='2 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/5677266441726583983'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/5677266441726583983'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/03/rowid-table-function.html' title='另一种方法显示ROWID扩充信息-table function'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>2</thr:total></entry><entry><id>tag:blogger.com,1999:blog-21821055.post-7749877569552401877</id><published>2009-03-31T11:02:00.000-07:00</published><updated>2009-03-31T13:11:56.677-07:00</updated><category scheme='http://www.blogger.com/atom/ns#' term='work'/><title type='text'>deprecated ROWID hint 废弃的行标识提示</title><content type='html'>在Oracle 10g以后,RowID 这个SQL提示就被废弃了.搜索Google也找不到替代方案.&lt;br /&gt;在一些应用场景里面利用RowID存取路径,还是很有帮助的. 比如回改, 就是在用户界面显示用户感兴趣的数据,数据被修改以后,再更新回数据库.&lt;br /&gt;&lt;br /&gt;那么怎样强制优化器使用存取路径TABLE ACCESS BY ROWID呢? 我暂时发现了两种方法:&lt;br /&gt;&lt;br /&gt;1) 使用No_Index SQL提示&lt;br /&gt;2) 使用表达式或者运算符禁止索引扫描.&lt;br /&gt;&lt;br /&gt;关于具体的搭建测试环境和演示, 参考文章&lt;a href="http://mujiang.blogspot.com/2009/02/noindex-hint-and-deprecated-rowid-hint.html"&gt;NO_INDEX hint and deprecated ROWID hint&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;测试结果&lt;br /&gt;--&lt;br /&gt;当查询优化器采用TABLE ACCESS BY USER ROWID存取路径时,我们发现逻辑读(Buffer列)由2降到1.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/21821055-7749877569552401877?l=zhu1.blogspot.com' alt='' /&gt;&lt;/div&gt;</content><link rel='replies' type='application/atom+xml' href='http://zhu1.blogspot.com/feeds/7749877569552401877/comments/default' title='Post Comments'/><link rel='replies' type='text/html' href='https://www.blogger.com/comment.g?blogID=21821055&amp;postID=7749877569552401877' title='0 Comments'/><link rel='edit' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7749877569552401877'/><link rel='self' type='application/atom+xml' href='http://www.blogger.com/feeds/21821055/posts/default/7749877569552401877'/><link rel='alternate' type='text/html' href='http://zhu1.blogspot.com/2009/03/deprecated-rowid-hint.html' title='deprecated ROWID hint 废弃的行标识提示'/><author><name>Charlie 1 木匠</name><uri>http://www.blogger.com/profile/14655756353501513388</uri><email>charlie.zhu1@gmail.com</email><gd:extendedProperty xmlns:gd='http://schemas.google.com/g/2005' name='OpenSocialUserId' value='14041361647388934325'/></author><thr:total xmlns:thr='http://purl.org/syndication/thread/1.0'>0</thr:total></entry></feed>