Web

MySQL的表类型和存储引擎

MySQL的表类型由存储引擎(Storage Engines)决定,类型包括MyISAM、innoDB、BDB等。

常用的存储引擎

MySQL 数据表主要支持六种类型 ,分别是:BDB、HEAP、ISAM、MERGE、MYISAM、InnoBDB。

这六种又分为两类,一类是"事务安全型"(transaction-safe),包括BDB和InnoDB;其余都属于第二类,称为"非事务安全型"(non-transaction-safe)。

BDB 全称是"Brekeley DB",它是Mysql最早的具有事务能力的表的类型,由Sleepycat Software (http://www.sleepycat.com)开发。它提供了事务控制能力功能,它确保一组命令全部执行成功,或者当任何一个命令出现错误时所有命令的结果都被回退,可以想像在电子银行中事务控制能力是非常重要的。支持COMMIT、ROLLBACK和其他事务特性。最新版本的Mysql已经计划移除对BDB的支持,转而全力发展InnoDB。

(更多…)

Emeric lee
Web

使用Xdebug调试PHP程序

XDebug是个好东西啊,用来调试PHP程序的,可以和Eclipse配合。

配置步骤:(Windows+Apache+php环境)

1.下载和PHP版本环境相适应的XDebug版本,放置于PHP目录,主要None-ThreadSafe版似乎是用来在CLI方式下使用的,一般不需要

2.修改php.ini文件,参考如下

[Xdebug]
;zend_extension_ts	= "D:\server\php5\ext\php_xdebug-2.0.5-5.3-vc6.dll"
;发现在PHP5.3+Apache(CGI)方式下,似乎必须使用 zend_extension 加载才能成功
zend_extension		= "D:\server\php5\ext\php_xdebug-2.0.5-5.3-vc6-nts.dll"

xdebug.auto_trace		= off		;开启自动跟踪

xdebug.remote_autostart		= off		;开启远程调试自动启动
xdebug.remote_enable		= 1
xdebug.remote_host		= 10.5.184.251
xdebug.remote_port		= 9000
;xdebug.remote_handler		= “dbgp”

xdebug.show_exception_trace	= On		;开启异常跟踪

xdebug.collect_vars		= On		;收集变量
xdebug.collect_return		= On		;收集返回值
xdebug.collect_params		= On		;收集参数

注意:remote_host应该填写远程调试机的地址,而不是PHP服务器的地址,在Xdebug运行方式下,调试工具实际是调试过程的服务端,Xdebug会主动连接指定的remoete_host,从而建立调试通讯。所以要注意调试机的防火墙问题


3.配置调试工具,Eclipse就很好用,具体不说了,摸索下就可以了

(更多…)

Emeric lee
Web

从“UML何时死掉”谈起(转)

从“UML何时死掉”谈起 - 技术开发 | IT168.

【IT168 技术文章】得了一个机会(1),我问Ivar:“UML什么时候才会死掉呀”。我无意用这个透着促狭味道的问题去为难大师,实在是因为这是我一直以来思考着的问题。向UML之父去求解,自然是最好。

Ivar细毫没有认为我是在为难他,他诚恳的回答让我在那个会议中陷入了深思。他说:“什么时候面向对象死掉了,UML就死掉了”。(2)

一个问题看起来很复杂,但它的答案可能非常简单。一个答案看起来非常简单,但它可能是最正确的。一个正确的答案,也许毫无意义,但也许,那就是大师的答案。

很多我们现在看起来是非常“理所当然”的事情,就曾经困扰着大师们。比如说,我们现在都知道程序的基本逻辑是顺序、分支与循环。那么,“为什么顺序、分支与循环是基本逻辑呢”?“作为基本逻辑,它们充备吗?”谁能回答我?如何回答我?

(更多…)

Emeric lee
Web

UML关系定义的解析及思维导向图

对UML的关系定义一直有点感觉混乱,这是一天的学习总结,主要成果是下面的这张图,这张图没有按照一般的 Has a / Use a / Is a的3类法进行分类,而是把 Has a 作为了 Use a的一个子集来分析。因为没有看到任何其他参考资料使用了这种方式,所以这种方法未必完全准确,仅供参考。


[caption id="attachment_259" align="aligncenter" width="500" caption="UML关系解析思维导向图"]UML关系解析思维导向图[/caption]


(更多…)

Emeric lee
Web

表格的标准化写法

HMTL中表格标准写法的一个比较完整的实例,仅供参考

结合了thead,tfoot,th的应用,还有CSS控制表格
注意:

  1. tfoot在fbody前面
  2. td,th,tr,thead,tfoot,tbody都可以省略结束标记
  3. th不仅仅用在表头中
Title = = = = =
= = = = = =
B - - - - +
B - - - - +
B - - - - +
B - - - - +
B - - - - +

Wordpress在保存会自作聪明的做一些源码改写操作,同时上面的表格也会受到wordpress本身的CSS影响,所以代码请以下面部分的源码为准

(更多…)

Emeric lee
Web

Linux入门-软件管理篇(APT)

APT 软件安装管理系统,Debian下的系统软件安装管理工作 除非你确实知道你在什么,请一直保持使用APT相关工具来管理软件,而不要使用其它工具或方式。 准备工作 使用APT安装更新系统前,首先

  • 确保网络或其它来源(光盘等)可用
  • 如果使用网络镜像,请手动或自动选择最快的网络镜像来源
    #自动方式
    #参见下面的apt-spy
    
    #手动方式
    vim /etc/apt/sources.list
    
    (更多…)

    Emeric lee
    Web

    Linux入门-用户管理篇

    管理用户(user)和用户组(group)的相关工具或命令

    • 基本查询命令
      • w
      • who
      • id
      • finger
        默认似乎不安装的,手动安装:apt-get install finger
      • cat /etc/passwd
        可以查看所有用户的列表(难倒没有别的办法了吗?震惊ing)
      • cat /etc/group
        查看用户组

    (更多…)

    Emeric lee
    Web

    Linux入门-终端环境(bash)设置篇

    Bash是Debian的默认SHELL,设置终端环境(bash)使Bash更好地为我们服务,我们需定制bash shell环境,这里讲述bash用户环境配置。 bash_profile、.bashrc、和.bash_logout 上面这三个文件是bash shell的用户环境配置文件,位于用户的主目录下。注意bash_profile、.bash_logout并不总是存在,至少Debian中就没有默认创建 (更多…)

    Emeric lee
    Web

    linux入门-系统时间设置篇

    是的,没错,linux的时间设置需要专门写一篇来说明!

    date #显示系统当前本地时间

    STEP1:设定硬件时钟(BIOS)

    debian/linux默认认为BIOS时间是世界时间(UTC),BOIS一般实际设置的是本地时间,所以需要修改它(特别在VmWare等虚拟机环境下)

    #编辑rcS,设置UTC=no,告诉系统,硬件时间是否为UTC时间
    #BIOS=本地时间,UTC=no
    #BIOS=UTC时间,UTC=yes
    vim /etc/default/rcS
    
    #其它相关的命令:
    hwclock --show --utc        #显示当前硬件时钟,硬件时钟假定为UTC时间
    hwclock --show --localtime  #显示当前硬件时钟,硬件时钟假定为本地时间
    hwclock                     #也可以用来设置硬件时间
    

    (更多…)

    Emeric lee
    Web

    Linux入门-文本编辑器篇(VI VIM)

    文本编辑器有很多,比如图形模式的gedit、kwrite、OpenOffice ... ... ,文本模式下的编辑器有vi、vim(vi的增强版本)和nano ... ... vi和vim是我们在Linux中最常用的编辑器。我们有必要介绍一下vi(vim)最简单的用法,以让Linux入门级用户在最短的时间内学会使用它。

    nano 工具和DOS操作系统下的edit操作相似,使用简单,我们不作介绍了,如果您有兴趣,不妨尝试一下;

    本文以Debian版Linux作为测试系统。

    大部分Linux系统默认都安装了一个缩水版的VIM,同时使用VI命令时会以兼容方式启动这个缩水版的VIM。缩水版的VIM在一些功能上和完整版有区别,特别是在插入模式下的光标移动,推荐安装完整版的VIM

     apt install vim

    (更多…)

    Emeric lee
    Web

    Windows平台下Apache+PHP4+PHP5+FastCGI安装笔记

    修正:2010.3

    1.PHP自5.3版起默认不在支持针对Windows的VC6编译版本,只提供VC9版本的,而APAche官方提供的Apache Windows编译包都是VC6的。所以我们需要使用第三方编译的VC9版本的Apache。 2.PHP 的 None Thread Safe 版本适用于CGI/FastCGI方式,而相应的Thread Safe版本适用于SAPI和Mod方式 3. http://www.apachelounge.com/download/ 这里提供了大量适用于Windows的LAMP有关预编译包,包括VC9版本的Apache和FastCGI,这个网站也是PHP官方推荐的网站。

    原文

    Go PHP5

    很多开发组织已经开始参与到 Go PHP5 的活动中来了,PHP官方也早已经声明于2007年底停止对PHP4的所有技术支持,看来PHP5/6的广泛应用已经是不可抗拒的浪潮了,仅仅是时间问题,而且时间不会太长。

    Apache+PHP+FastCGI

    对于目前的过渡阶段,很多开发者还是需要一个可以实现PHP4和PHP5共存的开发环境,这两天尝试在Windows下使用APACHE环境配置了一个PHP4和PHP5共存的环境,请注意:此配置使用 CGI 运行方式,而没有使用常见的 Apache modules 方式。我曾经尝试使用 Apache modules方式配置双PHP,但没有成功。 关键特性:
    1. Windows+Apache+PHP(Apache2.0下测试)
    2. PHP4+PHP5共存
    3. FastCGI
    以下是配置中用到的Apache Conf: (更多…)

    Emeric lee