飘飘悠悠 发表于 2015-1-16 20:14:28

发一篇MySQL以速率为方针

MySQL的双许可模式意味着,那些希望对数据库具有额外控制的人可以直接从数据库厂商那儿得到帮助。MySQLAB公司提供了支持和维护服务,诸如代码更新和补丁修补服务等,每年订阅费为大约3000美元。MySQL以速率为方针



--------------------------------------------------------------------------------


MySQL和PostgreSQL都长短常出名的数据库开放源码项目,并且都有代替商用数据库体系的趋向,但二者有着分歧的计划方针。一样平常而言,假如必要更快的速率,能够优先思索MySQL,而假如必要一些新的特征,那能够选择PostgreSQL。

今朝MySQL由MySQLAB公司保护,其最新不乱版本为3.23,撑持事件处置的3.23Max版也进进了Beta测试阶段,而它的最新开辟版本4.0已进进了Alpha测试阶段。它略显不平常的允许用度,很简单让用户对它印象深入。它的代价随平台和安装体例的分歧而改动,其Windows版本在任何情形下都难免费,而对任何Unix/linux版本,假如用户或体系办理员本人安装是收费的,第三方安装则必需付出允许用度。

MySQL是基于C/S系统布局的收集数据库办理体系。它的计划以速率为次要方针,能够疾速处置多个用户的查询哀求,在处置客户端毗连时的速率也十分快,很合适用做Web站点的背景数据库。绝对而言,PostgreSQL的实行速率对照慢,它对每一个毗连都天生一个子历程,而天生子历程、创建背景服务历程的步骤减慢了它的实行速率。MySQL的服务器功效很松散,各类庞大的功效处置(好比xml撑持)完整被放到客户端举行,这使得增添功效时不会就义数据库服务器的速率和牢靠性。并且它已被贸易内存检测程序证实不存在内存保守,一连中止和程序溃散的征象也很稀有,在不乱性上比PostgreSQL要强一些。

在最后的计划阶段,MySQL次要面向中等范围的数据库,也就是说,数据库的范围约莫有几万万行,每一个表约莫100MB。跟着MySQL项目标开展,它的利用范畴也渐渐扩大到TB范围的年夜型数据库和小型的手持或嵌进式设备范畴。可是在短时间内,MySQL不会撑持及时数据库或年夜范围集群数据库。固然在其3.23版本中,它经由过程MyISAM表,可使体系在实际上可以撑持8000PB的表。但因为操纵体系的限定,在年夜部分Linux体系下,它仅能处置最年夜为2GB或4GB的表。在3.23版本中,还到场了撑持年夜型服务器集群的复制、InnoDB的事件表处置器、BerkerleyDB事件表处置器接口、全文本搜刮、MyODBC2.5接口、MyISAM表的主动反省和修复、批量拔出等新模块。

InnoDB和BDB事件表处置器的引进使MySQL中利用这些体例存储的数据表具有很好的事件处置才能。不外关于其他体例存储的表,利用原子操纵保护完全性和分歧性一般会丧失一些功能。在完全性十分主要时,可使用LOCKTABLES举行表锁定。从3.23.44入手下手,InnoDB表撑持外码限定反省,不外它的利用,出格是误用外码大概会招致较严峻的成绩。

MySQL不撑持嵌套查询功效,给开辟职员带来很年夜方便。它只撑持SQL92的一个子集,而不像PostgreSQL那样撑持SQL92的一个通用子集。以是关于逻辑对照庞大的查询,常常要创建一时表来保留两头信息,偶然候这类体例会使一些查询语句的表述很不直不雅大概基本没法暗示。

不外在MySQL4.0体系中,又增添了一些新特征,好比撑持fail-safe体例复制和联机备份的事情体例,以顺应关头义务和年夜负载运转的用户。它还对年夜段文本接纳新的全文索引,利用户能够用天然言语形貌举行检索操纵。别的,在4.0之前的版本中只能经由过程明文举行服务器和客户端之间的毗连,若要供应较强的平安性必需在服务器和客户端之间架设防火墙;而4.0版本在客户机和服务器之间撑持平安通讯体例,其mysqld服务器保卫历程可使用平安套接字(SSL)和客户机举行通讯。别的它经由过程对MyISAM在表级到场标记毗连,使得在Windows体系下也能撑持标记毗连处置。

(盘算机天下报第11期B24)
“MySQL实际上是一个数据库家族,你可以从选择一个并将其配置成可以满足你的大多数情况,”开源顾问公司Ethiqa的总裁如此表示,“因此,你可以在开始的时候选择一个小巧的版本产品,以后再根据需要来对其进行性能或大小上的扩展。”

不帅 发表于 2015-1-18 19:08:36

可以动态传入参数,省却了动态SQL的拼写。

谁可相欹 发表于 2015-1-24 14:23:30

你觉得我的非分区索引无法对起子分区,你可以提醒我一下呀!没有任何的提醒,直接就变成了非分区表。不知道这算不算一个bug。大家也可以试试。

深爱那片海 发表于 2015-2-1 17:00:29

也可谈一下你是怎么优化存储过程的?

精灵巫婆 发表于 2015-2-7 11:11:29

一个百万级别的基本信息表A,一个百万级别的详细记录表B,A中有个身份证id,B中也有身份id;先要找出A中在B的详细记录。

活着的死人 发表于 2015-2-21 19:49:43

你可以简单地认为适合的就是好,不适合就是不好。

山那边是海 发表于 2015-3-6 21:19:22

groupby子句可以将查询结果分组,并返回行的汇总信息Oracle按照groupby子句中指定的表达式的值分组查询结果。

老尸 发表于 2015-3-13 21:41:45

相信各位对数据库和怎么样学习数据库都有一些经验和看法,也会有人走了一些弯路总结出自己的经验来,希望大家能把各自的看法和经验拿出来分享,给别人一份帮助,给自己一份快乐

简单生活 发表于 2015-3-20 19:51:42

学习SQL语言的话如果要学会去做网站就不是很难!但是要做数据库管理的话就有难度了!
页: [1]
查看完整版本: 发一篇MySQL以速率为方针