首页 | 新闻 | 交流 | 问吧 | 文档 | 手册 | 下载 | 博客

收藏此问题 发表新评论

Mysql 5.0存储过程技术资料

        Mysql存储过程手册,希望大家能够喜欢!

        针对目前很多网友下载不回帖现象,本帖需要回复才能下载,请谅解!

        
昵称: 山猫  时间: 2009-08-08 22:34:00
不错顶下
昵称: 287958270  时间: 2009-08-09 08:03:00
下来看看
昵称: 287958270  时间: 2009-08-09 08:04:00
好东西 正需要呢 楼主真好
昵称: 287958270  时间: 2009-08-09 08:07:00
ding
昵称: asd12fg  时间: 2009-08-09 08:12:00
学习一下!!!!!!!!
昵称: dirall  时间: 2009-08-09 10:24:00
谢谢,共享
昵称: winting  时间: 2009-08-09 10:56:00
谢谢,共享
昵称: 263290692  时间: 2009-08-09 11:36:00
谢谢分享~~~~
昵称: juanjuan  时间: 2009-08-10 08:26:00
看看
昵称: evil  时间: 2009-08-10 22:34:00
哈哈哈哈,好东西
昵称: kuso  时间: 2009-08-11 00:04:00
看看那
昵称: 125636329  时间: 2009-08-14 11:14:00
顶,学习
昵称: gf751122  时间: 2009-08-15 09:55:00
辛苦了!     
昵称: qiangfeng03  时间: 2009-08-15 13:39:00
......狂顶
昵称: 潮洲蜘蛛  时间: 2009-08-15 17:04:00
看看,,,
昵称: hxprince  时间: 2009-08-16 13:59:00
我也想看一下
昵称: zhouitpro  时间: 2009-08-16 20:38:00
学习一下~~
昵称: ly77289  时间: 2009-08-17 23:22:00
顶顶!
昵称: 柚子猫  时间: 2009-08-20 11:34:00
不错不错啊。php就是好啊
昵称: 123123  时间: 2009-08-22 16:02:00
学习学习
昵称: 123123  时间: 2009-08-22 16:04:00
加油加油啦
昵称: 123123  时间: 2009-08-22 16:05:00
看一看,
昵称: zzzsx5903  时间: 2009-08-22 19:16:00
ding 一下
昵称: micht767  时间: 2009-08-23 15:32:00
看看
昵称: ufo456  时间: 2009-08-24 21:52:00
kkkkkkkk
kllllllll
昵称: lgp12357  时间: 2009-08-28 15:52:00
顶一下
昵称: any  时间: 2009-08-28 20:35:00
DDDDDDDDDDDDDD
昵称: jscsmax  时间: 2009-08-29 11:39:00
下来看看
昵称: qawsplok  时间: 2009-08-31 13:30:00
昵称: weblcl  时间: 2009-09-03 14:40:00
看看
昵称: baoq  时间: 2009-09-03 15:23:00
还需要威望啊
昵称: baoq  时间: 2009-09-03 15:24:00
看看
昵称: baoq  时间: 2009-09-03 15:24:00
昵称: wangjun0511  时间: 2009-09-03 16:14:00
sdfsdfsaf
昵称: wangjun0511  时间: 2009-09-03 16:14:00
8错
昵称: 358749545  时间: 2009-09-05 16:08:00
我路过,不小心看到楼主发了这么好的东西,特意来放虫子!
昵称: 游天小虾  时间: 2009-09-07 15:22:00
ddddddddddddddddddddddddddddddd
昵称: aiwbg2005  时间: 2009-09-11 10:16:00
俺要看看吗,给俺看看吗,俺的威望怎么就差一点
昵称: aiwbg2005  时间: 2009-09-11 10:17:00
回帖先
昵称: aiens  时间: 2009-09-11 10:41:00
瞧瞧
昵称: justgame  时间: 2009-09-12 00:44:00
顶,好东西,很不错的说一声
昵称: qbd1313  时间: 2009-09-14 04:06:00
昵称: xiaoke  时间: 2009-09-15 09:53:00
很好,谢谢``
昵称: listcvc  时间: 2009-09-16 13:36:00
正想学习
昵称: lyic_lee  时间: 2009-09-16 16:55:00
正需要,非常感激
昵称: 亮仔仔  时间: 2009-09-16 17:45:00
需要威望:10 ,再发一次
昵称: 亮仔仔  时间: 2009-09-16 17:46:00
学习了。!谢谢了!
昵称: 非常电电  时间: 2009-09-17 10:30:00
昵称: 海角  时间: 2009-09-19 01:42:00
下载不了
昵称: 海角  时间: 2009-09-19 01:43:00
asdfasdf
昵称: yuhuaan  时间: 2009-09-21 13:37:00
昵称: zhangheng  时间: 2009-09-21 19:48:00
昵称: zhangheng  时间: 2009-09-21 19:49:00
昵称: zhangheng  时间: 2009-09-21 19:49:00
  
昵称: zhangheng  时间: 2009-09-21 19:50:00
昵称: zhangheng  时间: 2009-09-21 19:50:00
昵称: zhangheng  时间: 2009-09-21 19:51:00
昵称: zhangheng  时间: 2009-09-21 19:51:00
昵称: yilufei2006  时间: 2009-09-21 22:03:00
    
昵称: echo  时间: 2009-09-22 17:21:00
      
昵称: eavx  时间: 2009-09-22 23:48:00
昵称: sweet  时间: 2009-09-23 14:27:00
以前学过.net的存储过程,没想php里也有,是个好东东,
昵称: fen115573167  时间: 2009-09-23 16:13:00
回复
昵称: zhanglitao  时间: 2009-09-23 17:04:00
不错顶下
昵称: jiasongpo  时间: 2009-09-27 10:33:00
看看啊。。。
昵称: aivyzh5  时间: 2009-09-27 11:00:00
快下来看看
昵称: rong528  时间: 2009-09-27 11:24:00
    
昵称: fg352l  时间: 2009-09-27 11:42:00
不错顶下
昵称: whirlyzhq  时间: 2009-09-28 15:37:00
好东西
昵称: hjllove  时间: 2009-09-28 15:56:00
怎么那么麻烦啊,知识共享嘛
昵称: ajax2006  时间: 2009-09-28 17:19:00
太麻烦啦~~~~~~~~~~~~~~~~~~~~~······
昵称: ajax2006  时间: 2009-09-28 17:21:00
顶~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
昵称: ajax2006  时间: 2009-09-28 17:21:00
顶~~~~~~~~~~~~~~~~~~
昵称: ajax2006  时间: 2009-09-28 17:22:00
顶~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
昵称: ajax2006  时间: 2009-09-28 17:23:00
顶~~~~~~~~~~~~~~~~~~~~~~~~~~~~
昵称: ajax2006  时间: 2009-09-28 17:23:00
顶~~~~~~~~~~~~~~~~~~~~~~~~~~
昵称: ajax2006  时间: 2009-09-28 17:23:00
再顶~~~~~~~~~
昵称: ajax2006  时间: 2009-09-28 17:24:00
顶~~
昵称: ajax2006  时间: 2009-09-28 17:24:00
顶~~~
昵称: ajax2006  时间: 2009-09-28 17:24:00
谢谢,楼主。
昵称: 卡拉  时间: 2009-09-28 17:25:00
学习一下!!!!!!!!
昵称: hi_listen  时间: 2009-09-29 15:42:00
支持一下,下载来有空看。
昵称: shenghongzhi  时间: 2009-09-29 21:59:00
好东西,不用回复得到也要回复
昵称: wxlianxi  时间: 2009-10-01 11:06:00
看看
昵称: ljm  时间: 2009-10-01 15:39:00
Mysql存储过程手册,希望大家能够喜欢!

        针对目前很多网友下载不回帖现象,本帖需要回复才能下载,请谅解!
昵称: iphpmysql  时间: 2009-10-01 19:16:00
 喜欢~~~
昵称: somlan  时间: 2009-10-01 22:33:00
????????????
昵称: irw  时间: 2009-10-03 15:44:00
????????????????
昵称: irw  时间: 2009-10-03 15:54:00
好东西就是要支持
昵称: rcook  时间: 2009-10-05 11:00:00
            
昵称: wjt85601986  时间: 2009-10-05 11:43:00
我来看下可以不
昵称: 5555  时间: 2009-10-05 14:18:00
回帖~~~~~~~~~~~
昵称: xj199241  时间: 2009-10-05 20:29:00
ddddddddd
昵称: hmily  时间: 2009-10-07 00:43:00
谢谢!
昵称: 472559561  时间: 2009-10-07 14:32:00
   顶起来猫猫
昵称: wangtaoya  时间: 2009-10-08 15:41:00
kankan
昵称: bachosy  时间: 2009-10-08 17:25:00
多舒服撒
昵称: hly1120  时间: 2009-10-09 11:05:00
昵称: pmdmq  时间: 2009-10-09 15:20:00
      
昵称: php2002  时间: 2009-10-09 15:34:00
昵称: rote  时间: 2009-10-09 23:39:00
昵称: edward52  时间: 2009-10-10 19:19:00
找很久啦 !
昵称: zhangrongxi5  时间: 2009-10-14 09:04:00
下载必须得回复!
昵称: a00514  时间: 2009-10-17 16:29:00
好贴就应该顶上去!
昵称: jinjinle  时间: 2009-10-18 03:29:00
  
昵称: itgay  时间: 2009-10-18 21:59:00
研究研究```
昵称: zhouguang56  时间: 2009-10-20 09:58:00
fdsfdsg
昵称: shui_guai  时间: 2009-10-20 10:30:00
顶顶!!!!!!!!!!!!
昵称: lbb  时间: 2009-10-20 15:09:00
肯定要的啊  回复顶你
昵称: seoerdream  时间: 2009-10-22 13:15:00
谢了
昵称: 祥子  时间: 2009-10-22 17:16:00
我也顶下了
昵称: 5555  时间: 2009-10-25 11:08:00
aaaaaaaaaaaaaaaaaaaaaaaaa
昵称: bopo  时间: 2009-10-26 12:19:00
刚学习MYSQL。支持
昵称: aoaoaiqi  时间: 2009-10-26 14:59:00
顶~~~~
昵称: shideqin  时间: 2009-10-28 16:42:00
葵花宝典。。。
昵称: chengxj889  时间: 2009-10-30 09:00:00
下来看看
昵称: smilewit  时间: 2009-10-31 14:41:00
呵呵呵,好东西,正缺呢
昵称: denghai  时间: 2009-10-31 21:28:00
瞅瞅
昵称: birth0529  时间: 2009-11-01 15:25:00
学习一下!!!!!!!!
昵称: luke  时间: 2009-11-02 12:24:00
学习一下
昵称: lee_php100  时间: 2009-11-02 17:15:00
很好 很不错
昵称: shexlove  时间: 2009-11-05 14:15:00
强大
昵称: shexlove  时间: 2009-11-05 14:19:00
威望是什么
昵称: shexlove  时间: 2009-11-05 14:21:00
我要我的威望
昵称: shexlove  时间: 2009-11-05 14:29:00
估计这次因该是9
昵称: shexlove  时间: 2009-11-05 14:31:00
好了 感谢楼猪
昵称: shexlove  时间: 2009-11-05 14:31:00
good
昵称: wanking0518  时间: 2009-11-05 16:39:00
谢谢 楼主
昵称: love3245293  时间: 2009-11-05 18:44:00
昵称: ecpt  时间: 2009-11-06 11:48:00
CCCC
昵称: wangwen1120  时间: 2009-11-07 23:43:00
      
昵称: liuqzhi110  时间: 2009-11-08 10:40:00
人性化回帖
昵称: aoaoaiqi  时间: 2009-11-10 14:39:00
Let me see it first!
昵称: caizhongquan  时间: 2009-11-11 08:53:00
看看哈
昵称: ysc690026213  时间: 2009-11-15 22:13:00
顶顶顶
昵称: feng54074  时间: 2009-11-18 10:22:00
ddddddddddd
昵称: xiasha11  时间: 2009-11-18 15:50:00
支持一下下。
昵称: huanleicool  时间: 2009-11-18 20:33:00
为什么我下不了的??
昵称: guoyanxiang  时间: 2009-11-18 20:41:00
好东西
昵称: haide168  时间: 2009-11-18 22:08:00
正在学习当中,看一下
昵称: yetur  时间: 2009-11-20 08:48:00
   学习下。
昵称: xincui237  时间: 2009-11-20 09:44:00
看看
昵称: xiaopong  时间: 2009-11-20 10:42:00
ding shang
昵称: 447639089  时间: 2009-11-20 13:58:00
昵称: ufofans  时间: 2009-11-23 17:36:00
下载学习一下
昵称: tt.php  时间: 2009-11-24 11:02:00
性能优化(概述)哈哈,看看是什么好东西
昵称: abcvw  时间: 2009-11-24 12:04:00
还没用过呢  
昵称: eyoukey  时间: 2009-11-25 16:35:00
ddddddddddddddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:58:00
ddddddddddddddddddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:58:00
ddddddddddddddddddddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:58:00
dddddddddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:58:00
dddddddddddddddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:58:00
ddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:58:00
daaaaaaaaaaaaaaaaaaaa
昵称: mikey1  时间: 2009-11-27 15:59:00
dddddddddddddddddddddddddddddd
昵称: mikey1  时间: 2009-11-27 15:59:00
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb
昵称: mikey1  时间: 2009-11-27 15:59:00
回帖是规矩
昵称: ren1115  时间: 2009-11-27 17:41:00
看下是怎么存储的
昵称: txjcv  时间: 2009-11-28 10:16:00
Re:Mysql 5.0存储过程技术资料
昵称: koogle  时间: 2009-11-28 18:53:00
看看
昵称: ming3721  时间: 2009-11-29 11:56:00
昵称: xuandun  时间: 2009-11-29 18:37:00
好啊,我一直想要整理下,一直没有时间,现在也可以参考你的一下了,谢谢
昵称: alkz  时间: 2009-11-29 21:05:00
不错哦  
昵称: userand  时间: 2009-12-01 13:18:00
看下这个
昵称: liaomars  时间: 2009-12-01 14:58:00
let me have a look!
昵称: lenush  时间: 2009-12-01 16:16:00
eee
昵称: zengzhaolin  时间: 2009-12-01 16:53:00
谢谢啊
昵称: jobo  时间: 2009-12-01 17:06:00
回一个
看一看
昵称: 冯岩  时间: 2009-12-05 22:54:00
天,威望不够
昵称: 冯岩  时间: 2009-12-05 22:55:00
正需要  谢谢啦!
昵称: 飘飘拳  时间: 2009-12-06 11:36:00
顶~回帖是一种美德~~
昵称: xlmxbg  时间: 2009-12-06 13:11:00
什么东西,看看
昵称: lc13579443  时间: 2009-12-09 11:13:00
haohao
昵称: ywjw  时间: 2009-12-09 22:47:00
谢谢分享
昵称: vick123  时间: 2009-12-10 16:11:00
刚好需要,谢谢
昵称: @szsming  时间: 2009-12-10 16:36:00
不错,支持一下
昵称: php100.com  时间: 2009-12-11 07:46:00
好的
昵称: 1123mylove  时间: 2009-12-11 11:32:00
威望少了啊 要多发发才行
昵称: 1123mylove  时间: 2009-12-11 11:33:00
威望少了啊 要多发发才行
昵称: 1123mylove  时间: 2009-12-11 11:33:00
谢谢非常
昵称: bingqi1008  时间: 2009-12-14 14:54:00
ding
昵称: dwx1011  时间: 2009-12-14 21:14:00
学习下
昵称: benteng2010  时间: 2009-12-15 12:19:00
好好好
昵称: yuezhishang  时间: 2009-12-15 13:30:00
看看 收藏一下先
昵称: 只是因为  时间: 2009-12-16 15:03:00
飞尝感谢......
昵称: outright  时间: 2009-12-17 22:20:00
下载不回帖又怎么了
昵称: zzh1989829  时间: 2009-12-18 16:54:00
昵称: changshajh  时间: 2009-12-18 23:10:00
学习一下!!!!!!!!
昵称: changshajh  时间: 2009-12-18 23:16:00
学习一下!!!!!!!!
昵称: changshajh  时间: 2009-12-18 23:17:00
不错顶下
昵称: changshajh  时间: 2009-12-18 23:18:00
不错顶下
昵称: changshajh  时间: 2009-12-18 23:18:00
不错顶下
昵称: changshajh  时间: 2009-12-18 23:19:00
不错顶下
昵称: changshajh  时间: 2009-12-18 23:19:00
不错顶下
昵称: changshajh  时间: 2009-12-18 23:20:00
看一下是啥好东西。。。
昵称: id128  时间: 2009-12-19 10:22:00
看看...............
昵称: hotdiablo  时间: 2009-12-19 23:46:00
111
昵称: xiongsd  时间: 2009-12-22 09:18:00
顶顶更健康
昵称: kissmejj126  时间: 2009-12-23 10:26:00
学习!!!
昵称: znza  时间: 2009-12-23 21:01:00
看看          
昵称: kaleng  时间: 2009-12-24 00:25:00
看看
昵称: pheadxp  时间: 2009-12-25 00:08:00
回帖 学习
昵称: zzhqhappy  时间: 2009-12-28 09:34:00
look op
昵称: inuex  时间: 2009-12-28 20:42:00
太小气了吧,还要10威望  
昵称: inuex  时间: 2009-12-28 20:44:00
给哥看看
昵称: dongdong1237  时间: 2009-12-29 11:43:00
支持
昵称: 设计源泉  时间: 2009-12-29 16:42:00
一、我们可以且应该优化什么?
硬件
操作系统/软件库
SQL服务器(设置和查询)
应用编程接口(API)
应用程序
--------------------------------------------------------------------------------
二、优化硬件
如果你需要庞大的数据库表(>2G),你应该考虑使用64位的硬件结构,像Alpha、Sparc或即将推出的IA64。因为MySQL内部使用大量64位的整数,64位的CPU将提供更好的性能。
对大数据库,优化的次序一般是RAM、快速硬盘、CPU能力。
更多的内存通过将最常用的键码页面存放在内存中可以加速键码的更新。
如果不使用事务安全(transaction-safe)的表或有大表并且想避免长文件检查,一台UPS就能够在电源故障时让系统安全关闭。
对于数据库存放在一个专用服务器的系统,应该考虑1G的以太网。延迟与吞吐量同样重要。
--------------------------------------------------------------------------------
三、优化磁盘
为系统、程序和临时文件配备一个专用磁盘,如果确是进行很多修改工作,将更新日志和事务日志放在专用磁盘上。
低 寻道时间对数据库磁盘非常重要。对与大表,你可以估计你将需要log(行数)/log(索引块长度/3*2/(键码长度 + 数据指针长度))+1次寻到才能找到一行。对于有500000行的表,索引Mediun int类型的列,需要log(500000) / log(1024/3*2/(3 + 2))+1=4次寻道。上述索引需要500000*7*3/2= 5.2M的空间。实际上,大多数块将被缓存,所以大概只需要1-2次寻道。
然而对于写入(如上),你将需要4次寻道请求来找到在哪里存放新键码,而且一般要2次寻道来更新索引并写入一行。
对于非常大的数据库,你的应用将受到磁盘寻道速度的限制,随着数据量的增加呈N log N数据级递增。
将数据库和表分在不同的磁盘上。在MySQL中,你可以为此而使用符号链接。
条列磁盘(RAID 0)将提高读和写的吞吐量。
带镜像的条列(RAID 0+1)将更安全并提高读取的吞吐量。写入的吞吐量将有所降低。
不要对临时文件或可以很容易地重建的数据所在的磁盘使用镜像或RAID(除了RAID 0)。
在Linux上,在引导时对磁盘使用命令hdparm -m16 -d1以启用同时读写多个扇区和DMA功能。这可以将响应时间提高5~50%。
在Linux上,用async (默认)和noatime挂载磁盘(mount)。
对于某些特定应用,可以对某些特定表使用内存磁盘,但通常不需要。
--------------------------------------------------------------------------------
四、优化操作系统
不要交换区。如果内存不足,增加更多的内存或配置你的系统使用较少内存。
不要使用NFS磁盘(会有NFS锁定的问题)。
增加系统和MySQL服务器的打开文件数量。(在safe_mysqld脚本中加入ulimit -n #)。
增加系统的进程和线程数量。
如果你有相对较少的大表,告诉文件系统不要将文件打碎在不同的磁道上(Solaris)。
使用支持大文件的文件系统(Solaris)。
选择使用哪种文件系统。在Linux上的Reiserfs对于打开、读写都非常快。文件检查只需几秒种。
--------------------------------------------------------------------------------
五、选择应用编程接口
PERL
可在不同的操作系统和数据库之间移植。
适宜快速原型。
应该使用DBI/DBD接口。
PHP
比PERL易学。
使用比PERL少的资源。
通过升级到PHP4可以获得更快的速度。
C
MySQL的原生接口。
较快并赋予更多的控制。
低层,所以必须付出更多。
C++
较高层次,给你更多的时间来编写应用。
仍在开发中
ODBC
运行在Windows和Unix上。
几乎可在不同的SQL服务器间移植。
较慢。MyODBC只是简单的直通驱动程序,比用原生接口慢19%。
有很多方法做同样的事。很难像很多ODBC驱动程序那样运行,在不同的领域还有不同的错误。
问题成堆。Microsoft偶尔还会改变接口。
不明朗的未来。(Microsoft更推崇OLE而非ODBC)
ODBC
运行在Windows和Unix上。
几乎可在不同的SQL服务器间移植。
较慢。MyODBC只是简单的直通驱动程序,比用原生接口慢19%。
有很多方法做同样的事。很难像很多ODBC驱动程序那样运行,在不同的领域还有不同的错误。
问题成堆。Microsoft偶尔还会改变接口。
不明朗的未来。(Microsoft更推崇OLE而非ODBC)
JDBC
理论上可在不同的操作系统何时据库间移植。
可以运行在web客户端。
Python和其他
可能不错,可我们不用它们。
--------------------------------------------------------------------------------
六、优化应用
应该集中精力解决问题。
在编写应用时,应该决定什么是最重要的:
速度
操作系统间的可移植性
SQL服务器间的可移植性
使用持续的连接。.
缓存应用中的数据以减少SQL服务器的负载。
不要查询应用中不需要的列。
不要使用SELECT * FROM table_name...
测试应用的所有部分,但将大部分精力放在在可能最坏的合理的负载下的测试整体应用。通过以一种模块化的方式进行,你应该能用一个快速"哑模块"替代找到的瓶颈,然后很容易地标出下一个瓶颈。
如果在一个批处理中进行大量修改,使用LOCK TABLES。例如将多个UPDATES或DELETES集中在一起。
--------------------------------------------------------------------------------
七、应该使用可移植的应用
Perl DBI/DBD
ODBC
JDBC
Python(或其他有普遍SQL接口的语言)
你应该只使用存在于所有目的SQL服务器中或可以很容易地用其他构造模拟的SQL构造。www.mysql.com上的Crash-me页可以帮助你。
为操作系统/SQL服务器编写包装程序来提供缺少的功能。
--------------------------------------------------------------------------------
八、如果你需要更快的速度,你应该:
找出瓶颈(CPU、磁盘、内存、SQL服务器、操作系统、API或应用)并集中全力解决。
使用给予你更快速度/灵活性的扩展。
逐渐了解SQL服务器以便能为你的问题使用可能最快的SQL构造并避免瓶颈。
优化表布局和查询。
使用复制以获得更快的选择(select)速度。
如果你有一个慢速的网络连接数据库,使用压缩客户/服务器协议。
不要害怕时应用的第一个版本不能完美地移植,在你解决问题时,你总是可以在以后优化它。
--------------------------------------------------------------------------------
九、优化MySQL
挑选编译器和编译选项。
位你的系统寻找最好的启动选项。
通读MySQL参考手册并阅读Paul DuBios的《MySQL》一书。(已有中文版-译注)
多用EXPLAIN SELECT、SHOW VARIABLES、SHOW STATUS和SHOW PROCESSLIST。
了解查询优化器的工作原理。
优化表的格式。
维护你的表(myisamchk、CHECK TABLE、 OPTIMIZE TABLE)
使用MySQL的扩展功能以让一切快速完成。
如果你注意到了你将在很多场合需要某些函数,编写MySQL UDF函数。
不要使用表级或列级的GRANT,除非你确实需要。
购买MySQL技术支持以帮助你解决问题:)
--------------------------------------------------------------------------------
十、编译和安装MySQL
通过位你的系统挑选可能最好的编译器,你通常可以获得10-30%的性能提高。
在Linux/Intel平台上,用pgcc(gcc的奔腾芯片优化版)编译MySQL。然而,二进制代码将只能运行在Intel奔腾CPU上。
对于一种特定的平台,使用MySQL参考手册上推荐的优化选项。
一般地,对特定CPU的原生编译器(如Sparc的Sun Workshop)应该比gcc提供更好的性能,但不总是这样。
用你将使用的字符集编译MySQL。
静态编译生成mysqld的执行文件(用--with-mysqld-ldflags=all-static)并用strip sql/mysqld整理最终的执行文件。
注意,既然MySQL不使用C++扩展,不带扩展支持编译MySQL将赢得巨大的性能提高。
如果操作系统支持原生线程,使用原生线程(而不用mit-pthreads)。
用MySQL基准测试来测试最终的二进制代码。
--------------------------------------------------------------------------------
十一、维护
如果可能,偶尔运行一下OPTIMIZE table,这对大量更新的变长行非常重要。
偶尔用myisamchk -a更新一下表中的键码分布统计。记住在做之前关掉MySQL。
如果有碎片文件,可能值得将所有文件复制到另一个磁盘上,清除原来的磁盘并拷回文件。
如果遇到问题,用myisamchk或CHECK table检查表。
用mysqladmin -i10 precesslist extended-status监控MySQL的状态。
用MySQL GUI客户程序,你可以在不同的窗口内监控进程列表和状态。
使用mysqladmin debug获得有关锁定和性能的信息。
--------------------------------------------------------------------------------
十二、优化SQL
扬SQL之长,其它事情交由应用去做。使用SQL服务器来做:
找出基于WHERE子句的行。
JOIN表
GROUP BY
ORDER BY
DISTINCT
不要使用SQL来做:
检验数据(如日期)
成为一只计算器
技巧:
明智地使用键码。
键码适合搜索,但不适合索引列的插入/更新。
保持数据为数据库第三范式,但不要担心冗余信息或这如果你需要更快的速度,创建总结表。
在大表上不做GROUP BY,相反创建大表的总结表并查询它。
UPDATE table set count=count+1 where key_column=constant非常快。
对于大表,或许最好偶尔生成总结表而不是一直保持总结表。
充分利用INSERT的默认值。
--------------------------------------------------------------------------------
十三、不同SQL服务器的速度差别(以秒计)
 
通过键码读取2000000行: NT Linux
mysql 367 249
mysql_odbc 464  
db2_odbc 1206  
informix_odbc 121126  
ms-sql_odbc 1634  
oracle_odbc 20800  
solid_odbc 877  
sybase_odbc 17614  
 
插入350768行: NT Linux
mysql 381 206
mysql_odbc 619  
db2_odbc 3460  
informix_odbc 2692  
ms-sql_odbc 4012  
oracle_odbc 11291  
solid_odbc 1801  
sybase_odbc 4802  
在上述测试中,MySQL配置8M高速缓存运行,其他数据库以默认安装运行。
--------------------------------------------------------------------------------
十四、重要的MySQL启动选项
back_log 如果需要大量新连接,修改它。
thread_cache_size 如果需要大量新连接,修改它。
key_buffer_size 索引页池,可以设成很大。
bdb_cache_size BDB表使用的记录和键吗高速缓存。
table_cache 如果有很多的表和并发连接,修改它。
delay_key_write 如果需要缓存所有键码写入,设置它。
log_slow_queries 找出需花大量时间的查询。
max_heap_table_size 用于GROUP BY
sort_buffer 用于ORDER BY和GROUP BY
myisam_sort_buffer_size 用于REPAIR TABLE
join_buffer_size 在进行无键吗的联结时使用。
--------------------------------------------------------------------------------
十五、优化表
MySQL拥有一套丰富的类型。你应该对每一列尝试使用最有效的类型。
ANALYSE过程可以帮助你找到表的最优类型:SELECT * FROM table_name PROCEDURE ANALYSE()。
对于不保存NULL值的列使用NOT NULL,这对你想索引的列尤其重要。
将ISAM类型的表改为MyISAM。
如果可能,用固定的表格式创建表。
不要索引你不想用的东西。
利用MySQL能按一个索引的前缀进行查询的事实。如果你有索引INDEX(a,b),你不需要在a上的索引。
不在长CHAR/VARCHAR列上创建索引,而只索引列的一个前缀以节省存储空间。CREATE TABLE table_name (hostname CHAR(255) not null, index(hostname(10)))
对每个表使用最有效的表格式。
在不同表中保存相同信息的列应该有同样的定义并具有相同的列名。
--------------------------------------------------------------------------------
十六、MySQL如何次存储数据
数据库以目录存储。
表以文件存储。
列以变长或定长格式存储在文件中。对BDB表,数据以页面形式存储。
支持基于内存的表。
数据库和表可在不同的磁盘上用符号连接起来。
在Windows上,MySQL支持用.sym文件内部符号连接数据库。
--------------------------------------------------------------------------------
十七、MySQL表类型
HEAP表:固定行长的表,只存储在内存中并用HASH索引进行索引。
ISAM表:MySQL 3.22中的早期B-tree表格式。
MyIASM:IASM表的新版本,有如下扩展:
二进制层次的可移植性。
NULL列索引。
对变长行比ISAM表有更少的碎片。
支持大文件。
更好的索引压缩。
更好的键吗统计分布。
更好和更快的auto_increment处理。
来自Sleepcat的Berkeley DB(BDB)表:事务安全(有BEGIN WORK/COMMIT|ROLLBACK)。
--------------------------------------------------------------------------------
十八、MySQL行类型(专指IASM/MyIASM表)
如果所有列是定长格式(没有VARCHAR、BLOB或TEXT),MySQL将以定长表格式创建表,否则表以动态长度格式创建。
定长格式比动态长度格式快很多并更安全。
动态长度行格式一般占用较少的存储空间,但如果表频繁更新,会产生碎片。
在某些情况下,不值得将所有VARCHAR、BLOB和TEXT列转移到另一个表中,只是获得主表上的更快速度。
利用myiasmchk(对ISAM,pack_iasm),可以创建只读压缩表,这使磁盘使用率最小,但使用慢速磁盘时,这非常不错。压缩表充分地利用将不再更新的日志表
--------------------------------------------------------------------------------
十九、MySQL高速缓存(所有线程共享,一次性分配)
键码缓存:key_buffer_size,默认8M。
表缓存:table_cache,默认64。
线程缓存:thread_cache_size,默认0。
主机名缓存:可在编译时修改,默认128。
内存映射表:目前仅用于压缩表。
注意:MySQL没有行高速缓存,而让操作系统处理。
--------------------------------------------------------------------------------
二十、MySQL缓存区变量(非共享,按需分配)
sort_buffer:ORDER BY/GROUP BY
record_buffer:扫描表。
join_buffer_size:无键联结
myisam_sort_buffer_size:REPAIR TABLE
net_buffer_length:对于读SQL语句并缓存结果。
tmp_table_size:临时结果的HEAP表大小。
 
--------------------------------------------------------------------------------
二十一、MySQL表高速缓存工作原理
每个MyISAM表的打开实例(instance)使用一个索引文件和一个数据文件。如果表被两个线程使用或在同一条查询中使用两次,MyIASM将共享索引文件而是打开数据文件的另一个实例。
如果所有在高速缓存中的表都在使用,缓存将临时增加到比表缓存尺寸大些。如果是这样,下一个被释放的表将被关闭。
你可以通过检查mysqld的Opened_tables变量以检查表缓存是否太小。如果该值太高,你应该增大表高速缓存。
 
--------------------------------------------------------------------------------
二十二、MySQL扩展/优化-提供更快的速度
使用优化的表类型(HEAP、MyIASM或BDB表)。
对数据使用优化的列。
如果可能使用定长行。
使用不同的锁定类型(SELECT HIGH_PRIORITY,INSERT LOW_PRIORITY)
Auto_increment
REPLACE (REPLACE INTO table_name VALUES (...))
INSERT DELAYED
LOAD DATA INFILE / LOAD_FILE()
使用多行INSERT一次插入多行。
SELECT INTO OUTFILE
LEFT JOIN, STRAIGHT JOIN
LEFT JOIN ,结合IS NULL
ORDER BY可在某些情况下使用键码。
如果只查询在一个索引中的列,将只使用索引树解决查询。
联结一般比子查询快(对大多数SQL服务器亦如此)。
LIMIT
SELECT * from table1 WHERE a > 10 LIMIT 10,20
DELETE * from table1 WHERE a > 10 LIMIT 10
foo IN (常数列表) 高度优化。
GET_LOCK()/RELEASE_LOCK()
LOCK TABLES
INSERT和SELECT可同时运行。
UDF函数可装载进一个正在运行的服务器。
压缩只读表。
CREATE TEMPORARY TABLE
CREATE TABLE .. SELECT
带RAID选项的MyIASM表将文件分割成很多文件以突破某些文件系统的2G限制。
Delay_keys
复制功能
--------------------------------------------------------------------------------
二十二、MySQL何时使用索引
对一个键码使用>, >=, =, 1 and key_part1 explain select t3.DateOfAction, t1.TransactionID
-> from t1 join t2 join t3
-> where t2.ID = t1.TransactionID and t3.ID = t2.GroupID
-> order by t3.DateOfAction, t1.TransactionID;
+-------+--------+---------------+---------+---------+------------------+------+---------------------------------+
| table | type | possible_keys | key | key_len | ref | rows | Extra |
+-------+--------+---------------+---------+---------+------------------+------+---------------------------------+
| t1 | ALL | NULL | NULL | NULL | NULL | 11 | Using temporary; Using filesort |
| t2 | ref | ID | ID | 4 | t1.TransactionID | 13 | |
| t3 | eq_ref | PRIMARY | PRIMARY | 4 | t2.GroupID | 1 | |
+-------+--------+---------------+---------+---------+------------------+------+---------------------------------+
ALL和范围类型提示一个潜在的问题。
 
--------------------------------------------------------------------------------
二十五、学会使用SHOW PROCESSLIST
使用SHOW processlist来发现正在做什么:
+----+-------+-----------+----+---------+------+--------------+-------------------------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-------+-----------+----+---------+------+--------------+-------------------------------------+
| 6 | monty | localhost | bp | Query | 15 | Sending data | select * from station,station as s1 |
| 8 | monty | localhost | | Query | 0 | | show processlist |
+----+-------+-----------+----+---------+------+--------------+-------------------------------------+
在mysql或mysqladmin中用KILL来杀死溜掉的线程。
--------------------------------------------------------------------------------
二十六、如何知晓MySQL解决一条查询
运行项列命令并试图弄明白其输出:
SHOW VARIABLES;
SHOW COLUMNS FROM ...G
EXPLAIN select ...G
FLUSH STATUS;
SELECT ...;
SHOW STATUS;
--------------------------------------------------------------------------------
二十七、MySQL非常不错
日志
在进行很多连接时,连接非常快。
同时使用SELECT和INSERT的场合。
在不把更新与耗时太长的选择结合时。
在大多数选择/更新使用唯一键码时。
在使用没有长时间冲突锁定的多个表时。
在用大表时(MySQL使用一个非常紧凑的表格式)。
--------------------------------------------------------------------------------
二十八、MySQL应避免的事情
用删掉的行更新或插入表,结合要耗时长的SELECT。
在能放在WHERE子句中的列上用HAVING。
不使用键码或键码不够唯一而进行JOIN。
在不同列类型的列上JOIN。
在不使用=匹配整个键码时使用HEAP表。
在MySQL监控程序中忘记在UPDATE或DELETE中使用一条WHERE子句。如果想这样做,使用mysql客户程序的--i-am-a-dummy选项。
--------------------------------------------------------------------------------
二十九、MySQL各种锁定
内部表锁定
LOCK TABLES(所有表类型适用)
GET LOCK()/RELEASE LOCK()
页面锁定(对BDB表)
ALTER TABLE也在BDB表上进行表锁定
LOCK TABLES允许一个表有多个读者和一个写者。
一般WHERE锁定具有比READ锁定高的优先级以避免让写入方干等。对于不重要的写入方,可以使用LOW_PRIORITY关键字让锁定处理器优选读取方。
UPDATE LOW_PRIORITY SET value=10 WHERE id=10;
--------------------------------------------------------------------------------
三十、给MySQL更多信息以更好地解决问题的技巧 注意你总能去掉(加注释)MySQL功能以使查询可移植:
SELECT /*! SQL_BUFFER_RESULTS */ ...
SELECT SQL_BUFFER_RESULTS ...
将强制MySQL生成一个临时结果集。只要所有临时结果集生成后,所有表上的锁定均被释放。这能在遇到表锁定问题时或要花很长时间将结果传给客户端时有所帮助。
SELECT SQL_SMALL_RESULT ... GROUP BY ...
告诉优化器结果集将只包含很少的行。
SELECT SQL_BIG_RESULT ... GROUP BY ...
告诉优化器结果集将包含很多行。
SELECT STRAIGHT_JOIN ...
强制优化器以出现在FROM子句中的次序联结表。
SELECT ... FROM table_name [USE INDEX (index_list) | IGNORE INDEX (index_list)] table_name2
强制MySQL使用/忽略列出的索引。
--------------------------------------------------------------------------------
三十一、事务的例子
MyIASM表如何进行事务处理:
mysql> LOCK TABLES trans READ, customer WRITE;
mysql> select sum(value) from trans where customer_id=some_id;
mysql> update customer set total_value=sum_from_previous_statement
where customer_id=some_id;
mysql> UNLOCK TABLES;
BDB表如何进行事务:
mysql> BEGIN WORK;
mysql> select sum(value) from trans where customer_id=some_id;
mysql> update customer set total_value=sum_from_previous_statement
where customer_id=some_id;
mysql> COMMIT;
注意你可以通过下列语句回避事务:
UPDATE customer SET value=value+new_value WHERE customer_id=some_id;
--------------------------------------------------------------------------------
三十二、使用REPLACE的例子
REPLACE的功能极像INSERT,除了如果一条老记录在一个唯一索引上具有与新纪录相同的值,那么老记录在新纪录插入前则被删除。不使用 select 1 FROM t1 WHERE key=#
IF found-row
LOCK TABLES t1
DELETE FROM t1 WHERE key1=#
INSERT INTO t1 VALUES (...)
UNLOCK TABLES t1;
ENDIF
而用
REPLACE INTO t1 VALUES (...)
--------------------------------------------------------------------------------
三十三、一般技巧
使用短主键。联结表时使用数字而非字符串。
当使用多部分键码时,第一部分应该时最常用的部分。
有疑问时,首先使用更多重复的列以获得更好地键码压缩。
如果在同一台机器上运行MySQL客户和服务器,那么在连接MySQL时则使用套接字而不是TCP/IP(这可以提高性能7.5%)。可在连接MySQL服务器时不指定主机名或主机名为localhost来做到。
如果可能,使用--skip-locking(在某些OS上为默认),这将关闭外部锁定并将提高性能。
使用应用层哈希值而非长键码:
SELECT * FROM table_name WHERE hash=MD5(concat(col1,col2)) AND
col_1='constant' AND col_2='constant'
在文件中保存需要以文件形式访问的BLOB,在数据库中只保存文件名。
删除所有行比删除一大部分行要快。
如果SQL不够快,研究一下访问数据的较底层接口。
--------------------------------------------------------------------------------
三十四、使用MySQL 3.23的好处
MyISAM:可移植的大表格式
HEAP:内存中的表
Berkeley DB:支持事务的表。
众多提高的限制
动态字符集
更多的STATUS变量
CHECK和REPAIR表
更快的GROUP BY和DISTINCT
LEFT JOIN ... IF NULL的优化
CREATE TABLE ... SELECT
CREATE TEMPORARY table_name (...)
临时HEAP表到MyISAM表的自动转换
复制
mysqlhotcopy脚本
--------------------------------------------------------------------------------
三十五、正在积极开发的重要功能
改进事务处理
失败安全的复制
正文搜索
多个表的删除(之后完成多个表的更新)
更好的键码缓存
原子RENAME (RENAME TABLE foo as foo_old, foo_new as foo)
查询高速缓存
MERGE TABLES
一个更好的GUI客户程序
昵称: riiyii  时间: 2009-12-30 09:56:00
    谢谢分享
昵称: sqw00453579  时间: 2009-12-30 14:01:00
想学习
昵称: nancy  时间: 2009-12-30 20:27:00
学一下.
昵称: nancy  时间: 2009-12-30 20:28:00
        
昵称: nancy  时间: 2009-12-30 20:29:00
            
昵称: nancy  时间: 2009-12-30 20:29:00
        
昵称: nancy  时间: 2009-12-30 20:30:00
        
昵称: nancy  时间: 2009-12-30 20:30:00
昵称: nancy  时间: 2009-12-30 20:31:00
          
昵称: nancy  时间: 2009-12-30 20:32:00
          
昵称: nancy  时间: 2009-12-30 20:33:00
              
昵称: nancy  时间: 2009-12-30 20:34:00
深入学习中
昵称: xiaokaizhi  时间: 2010-01-01 09:37:00
定  定 定
昵称: q185508016  时间: 2010-01-02 17:18:00
针对目前很多网友下载不回帖现象,本帖需要回复才能下载, 谅解!
昵称: extra  时间: 2010-01-02 20:19:00
看看
昵称: wenphp100  时间: 2010-01-03 17:59:00
顶你一下
昵称: zjgqianlei  时间: 2010-01-03 19:06:00
顶!!!
昵称: kingps305  时间: 2010-01-04 10:32:00
学习学习,嘿嘿!
昵称: taylor89  时间: 2010-01-05 09:49:00
kanka
昵称: aphpboy  时间: 2010-01-05 15:21:00
xue xi xia xin zhi shi
昵称: laizhengxi  时间: 2010-01-06 20:16:00
针对目前很多网友下载不回帖现象,本帖需要回复才能下载
昵称: kangyangyang  时间: 2010-01-06 22:03:00
   针对目前很多网友下载不回帖现象,本帖需要回复才能下载,请谅解!
昵称: addminlinux  时间: 2010-01-10 14:32:00
下来看看
昵称: xwf8899  时间: 2010-01-10 17:45:00
Mysql 5.0存储过程技术资料
昵称: hyrxb  时间: 2010-01-12 16:37:00
顶,看看
昵称: fmirage  时间: 2010-01-13 15:06:00
dsadsadasdasdasdasd
昵称: zqs122333  时间: 2010-01-16 15:39:00
学习一下
昵称: dade  时间: 2010-01-18 10:55:00
回帖,看帖,学习贴
昵称: cnxpc  时间: 2010-01-18 13:23:00
xuexi xue xi
昵称: dick.com  时间: 2010-01-18 15:01:00
好东西 正需要呢 楼主真好
昵称: taojinbei  时间: 2010-01-20 15:17:00
了解一下,谢谢分享
昵称: dearyzy  时间: 2010-01-20 17:08:00
昵称: cpf4455  时间: 2010-01-21 11:27:00
好东东一定要支持
昵称: hackzhacai  时间: 2010-01-21 12:43:00
原来山猫你很早以前就传过了。

我现在才知道有个叫存储过程的东西。 一定要看看。
昵称: 上课睡觉  时间: 2010-01-21 14:04:00
学习一下,谢谢了
昵称: huangensen  时间: 2010-01-21 14:10:00
下来看看!
昵称: js840852371  时间: 2010-01-21 14:17:00
ding ding ding
昵称: yj58723879  时间: 2010-01-21 14:28:00
多谢
昵称: mars429  时间: 2010-01-22 11:28:00
学习一下  谢谢楼主了
昵称: cnxyy123  时间: 2010-01-22 14:49:00
很想要这样在资料吧
昵称: jiang9562  时间: 2010-01-22 17:07:00
昵称: 路小程  时间: 2010-01-23 13:02:00
看看是什么样子的
昵称: lizhanxin  时间: 2010-01-23 16:46:00
回复看看这个东西
昵称: tailiyan88  时间: 2010-01-25 14:40:00
存储过程 必须要看 不可缺少 多谢
昵称: tty  时间: 2010-01-25 18:42:00
学习下,看看,谢谢
昵称: 零度冰水  时间: 2010-01-27 16:30:00
好东西 正需要呢 楼主真好
昵称: kinoko88  时间: 2010-01-29 15:10:00
看看
昵称: inttt  时间: 2010-01-31 11:02:00
刚好需要这个。多谢
昵称: sykenluo  时间: 2010-02-02 17:53:00
看不到
昵称: 哎。。。  时间: 2010-04-04 13:15:55
刚好需要这个。多谢
昵称: rbq  时间: 2010-06-11 16:56:56
刚好需要这个。多谢
昵称: wenrui0408  时间: 2010-06-11 16:58:08
回复了也没有啊
昵称: wenrui0408  时间: 2010-06-11 16:58:49
大沙发沙发的方法反反复反复反复反复反复
昵称: 斯蒂芬  时间: 2010-11-10 16:56:36
感谢楼主
昵称: dsahdj  时间: 2010-11-22 16:51:55
刚才你才能
昵称: 下次在现场  时间: 2010-11-22 16:52:54