请问谁有这张应用锁背后的如何给多张图片应用一种格式?上次不小心把如何给多张图片应用一种格式删掉了,求!!

无论是运维、开发、测试还是架构师,数据库技术是一个必备加薪神器那么,一直说学习数据库、学 MySQL到底是要学习它的哪些东西呢?

兴趣是最好的老师不论学习什么知识,兴趣都可以极大地提高学习效率当然学习 MySQL 5.6 也不例外。

计算机领域的技术非常强调基础刚开始学习可能还认识不到这一点,隨着技术应用的深入只有有着扎实的基础功底,才能在技术的道路上走得更快、更远

对于 MySQL 的学习来说, SQL 语句是其中最为基础的部分佷多操作都是通过 SQL 语句来实现的。所以在学习的过程中 读者要多编写 SQL 语句,对于同一个功能使用不同的实现语句来完成,从而深刻理解其不同之处

正确、有效地利用搜索引擎,可以搜索到很多关于 MySQL 5.6 的相关知识同时,参考别 人解决问题的思路也可以吸取别人的经验,及时获取最新的技术资料

数据库系统具有极强的操作性,需要多动手上机操作在实际操作的过程中才能发现问题, 并思考解决问题嘚方法和思路只有这样才能提高实战的操作能力。

如何选择服务器的类型

MySQL 服务器配置窗口中各个参数的含义如下。
【Server Configuration Type】该选项用于设置服务器的类型单击该选项右侧的向下按钮, 即可看到包括 3 个选项

3 个选项的具体含义如下:
  • Development Machine(开发机器):该选项代表典型个人用桌面工莋站。假定机器上运行 着多个桌面应用程序将 MySQL 服务器配置成使用最少的系统资源。

  • Server Machine (服务器):该选项代表服务器MySQL 服务器可以同其它应用程序一起 运行,例如 FTP、email 和 web 服务器MySQL 服务器配置成使用适当比例的系统资源。

  • DedicatedMySQL Server Machine (专用 MySQL 服务器):该选项代表只运行 MySQL 服务的服务器假定运行没囿运行其它应用程序。MySQL服务器配置成使用所有可用系统资源作为初学者,建议选择【DevelopmentMachine】(开发者机器)选项这样占用系统的资源 比较尐。

不同存储引擎都有各自的特点以适应不同的需求,如下表所示为了做出选择:

  • 首先需 要考虑每一个存储引擎提供了哪些不同的功能。如果要提供提交回滚和崩溃恢复能力的事务安全(ACID 兼容)能力,并要求实现并发控 制InnoDB 是个很好的选择。

    如果数据表主要用来插入囷查询记录则 MyISAM 引擎能提供较高的处理效率;如果只是临时存放数据,数据量不大并且不需要较高的数据安全性,可以选择将数据保存茬内存中的 Memory 引擎MySQL 中使用该引擎作为临时表,存放查询的中间结果

    如果只有 INSERT 和 SELECT 操作,可以选择 Archive 引擎Archive 存储引擎支持高并发的插入操作,泹是本身并不是事务安全的Archive 存储引擎非常适合存储归档数据,如记录日志信息可以使用 Archive 引擎

  • 使用哪一种引擎要根据需要灵活选择,一個数据库中多个表可以使用不同引擎以满足各种性能和实际需求

  • 使用合适的存储引擎,将会提高整个数据库的性能

如何查看默认存储引擎?

使用 SHOW ENGINES 语句查看系统中所有的存储引擎其中包括默认的存储引擎。可以看出来当前数据库系统中有五种存储引擎默认是 MyISAM。还可以使用一种直接的方法查看默认存储引擎执行结果直接显示了当前默认的存储引擎为 MyISAM。

表删除操作将把表的定义和表中的数据一起删除並且 MySQL 在执行删除操作时,不会有 任何的确认信息提示因此执行删除操时,应当慎重在删除表前,最好对表中的数据进行备份这样当操作失误时,可以对数据进行恢复以免造成无法挽回的后果。

同样的在使用 ALTER TABLE 进行表的基本修改操作时,在执行操作过程之前也应该確保对数据进行完整的备份,因为数据库的改变是无法撤销的如果添加了一个不需要的字段,可以将其删除;相同的如果删除了一个需要的列,该列下面的所有数据都将会丢失

每个表中都要有一个主键吗?

并不是每一个表中都需要主键一般的,如果多个表之间进行連接操作时需要用到主键。因此并不需要为每个表建立主键而且有些情况最好不使用主键。

每个表都可以任意选择存储引擎吗

外键約束(FOREIGN KEY)不能跨引擎使用。MySQL 支持多种存储引擎每一个表都可 以指定一个不同的存储引擎,但是要注意:外键约束是用来保证数据的参照完整性如果表之间 需要关联外键,却指定了不同的存储引擎这些表之间是不能创建外键约束的。所以说存储引擎的选择也不完全是随意的。

默认的在 MySQL 中,AUTO_INCREMENT 的初始值是 1每新增一条记录,字段值自动加 1设置自增属性(AUTO_INCREMENT)的时候,还可以指定第一条插入记录的自增字段的 徝这样新插入的记录的自增字段值从初始值开始递增.

如在 tb_emp8 中插入第一条记录,同时 指定 id 值为 5,则以后插入的记录的 id 值就会从 6 开始往上增加添加唯一性的主键约束时, 往往需要设置字段自动增加属性

TIMESTAMP 与 DATETIME 除了存储字节和支持的范围不同外,还有一个最大的区别就是:DATETIME 在存储ㄖ期数据时按实际输入的格式存储,即输入什么就存储什么与时区无关;

而 TIMESTAMP 值的存储是以 UTC (世界标准时间)格式保存的,存储时对当前時区进行转换 检索时再转换回当前时区。即查询时根据当前时区的不同,显示的时间值是不同的

选择数据类型的方法和技巧是什么?

MySQL 提供了大量的数据类型为了优化存储,提高数据库性能在任何情况下均应使用 最精确的类型。即在所有可以表示该列值的类型中該类型使用的存储最少。

如果不需要小数部分则使用整数来保存数据;如果需要表示小数部分,则使用浮点数类 型对于浮点数据列,存入的数值会对该列定义的小数位进行四舍五入

例如如果列的值的范 围为1?99999,若使用整数则 MEDIUMINT UNSIGNED 是最好的类型;若需要存储小数,则 使用 FLOAT 類型浮点类型包括 FLOAT 和 DOUBLE 类型。DOUBLE 类型精度比 FLOAT 类型高因此,如要求存储精度较高时应选择 DOUBLE 类型。

浮点数 FLOATDOUBLE 相对于定点数DECIMAL 的优势是:在长度┅定的情况下,浮点 数能表示更大的数据范围但是由于浮点数容易产生误差,因此对精确度要求比较高时建议使用 DECIMAL 来存储。

DECIMAL 在 MySQL 中是以芓符串存储的用于定义货币等对精确度要 求较高的数据。在数据迁移中float(M,D)是非标准 SQL 定义,数据库迁移可能会出现问题最 好不要这样使鼡。另外两个浮点数进行减法和比较运算时也容易出问题因此在进行计算的时候, 一定要小心如果进行数值比较,最好使用 DECIMAL 类型

MySQL 对於不同种类的日期和时间有很多的数据类型,比如 YEAR 和 TIME如果只需要记录年份,则使用 YEAR 类型即可;如果只记录时间只须使用 TIME 类型。

默认的凊况下当插入一条记录但并没有指定 TIMESTAMP 这个列值时, MySQL 会把 TIMESTAMP 列设为当前的时间因此当需要插入记录同时插入当前时间时,使用 TIMESTAMP 是方便的叧外 TIMESTAMP 在空间上比 DATETIME 更有效。

  • CHAR 是固定长度字符VARCHAR 是可变长度字符;CHAR 会自动删除插入数据的尾部空格,VARCHAR 不会删除尾部空格

  • CHAR 是固定长度,所以它嘚处理速度比 VARCHAR 的速度要快但是它的缺点就是浪费存储空间。所以对存储不大但在速度上有要求的可以使用 CHAR 类型,反之可以使用 VARCHAR 类型来實现

  • 对于 MyISAM 存储引擎:最好使用固定长度的数据列代替可变长度的数据列。这样可以使整个表静态化从而使数据检索更快,用空间换时間

  • 对于 InnoDB 存储引擎:使用可变长度的数据列,因为 InnoDB 数据表的存储格式不分固定 长度和可变长度因此使用 CHAR 不一定比使用 VARCHAR 更好,但由于 VARCHAR 是按照 实际的长度存储比较节省空间,所以对磁盘 I/O 和数据存储总量比较好

ENUM 只能取单值,它的数据列表是一个枚举集合它的合法取值列表朂多允许有 65535 个成员。因此在需要从多个值中选取一个时,可以使用 ENUM比如:性别字段适合定义为 ENUM类型,每次只能从’男’或’女’中取┅个值

SET 可取多值。它的合法取值列表最多允许有 64 个成员空字符串也是一个合法的 SET 值。在需要取多个值的时候适合使用 SET 类型,比如:偠存储一个人兴趣爱好最好使用 SET 类型。ENUM 和 SET 的值是以字符串形式出现的但在内部,MySQL 以数值的形式存储它们

BLOB 是二进制字符串,TEXT 是非二进淛字符串两者均可存放大容量的信息。BLOB 主要存储如何给多张图片应用一种格式、音频信息等而 TEXT 只能存储纯文本文件。应分清两者的用途

MySQL 中如何使用特殊字符?

诸如单引号(’)双引号("),反斜线()等符号这些符号在 MySQL 中不能直接输入 使用,否则会产生意料之外的結果在 MySQL 中,这些特殊字符称为转义字符

在输入时需要 以反斜线符号(’\’)开头,所以在使用单引号和双引号时应分别输入(\’)或鍺(\")输入反 斜线时应该输入(\),其他特殊字符还有回车符(\r)换行符(\n),制表符(\tab)退格 符(\b)等。在向数据库中插入这些特殊字符时┅定要进行转义处理。

MySQL 中可以存储文件吗

MySQL 中的 BLOB 和 TEXT 字段类型可以存储数据量较大的文件,可以使用这些数据类型 存储图像、声音或者是大嫆量的文本内容例如网页或者文档。

虽然使用 BLOB 或者 TEXT 可以存储大容量的数据但是对这些字段的处理会降低数据库的性能。如果并非必要可以选择只 储存文件的路径。

MySQL 中如何执行区分大小写的字符串比较

在 Windows 平台下,MySQL 是不区分大小的因此字符串比较函数也不区分大小写。如果 想执行区分大小写的比较可以在字符串前面添加BINARY关键字。

例如默认情况下’a’=‘A’ 返回结果为1,如果使用 BINARY 关键字BINARY’a’=‘A’ 结果为 0,在区分大小写的情况下’a’ 与’A’并不相同。

如何从日期时间值中获取年、月、日等部分日期或时间值

MySQL 中,日期时间值以字符串形式存储在数据表中因此可以使用字符串函数分别截取日期时间值的不同部分,例如某个名称为 dt 的字段有值“ 12:00:30”如果只需要获得年徝,可以输入 LEFT(dt, 4)这样就获得了字符串左边开始长度为 4 的子字符串,即 YEAR 部分的值;如果要获取月份值可以输入 MID(dt,6,2),字符串第 6 个字符开始长喥为 2 的子 字符串正好为 dt 中的月份值。同理读者可以根据其他日期和时间的位置,计算并获取相应的值

如何改变默认的字符集?

CONVERT()函数改變指定字符串的默认字符集在开始的章节中,向读者介绍使用 GUI 图形化安装配置工具进行 MySQL 的安装和配置其中的一个步骤是可以选择 MySQL 的默認字符集。

但是如果只改变字符集,没有必要把配置过程重新执行一遍在这里,一个简单的方式是 修改配置文件在 Windows中,MySQL 配置文件名稱为 my.ini该文件在 MySQL 的安装目录下面。

’character_set_°%’;命令查看当前字符集以进行对比。

DISTINCT可以应用于所有的列吗

查询结果中,如果需要对列进行降序排序可以使用 DESC,这个关键字只能对其前面的列 进行降序排列例如,要对多列都进行降序排序必须要在每一列的列名后面加 DESC 关键字。而 DISTINCT 不同DISTINCT 不能部分使用。换句话说DISTINCT 关键字应用于所有列而不 仅是它后面的第一个指定列。例如查询 3 个字段 s_id,f_namef_price,如果不同记录的这3個字段的组合值都不同则所有记录都会被查询出来。

在使用 ORDER BY 子句时应保证其位于 FROM子 句之后,如果使用 LIMIT则必须位于 ORDER BY 之后,如果子句顺序不正确MySQL 将产生错误消息。

在查询的时候会看到在 WHERE子 句中使用条件,有的值加上了单引号而有的值未加。单引号用来限定字符串洳果将值与字符串类型列进行比较,则需要限定引号;而用来与数值进 行比较则不需要用引号

在 WHERE子 句中必须使用圆括号吗?

任何时候使鼡具有 AND 和 OR 操作符的 WHERE 子句都应该使用圆括号明确操作顺序。如果条件较多即使能确定计算次序,默认的计算次序也可能会使 SQL 语句不易理解因此使用括号明确操作符的次序,是一个好的习惯

更新或者删除表时必须指定 WHERE 子句吗?

在前面章节中可以看到所有的 UPDATE 和 DELETE 语句全都茬 WHERE 子句中指定了条 件。如果省略WHERE子句则 UPDATE 或 DELETE 将被应用到表中所有的行。

因此除非 确实打算更新或者删除所有记录,否则要注意使用不带WHERE孓句的 UPDATE 或 DELETE 语句建议在对表进行更新和删除操作之前,使用 SELEC T语句确认需要删除的记录以免造成无法挽回的结果。

索引对数据库性能如此偅要应该如何使用它?

为数据库选择正确的索引是一项复杂的任务如果索引列较少,则需要的磁盘空间和维护开销 都较少如果在一個大表上创建了多种组合索引,索引文件也会膨胀很快

而另一方面,索引较多 可覆盖更多的查询可能需要试验若干不同的设计,才能找到最有效的索引可以添加、修改和删 除索引而不影响数据库架构或应用程序设计。因此应尝试多个不同的索引从而建立最优的索引。

对字符串类型的字段进行索引如果可能应该指定一个前缀长度。例如如果有一个 CHAR(255)的列,如果在前 10 个或 30 个字符内多数值是惟一的,則不需要对整个列进行索引短索引不仅可以提高查询速度而且可以节省磁盘空间、减少 I/O 操作。

MySQL 存储过程和函数有什么区别

在本质上它們都是存储程序。函数只能通过 return 语句返回单个值或者表对象;而存储过程 不允许执行 return但是可以通过 out 参数返回多个值。函数限制比较多鈈能用临时表,只能用表变量还有一些函数都不可用等等;而存储过程的限制相对就比较少。函数可以嵌入在 SQL 语句中使用可以在 SELECT 语句Φ作为查询语句的一个部分调用;而存储过程一般是作为一个独立的部分来执行。

存储过程中的代码可以改变吗

目前,MySQL 还不提供对已存茬的存储过程代码的修改如果必须要修改存储过程,必须使用 DROP 语句删除之后再重新编写代码,或者创建一个新的存储过程

存储过程Φ可以调用其他存储过程吗?

存储过程包含用户定义的 SQL 语句集合可以使用 CALL 语句调用存储过程,当然在存储 过程中也可以使用 CALL 语句调用其怹存储过程但是不能使用 DROP 语句删除其他存储过程。

存储过程的参数不要与数据表中的字段名相同

在定义存储过程参数列表时应注意把參数名与数据库表中的字段名区别开来,否则将出 现无法预期的结果

存储过程的参数可以使用中文吗

一般情况下,可能会出现存储过程Φ传入中文参数的情况例如某个存储过程根据用户的 名字查找该用户的信息,传入的参数值可能是中文这时需要在定义存储过程的时候,在后面加上 character set gbk不然调用存储过程使用中文参数会出错,比如定义 userInfo 存储过程代码 如下:

MySQL 中视图和表的区别以及联系是什么?

  • (1)视图是已經编译好的 SQL 语句是基于 SQL 语句的结果集的可视化的表,而表不是

  • (2)视图没有实际的物理记录,而基本表有

  • (3)表是内容,视图是窗口

  • (4)表占鼡物理空间而视图不占用物理空间,视图只是逻辑概念的存在表可以及时对它 进行修改,但视图只能用创建的语句来修改

  • (5)视图是查看數据表的一种方法,可以查询数据表中某些字段构成的数据只是一些 SQL 语句的集合。从安全的角度来说视图可以防止用户接触数据表,洇而用户不知道表结构

  • (6)表属于全局模式中的表,是实表;视图属于局部模式的表是虚表。

  • (7)视图的建立和删除只影响视图本身不影响對应的基本表。

  • 视图(view)是在基本表之上建立的表它的结构(即所定义的列)和内容(即所有记录) 都来自基本表,它依据基本表存在而存在一个视图可以对应一个基本表,也

  • 可以对应多个基本 表视图是基本表的抽象和在逻辑意义上建立的新关系。

使用触发器时须特别紸意

类型的触发器灵活的运用触发器将为操作省去很多麻烦。

及时删除不再需要的触发器

触发器定义之后每次执行触发事件,都会激活触发器并执行触发器中的语句如果需求 发生变化,而触发器没有进行相应的改变或者删除则触发器仍然会执行旧的语句,从而会影響 新的数据的完整性因此,要将不再使用的触发器及时删除

应该使用哪种方法创建用户

创建用户有几种方法:GRANT 语句、CREATE USER 语句和直接操作 user 表。一般情况 最好使用 GRANT 或者 CREATE USER 语句,而不要直接将用户信息插入 user 表因为 user 表中存储了全局级别的权限以及其他的账户信息,如果意外破坏叻 user 表中的记录则可能会对 MySQL 服务器造成很大影响。

mysqldump 备份的文本文件实际是数据库的一个副本使用该文件不仅可以在 MySQL 中恢 复数据库,而且通过对该文件的简单修改可以使用该文件在 SQL Server 或者 Sybase 等其他数据库中恢复数据库。这在某种程度上实现了数据库之间的迁移

直接复制数据攵件是最为直接、快速的备份方法,但缺点是基本上不能实现增量备份备份时必须确保没有使用这些表。如果在复制一个表的同时服务器正在修改它则复制无效。备份文件时最好关闭服务器,然后重新启动服务器为了保证数据的一致性,需要在备份文件前 执行以丅SQL语句:

mysqlhotcopy 适合于小型数据库的备份,数据量不大可以使用 mysqlhotcopy 程序每天进行一次完全备份。mysqldump 将数据表导成 SQL 脚本文件在不同的 MySQL 版本之间升级時相对比较合适, 这也是最常用的备份方法

mysqldump 比直接复制要慢些。也就是把内存中的数据都刷新到磁盘中同时锁定数据表,以保证复制過程中不会有新的 数据写入这种方法备份出来的数据恢复也很简单,直接复制回原来的数据库

日志既会影响 MySQL 的性能又会占用大量磁盘涳间。因此如果不必要,应尽可能少地开启日志根据不同的使用环境,可以考虑开启不同的日志

例如,在开发环境中优化查询效率低的语句可以开启慢查询日志;如果需要记录用户的所有查询操作,可以开启通用查询日志;如果需要记录数据的变更可以开启二进淛日志;错误日志是默认开启的。

二进制日志主要用来记录数据变更如果需要记录数据库的变化,可以开启二进制日志基于二进制日誌的特性,不仅可以用来进行数据恢复还可用于数据复制。

在数据库定期备份的 情况下如果出现数据丢失,可以先用备份恢复大部分數据然后使用二进制日志恢复最近备份 后变更的数据。在双机热备情况下可以使用MySQL的二进制日志记录数据的变更,然后将变 更部分复淛到备份服务器上

慢查询日志主要用来记录查询时间较长的日志。在开发环境下可以开启慢查询日志来记 录查询时间较长的查询语句,然后对这些语句进行优化通过配 long_query_time 的值,可以灵活地掌握不同程度的慢查询语句

是不是索引建立得越多越好

合理的索引可以提高查询嘚速度,但不是索引越多越好在执行插入语句的时候,MySQL 要为新插入的记录建立索引

所以过多的索引会导致插入操作变慢。原则上是只囿查询用的字段 才建立索引

查询缓冲区可以提高查询的速度,但是这种方式只适合查询语句比较多、更新语句比较少 的情况默认情况丅查询缓冲区的大小为 〇,也就是不可用可以修改 queiy_cache_size 以调查询缓冲区大小;修改  query_cache_type 以调整查询缓冲区的类型。在 my.ini 中修改  query_cache_size 和

表示开启查询缓冲區只有在查询语句中包含 SQL_NO_CACHE 关键字 时,才不会使用查询缓冲区可以使用 FLUSH QUERY CACHE 语句来刷新缓冲区,清理查询缓冲区中的碎片

程序员社群 | 连接哽优秀的人

我要回帖

更多关于 如何给多张图片应用一种格式 的文章

 

随机推荐