MySQL简介二

MySQL基本命令  

    [ ]中的内容为可选项
  --创建数据库
  mysql> create database 数据库名称
  --创建表
  mysql> create table 表名 (
  列的名字(id)类型(int(4))primary key(定义主键) auto_increment(描述 自增),
  ……,
  );
  --查看所有数据库
  mysql> show databases 数据库名称;
  --使用某个数据库
  mysql> use database 数据库名称;
  --查看所使用数据库下所有的表
  mysql> show tables;
  --显示表的属性结构
  mysql> desc 表名;
  --选择表中数据的显示
  --* 代表选择所有列 ,
  mysql> select * from 表名 where id=?[and name=?] [or name=?];
  mysql> select id,name from 表名order by 某一列的名称 desc(降序,asc为升序)
  --删除表中的数据
  mysql> delete from table where id=?[or name=? (and name=?)];
  --删除表
  mysql> drop table;
  --删除数据库
  mysql> drop database;
  索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。
  注:[1]索引不是万能的!索引可以加快数据检索操作,但会使数据修改操作变慢。每修改数据记录,索引就必须刷新一次。为了在某种程序上弥补这一缺陷,许多SQL命令都有一个DELAY_KEY_WRITE项。这个选项的作用是暂时制止 MySQL在该命令每插入一条新记录和每修改一条现有之后立刻对索引进行刷新,对索引的刷新将等到全部记录插入/修改完毕之后再进行。在需要把许多新记录插入某个数据表的场合,DELAY_KEY_WRITE选项的作用将非常明显。[2]另外,索引还会在硬盘上占用相当大的空间。因此应该只为最经常查询和最经常排序的数据列建立索引。注意,如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果。
  从理论上讲,完全可以为数据表里的每个字段分别建一个索引,但MySQL把同一个数据表里的索引总数限制为16个。
  1. InnoDB数据表的索引
  与MyISAM数据表相比,在InnoDB数据表上,索引对InnoDB数据表的重要性要在得多。在InnoDB数据表上,索引不仅会在搜索数据记录时发挥作用,还是数据行级锁定机制的苊、基础。"数据行级锁定"的意思是指在事务操作的执行过程中锁定正在被处理的个别记录,不让其他用户进行访问。这种锁定将影响到(但不限于)SELECT...LOCK IN SHARE MODE、SELECT...FOR UPDATE命令以及INSERT、UPDATE和DELETE命令。
  出于效率方面的考虑,InnoDB数据表的数据行级锁定实际发生在它们的索引上,而不是数据表自身上。显然,数据行级锁定机制只有在有关的数据表有一个合适的索引可供锁定的时候才能发挥效力。
  2. 限制
  如果WHERE子句的查询条件里有不等号(WHERE coloum != ...),MySQL将无法使用索引。
  类似地,如果WHERE子句的查询条件里使用了函数(WHERE DAY(column) = ...),MySQL也将无法使用索引。
  在JOIN操作中(需要从多个数据表提取数据时),MySQL只有在主键和外键的数据类型相同时才能使用索引。
  如果WHERE子句的查询条件里使用比较操作符LIKE和REGEXP,MySQL 只有在搜索模板的第一个字符不是通配符的情况下才能使用索引。比如说,如果查询条件是LIKE 'abc%',MySQL将使用索引;如果查询条件是LIKE '%abc',MySQL将不使用索引。
  在ORDER BY操作中,MySQL只有在排序条件不是一个查询条件表达式的情况下才使用索引。(虽然如此,在涉及多个数据表查询里,即使有索引可用,那些索引在加快ORDER BY方面也没什么作用)
  如果某个数据列里包含许多重复的值,就算为它建立了索引也不会有很好的效果。比如说,如果某个数据列里包含的净是些诸如"0/1"或"Y/N"等值,就没有必要为它创建一个索引。
  普通索引、唯一索引和主索引
  1. 普通索引
  普通索引(由关键字KEY或INDEX定义的索引)的唯一任务是加快对数据的访问速度。因此,应该只为那些最经常出现在查询条件(WHERE column = ...)或排序条件(ORDER BY column)中的数据列创建索引。只要有可能,就应该选择一个数据最整齐、最紧凑的数据列(如一个整数类型的数据列)来创建索引。
  2. 唯一索引
  普通索引允许被索引的数据列包含重复的值。比如说,因为人有可能同名,所以同一个姓名在同一个"员工个人资料"数据表里可能出现两次或更多次。
  如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字UNIQUE把它定义为一个唯一索引。这么做的好处:一是简化了MySQL对这个索引的管理工作,这个索引也因此而变得更有效率;二是 MySQL会在有新记录插入数据表时,自动检查新记录的这个字段的值是否已经在某个记录的这个字段里出现过了;如果是,MySQL将拒绝插入那条新记录。也就是说,唯一索引可以保证数据记录的唯一性。事实上,在许多场合,人们创建唯一索引的目的往往不是为了提高访问速度,而只是为了避免数据出现重复。
  3. 主索引
  在前面已经反复多次强调过:必须为主键字段创建一个索引,这个索引就是所谓的"主索引"。主索引与唯一索引的唯一区别是:前者在定义时使用的关键字是PRIMARY而不是UNIQUE。
  4. 外键索引
  如果为某个外键字段定义了一个外键约束条件,MySQL就会定义一个内部索引来帮助自己以最有效率的方式去管理和使用外键约束条件。
  5. 复合索引
  索引可以覆盖多个数据列,如像INDEX(columnA, columnB)索引。这种索引的特点是MySQL可以有选择地使用一个这样的索引。如果查询操作只需要用到columnA数据列上的一个索引,就可以使用复合索引INDEX(columnA, columnB)。不过,这种用法仅适用于在复合索引中排列在前的数据列组合。比如说,INDEX(A, B, C)可以当做A或(A, B)的索引来使用,但不能当做B、C或(B, C)的索引来使用。
  6. 索引的长度
  在为CHAR和VARCHAR类型的数据列定义索引时,可以把索引的长度限制为一个给定的字符个数(这个数字必须小于这个字段所允许的最大字符个数)。这么做的好处是可以生成一个尺寸比较小、检索速度却比较快的索引文件。在绝大多数应用里,数据库中的字符串数据大都以各种各样的名字为主,把索引的长度设置为10~15个字符已经足以把搜索范围缩小到很少的几条数据记录了。
  在为BLOB和TEXT类型的数据列创建索引时,必须对索引的长度做出限制;MySQL所允许的最大索引jlkjljkjlj全文索引
  文本字段上的普通索引只能加快对出现在字段内容最前面的字符串(也就是字段内容开头的字符)进行检索操作。如果字段里存放的是由几个、甚至是多个单词构成的较大段文字,普通索引就没什么作用了。这种检索往往以LIKE %word%的形式出现,这对MySQL来说很复杂,如果需要处理的数据量很大,响应时间就会很长。
  这类场合正是全文索引(full-text index)可以大显身手的地方。在生成这种类型的索引时,MySQL将把在文本中出现的所有单词创建为一份清单,查询操作将根据这份清单去检索有关的数据记录。全文索引即可以随数据表一同创建,也可以等日后有必要时再使用下面这条命令添加:
  ALTER TABLE tablename ADD FULLTEXT(column1, column2)
  有了全文索引,就可以用SELECT查询命令去检索那些包含着一个或多个给定单词的数据记录了。下面是这类查询命令的基本语法:
  SELECT * FROM tablename
  WHERE MATCH(column1, column2) AGAINST('word1', 'word2', 'word3')
  上面这条命令将把column1和column2字段里有word1、word2和word3的数据记录全部查询出来。
  注解:InnoDB数据表不支持全文索引。
  查询和索引的优化
  只有当数据库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值。如果在测试数据库里只有几百条数据记录,它们往往在执行完第一条查询命令之后就被全部加载到内存里,这将使后续的查询命令都执行得非常快--不管有没有使用索引。只有当数据库里的记录超过了1000条、数据总量也超过了MySQL服务器上的内存总量时,数据库的性能测试结果才有意义。
  在不确定应该在哪些数据列上创建索引的时候,人们从EXPLAIN SELECT命令那里往往可以获得一些帮助。这其实只是简单地给一条普通的SELECT命令加一个EXPLAIN关键字作为前缀而已。有了这个关键字,MySQL将不是去执行那条SELECT命令,而是去对它进行分析。MySQL将以表格的形式把查询的执行过程和用到的索引(如果有的话)等信息列出来。
  在EXPLAIN命令的输出结果里,第1列是从数据库读取的数据表的名字,它们按被读取的先后顺序排列。type列指定了本数据表与其它数据表之间的关联关系(JOIN)。在各种类型的关联关系当中,效率最高的是system,然后依次是const、eq_ref、ref、range、index和All(All的意思是:对应于上一级数据表里的每一条记录,这个数据表里的所有记录都必须被读取一遍--这种情况往往可以用一索引来避免)。
  possible_keys数据列给出了MySQL在搜索数据记录时可选用的各个索引。key数据列是MySQL实际选用的索引,这个索引按字节计算的长度在key_len数据列里给出。比如说,对于一个INTEGER数据列的索引,这个字节长度将是4。如果用到了复合索引,在key_len数据列里还可以看到MySQL具体使用了它的哪些部分。作为一般规律,key_len数据列里的值越小越好(意思是更快)。
  ref数据列给出了关联关系中另一个数据表里的数据列的名字。row数据列是MySQL在执行这个查询时预计会从这个数据表里读出的数据行的个数。row数据列里的所有数字的乘积可以让我们大致了解这个查询需要处理多少组合。
  最后,extra数据列提供了与JOIN操作有关的更多信息,比如说,如果MySQL在执行这个查询时必须创建一个临时数据表,就会在extra列看到using temporary字样

安装MySQL时候的注意事项
    1、如果您是用MySQL+Apache,使用的又是FreeBSD网路操作系统的话,安装时候你应按注意到FreeBSD的版本问题,在FreeBSD的3.0以下版本来说,MySQL Source内含的MIT-pthread运行是正常的,但在这版本以上,你必须使用native threads,也就是加入一个with-named-thread-libs=-lc_r的选项。
    2、如果您在COMPILE过程中出了问题,请先检查你的gcc版本是否在2.81版本以上,gmake版本是否在3.75以上。
    3、如果不是版本的问题,那可能是你的内存不足,请使用./configure -- with-low-memory来加入。
    4、如果您要重新做你的configure,那么你可以键入rm config.cache和make clean来清除记录。
    5、我们一般把MySQL安装在/usr/local目录下,这是缺省值,您也可以按照你的需要设定你所安装的目录。

<think>好的,我现在需要帮助用户了解MySQL数据库的基本概念、功能和特点。首先,我得回顾一下用户提供的引用内容,确保信息准确。用户给了三个引用,都是关于MySQL的特点、优势以及与其他数据库的对比。 首先,根据引用3,MySQL属于关系型数据库,主流的还有SQL Server、Oracle等。用户可能想知道MySQL在其中的位置,所以需要说明它是关系型数据库,并且是开源的。引用1和2都提到MySQL是开源的,高性能,功能丰富,这些是关键点。 接下来,用户问及功能。MySQL的功能应该包括数据存储、事务处理、复制、安全性等。引用2提到高性能和丰富的功能,可以展开说明这些方面,比如支持事务处理的InnoDB引擎,主从复制,分区表等。 然后,特点方面,引用1和2都强调开源、易用性、跨平台支持、安全性。需要分点列出,比如开源免费、支持多种操作系统、良好的安全机制如SSL和访问控制。 用户可能还想知道MySQL的应用场景,比如Web应用,特别是LAMP架构,这部分可以结合引用中的内容,说明其在中小型项目中的优势,以及处理高并发的性能。 需要注意的是,回答要结构清晰,分点说明,同时引用正确的来源。比如提到开源特点时引用1和2,关系型数据库部分引用3。同时,确保使用正确的中文表达,避免技术术语使用错误。 最后,生成的相关问题要围绕MySQL的基础、对比、应用场景和优化,这样用户如果有进一步疑问,可以引导他们深入探索。例如,如何安装配置,与其他数据库的差异,优化方法等。 现在需要把这些点组织成连贯的回答,确保每个部分都有引用支持,并且语言自然流畅。</think>### MySQL数据库简介与核心特性 #### 一、基本概念 MySQL是一种**关系型数据库管理系统(RDBMS)**,基于结构化查询语言(SQL)进行数据管理。它由瑞典公司MySQL AB开发,现为Oracle旗下产品。MySQL以开源协议(GPL)发布,支持跨平台部署,广泛用于Web应用、企业级系统等场景[^3]。 #### 、核心功能 1. **数据存储与检索** 支持表结构设计,通过SQL语句实现数据的增删改查(CRUD),例如: ```sql SELECT * FROM users WHERE age > 25; ``` 2. **事务处理** 通过InnoDB引擎提供ACID特性(原子性、一致性、隔离性、持久性),保障数据一致性[^2]。 3. **数据复制与高可用** 支持主从复制(Master-Slave)、集群部署,提升数据可靠性和读取性能。 4. **权限管理与安全** 提供用户角色划分、SSL加密传输、IP白名单等安全机制。 #### 三、主要特点 1. **开源免费** 社区版可免费使用,降低企业成本[^1]。 2. **高性能** 优化查询引擎,支持索引、分区表等技术,可处理千万级数据量。 3. **跨平台支持** 兼容Linux、Windows、macOS等操作系统[^3]。 4. **易用性** 提供命令行工具(如`mysql`)及图形化界面(如MySQL Workbench)。 #### 四、典型应用场景 - **Web应用**:作为LAMP(Linux+Apache+MySQL+PHP)架构的核心组件,支持动态网站。 - **数据分析**:与BI工具结合,处理结构化数据。 - **嵌入式系统**:适用于轻量级设备数据存储。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值