热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

MySQL高级特性----对比与其他数据库_MySQL

性能对于速度的真实比较,请教不断成熟的MySQL基准套件。见10.8使用你自己的基准。因为没有线程创建开销、一个较小的语法分析器、较少功能和简单的安全性,mSQL应该在下列方面更快些:执行重复的连接和断开的测试,在每个连接期间运行一个非常简单的查询。有很少的
  性能
  对于速度的真实比较,请教不断成熟的MySQL基准套件。见10.8 使用你自己的基准。因为没有线程创建开销、一个较小的语法分析器、较少功能和简单的安全性,mSQL应该在下列方面更快些:
  执行重复的连接和断开的测试,在每个连接期间运行一个非常简单的查询。
  有很少的列和键的插入很简单的表的INSERT操作。
  CREATE TABLE和DROP TABLE。
  在不是一个索引的一些东西上SELECT。(一个表扫描是很容易的。)
  因为这些操作是如此简单,当你有更高的启动开销时,很难在这些方面变得更好。在连接被建立以后,MySQL应该性能好一些。在另一方面,MySQL比mSQL(以及大多数其他的SQL实现)在下列方面更好些:
  
  复杂的SELECT操作
  检索较大的结果(MySQL有一个更好、更快并且更安全的协议)。
  有变长字符串的表,因为MySQL有更有效的并可在VARCHAR列上索引。
  有很多列的表的处理。
  由长记录的表的处理。
  有很多许多表达式的SELECT。
  在大表上的SELECT。
  同时处理很多连接。MySQL充分是完全多线程化的,每个连接有它自己的线程,这意味着没有线程必须等待另一个线程(除非一个线程正在修改一张表,另外的线程想要存取)在mSQL中,一旦一个连接被建立了,所有其它线程必须等到第一个线程完成,不管连接正在运行的查询是短的或是长的。当第一个连接终止时,下一个才能工作,而此时所有其它线程再次等待,等等。
  
  联结。如果你改变一个SELECT中的表的顺序,mSQL可能变得异常地慢。在基准套件中,比MySQL要慢超过15000倍的时间。这是由于mSQL缺乏一个联结优化器以便以最佳的顺序排定表。然而,如果你把表按完全正确的顺序放在mSQL2中并且WHERE是很简单的并使用索引列,联结将相对快些!见10.8 使用你自己的基准。
  ORDER BY和GROUP BY。
  DISTINCT。
  使用TEXT或BLOB列。
  
  SQL功能
  GROUP BY和HAVING。mSQL根本不支持GROUP BY。MySQL支持一个有两个HAVING和下列函数: COUNT()、AVG()、MIN()、MAX()、SUM()和STD()的完整的GROUP BY。如果SELECT从一张表中检索,没有其他列被检索并且没有WHERE子句,COUNT(*)被优化以很快地返回。 MIN()和MAX()可以取字符串参数。
  带计算的INSERT和UPDATE。MySQL能在一个INSERT或UPDATE中做计算。例如:
  mysql> UPDATE SET x=x*10+y WHERE x<20;
  
  别名,MySQL有列的别名。
  限制列名。在MySQL中,如果一个列名在用于查询的表之间唯一的,你不必须使用完整的 合格者。
  带函数的SELECT。MySQL有很多函数(太多不能在这里列出;见7.4 用在SELECT和WHERE子句中的函数)。
  
  磁盘空间效率
  即,你能使你的表有多小?MySQL有很精确的类型,因此你可以创建占据很小空间的表。一个有用的MySQL数据类型的例子是MEDIUMINT,它是3个字节长。如果你有100,000,000个记录,每个记录节省甚至一个字节也是很重要的。mSQL2有一个较有限的列类型集合,因此更难于使表更小。
  
  稳定性
  这较难客观地评价。对于MySQL稳定性的讨论,见1.5 MySQL有多么稳定?。我们没有mSQL稳定性的经验,因此我们对此不能说任何东西。
  价格
  另一个重要的问题是许可证。MySQL有一个比mSQL更灵活的许可证,并且也不比mSQL昂贵。无论你选择使用哪个产品,记得要至少考虑支付一个许可证或电子邮件支持的费用。(当然如果你把你出售的一个产品包括在MySQL中,你将被要求获得一个许可证。)
  
  Perl接口
  MySQL有与mSQL基本相同Perl接口,当有一些增加的功能。
  
  JDBC ( Java )
  MySQL目前有4个JDBC驱动程序:
  gwe 驱动程序:由GWE technologies 开发的一个Java接口(不再支持)。
  jms 驱动程序:由Xiaokun Kelvin ZHU的开发的一个改进的gwe驱动程序。
  twz 驱动程序:由Terrence W. Zellers 开发的一个type 4 JDBC驱动程序并用于学习目的。
  mm 驱动程序:由Mark Matthews 开发的一个type 4 JDBC驱动程序。
  推荐的驱动程序是twz或mm驱动程序。两者均被报导工作出色。我们知道mSQL有一个 JDBC 驱动程序,但是我们对它有太少的经验不能进行比较。
  
  开发速度
  MySQL有一个非常小的开发者队伍,但是我们是非常习惯于用C和C++编码,非常快速。因为线程、函数、GROUP BY等在mSQL中仍未实现,它有很多追赶工作要做。要想得到关于它的一些前景,你可以查看mSQL最后一年的 “HISTIRY”文件,并将它与MySQL参考书手册的新功能小节比较(见D MySQL变迁历史)。哪个快开发得最快应该是相当明显的。
  
  实用程序
  mSQL和MySQL都有许多有趣的第三方工具。因为向上移植(从mSQL到MySQL)是很容易的,几乎所有mSQL可用的有趣的应用程序也可被MySQL使用。MySQL带有一个简单的msql2mysql程序修正在mSQL和MySQL使用的大多数C API函数之间拼写差别。例如,它将msqlConnect()实例改变为mysql_connect()。变换一个客户程序从mSQL到MySQL通常花几分钟时间。
  21.1.1 怎样将mSQL的工具转换到MySQL
  根据我们的经验,转换诸如使用mSQL C API的msql-tcl和msqljava工具将只花不大一小时时间,使得他们用MySQL C API工作。
  
  转换过程是:
  在源代码上运行外壳脚本msql2mysql。这需要replace程序,它与MySQL一起散发。
  编译。
  修正所有编译器错误。
  mSQL C API与MySQL C API 之间差别是:
  
  MySQL使用一个MYSQL结构作为一种连接类型(mSQL使用一个int)。
  mysql_connect()取一个指向一个MYSQL结构的指针作为一个参数。很容易定义全局性定义一个或使用malloc()获得一个。mysql_connect()也取两个参数指定用户和口令。你可以为了缺省使用将这些设置为NULL,NULL。
  mysql_error()取MYSQL结构作为一个参数。如果你正在移植老的代码,只是把参数加到你的老的msql_error()编码中。
  MySQL对所有错误返回一个错误号和一条文本错误消息。mSQL仅返回一条文字错误消息。
  存在某些不兼容性,因为MySQL支持从同一个进程的到服务器多个连接。
  
   mSQL和MySQL的客户机/服务器通讯协议有何不同
  有足够的差别使得不可能(或至少不容易)支持两者。
  
  它MySQL协议不同于mSQL协议的最重要的方面列在下面:
  
  一个消息缓冲区可以包含很多结果行。
  如果查询或结果比当前缓冲区大,消息缓冲区动态地被扩大,直到一个可配置的服务器和客户上限。
  所有的包被编号以捕捉重复或丢失的包。
  所有的列值以ASCII码发送。列和行的长度以紧凑的二进制编码(1、2或3个字节)发送。
  MySQL能在未缓冲得结果中读取(不必在客户端存储完整的集合)。
  如果一个单独写/读花了超过30秒时间,服务器关闭连接。
  如果一个连接空闲8个小时,服务器关闭连接。
   mSQL 2.0的SQL句法与MySQL有何不同
  列类型
  
  MySQL
  有下列额外的类型(比较其他的;见7.7 CREATE TABLE句法): 、
  对于一个字符串集中之一的ENUM类型。
  对于一个字符串集中多个的SET类型。
  对于64位整数的BIGINT类型。
  MySQL也支持下列额外的类型属性:
  UNSIGNED选项。
  对于整数列的ZEROFILL选项。
  对于是一个PRIMARY KEY的整数列的AUTO_INCREMENT选项。见20.4.29 mysql_insert_id()。
  对所有列的DEFAULT值。
  
  mSQL2
  mSQL列类型对应于MySQL类型显示在下面:mSQL类型 相应的MySQL类型 
  CHAR(len) CHAR(len) 
  TEXT(len) TEXT(len),len是最大长度。并且LIKE可运用。
  INT INT,有很多的选项! 
  REAL REAL,或FLOAT。有4和8字节版本。
  UINT INT UNSIGNED 
  DATE DATE,使用 ANSI SQL 格式而非mSQL自己的。
  TIME TIME 
  MONEY DECIMAL(12,2),有2个小数位的定点值。
  
  索引创建
  MySQL
  索引可以在表创建时用CREATE TABLE语句指定。
  mSQL
  在表被创建了以后,索引必须被创建,用单独的CREATE INDEX语句。
  把一个唯一标识符插入到一张表中
  
  MySQL 使用AUTO_INCREMENT作为列类型修饰符。见20.4.29 mysql_insert_id()。
  mSQL
  在一张表上创建一个SEQUENCE并且选择_seq列。
  为行获得一个唯一标识符
  
  MySQL 向表中增加一个PRIMARY KEY或UNIQUE键。
  
  mSQL 使用_rowid列。注意_rowid可以将来改变,取决于很多因素。
  得到列最后被修改的时间
  
  MySQL 在表中增加一个TIMESTAMP列。如果你不给出列值或如果你给它一个NULL值,该列自动为INSERT或UPDATE语句设置为当前的日期和时间。
  
  mSQL 使用_timestamp列。
  NULL值的比较
  
  MySQL MySQL遵从ANSI SQL且与NULL的比较总是NULL。
  
  mSQL 在mSQL中,NULL = NULL是TRUE(真)。当从mSQL到MySQL移植老的代码时,你必须将=NULL改委IS NULL,并将<>NULL改为IS NOT NULL。
  字符串的比较
  
  MySQL
  通常,字符串比较以大小写无关方式按当前字符集(缺省为ISO-8859-1 Latin1)决定的排序次序实施。如果你不喜欢这样,声明你的列有BINARY属性,它使得比较根据用在MySQL服务器主机上的ASCII顺序进行。
  mSQL
  所有的字符串比较以大小写敏感的方式以ASCII顺
推荐阅读
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • MyBatis错题分析解析及注意事项
    本文对MyBatis的错题进行了分析和解析,同时介绍了使用MyBatis时需要注意的一些事项,如resultMap的使用、SqlSession和SqlSessionFactory的获取方式、动态SQL中的else元素和when元素的使用、resource属性和url属性的配置方式、typeAliases的使用方法等。同时还指出了在属性名与查询字段名不一致时需要使用resultMap进行结果映射,而不能使用resultType。 ... [详细]
  • 本文介绍了2019年上半年内蒙古计算机软考考试的报名通知和考试时间。考试报名时间为3月1日至3月23日,考试时间为2019年5月25日。考试分为高级、中级和初级三个级别,涵盖了多个专业资格。报名采取网上报名和网上缴费的方式进行,报考人员可登录内蒙古人事考试信息网进行报名。详细内容请点击查看。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
author-avatar
手机用户2502895261
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有