MySQL必知必会笔记<2>

【英】ben Forta著

5

  1.0  *使用扩展查询*

        |---->select note from table   where Match(note)
Against(‘anl‘);

                       |--->where  Match(note)
Against(‘anl‘  WITH QUERY EXPANSION);

                       |--->按等级返回与第一行(优先级最高)有关的行,表中行越多,使用扩展查询结果越好。

  2.0  *关于insert*

      |--->insert操作耗时,可能降低等待处理的select语句性能。解决方案:

                                     |-->在insert和into之间插入LOW_PRIORITY(降低优先级)

                                     |-->同样适用于 UPDATAE
,DELETE语句。

    *提高insert性能*------>MySQL用单条insert语句处理多个插入比使用多条insert语句快。====
values (),(),()...

    *关于 INSERT
SELECT的使用,顾名思义就是把SELECT语句的内容作为INSERT的插入部分*

      |--->eg:      insert into 表名1(列) select 列 from
表名2

  3.0  *关于布尔文本搜索*    即使没有FULLTEXT索引也可以使用。

          eg:   select note

              from 表

              where Match(note) Against(‘heavy -ropt*‘ IN
BOOLEAN MODE);

              |--->为了匹配包含heavy,但不包含以rope开始词的行。

       *全文本布尔操作符*

         

       ---- 几个经典例子:

  4.0   *关于IGNORE*

          UPDATE 更新多行时,一行出错就会发生错误。

              |--->解决方案:UPDATE IGNORE .......

      *为了删除某个 列的值,可以设置他为NULL*

             
|---->delete 删除整行而不是某个列,若删除列用update语句。

                 
         |---->删除行,所有的行,但不会删除表本身。

             
*若要删除所有行,TRUNCATE TABLE (删除一个表,重新创建一个表)

  5.0

         *MySQL没有撤销(undo)按钮*

      
|---》NULL值是没有值,不是空串,空串是有一个有效的值,不是无值。

            |---》AUTO_INCREMENT (每个表只允许一个这样的列,而且他必须被索引)

        select last_insert-id()

            |----->返回最后一个AUTO_INCREMENT值。

6

    1.0   *关于MSQL引擎*

|

        |--->InnoDB 创建表最后一句常用。|ENGINE = InnoDB;

           |---->可靠的事务处理引擎,不支持全文本搜索

       |

       |--->MEMORY 功能等同于MYISAM,由于数据存储在内存,比较快,适用于临时表。

       |

       |--->MyISAM(大多数默认的引擎)支持全文本搜索,不支持事务处理。

    ****    外键不能跨引擎 ***

*ALTER TABLE 常用来定义外键*

|---->  eg:  
alter table 表名

             Add CONSTRAINT 列

            FOREIGN KEY () REFERENCE 表 (列)

  2.0

     *视图不能索引也不能有关联的触发器或默认值*

      SHOW CREATE VIEW  viewname;------>查看创建视图的语句

*关于更新*---------->先DROP再用CREATE ,也可以用CREATE OR REPLACE VIEW

      |------->insert update delete

        若有以下则不能更新:| 分组(group by having)

                  | 联结

                    | 子查询

                  |并

                  |聚集函数

                  |Distinct

                  |导出列

  3.0

     *关于创建存储过程*

          | CREATE PROCEDURE 存储名()

BEGIN

select语句

           END;

          引用存储过程的语句: CALL 存储名();

                    |--->将会显示select语句的查询结果。

        删除语句: DROP PROCEDURE 存储名;(如果删除的不存在将会出现    错误)

                                        |--->解决方案: DROP
PROCEDURE IF EXISTS;

  4.0

      MYSQL命令行客户机分隔符

          DELTMITER //

           A

END //

DELTMITER ;(除\符号以外)

5.0

      *存储过程本质是一个函数*

       注释语句:--

        SHOW CREATE PROCEDURE      
存储名;

                     |---> STATUS LIKE
‘存储名‘;--------->like限制输出

  6.0

    *关于游标*
 是一个存储在MYSQL服务器上的数据库查询,他不是一条select语句,而是被该语句检索出来的结果集。
不像多数DBMS,MYSQL游标只用于存储过程(函数)

    *触发器* ------->只有表才支持,视图不支持。

      CREATE TRIGGER ....

      FOR EACH ROW SELECT语句

         |----->对每个插入行都执行。

  7.0

    事务处理用来维护数据库完整性。

      START TRANSACTIDN

      当COMMIT或ROLLBACK语句执行时,事务会自动关闭。

如果不想让事务自动提交,则可以 SET AUTOCOMMIT
= 0;(不自动提交)------------>针对的是连接,不是服务器。

7

    1.0       *关于安全*

            CREATE USER ben IDENTIFIED BY ‘[email protected]‘;(创建一个用户口令)

                        |---->指定口令为纯文本

            RENAME USER ben TO f;

            drop user ben;

|--------->删除帐号以及相关帐号权限

            SET PASSWORD FOR ben = password(‘n3w
[email protected]‘);------------>更改口令。如果没有则更改的是自己。

    2.0 *关于权限的问题*

        GRANT 和REVOKE

            |----->GRANT ALL和REVOKE ALL,对应于整个服务器

            |----->ON DATABASE.*; 对应于整个数据库

            |----->ON DATABASE.TABLE;对应于特定的表

            |----->其他权限见下表

    3.0 *关于数据库的维护*

        *使用命令行实用程序MYSQLDUMP转储所有数据库内容到另外一个文件。

        *使用命令行实用程序MYSQLHOTCOPY从一个数据库复制所有数据。

        *ANALYZE TABLE用来检查表健是否正确。

        *CHECK TABLE用来针对许多问题对表进行检查。

    4.0

        查看日志:

              错误日志 hostname.err 位于data目录中。可用--log-error命令选项更改

              查询日志:hostname.log  --log

               二进制日志:hostname-bin --log-bin

              缓慢查询日志: hostname-slow.log        
     --log-slow-queries

**在使用日志时,可用FLUSH LOGS语句来刷新和重新开始所有的日志文件**

    5.0

           *MYSQL变量都必须以@开始*

        存储过程的一个例子:

            |---->create procedure 名字 (out p1
Decimal(8,2))------->"Decimal 十进位"

            |        BEGIN SELECT MIN(列) INTO P1
end;

       *串在字符集之间进行转换,使用cast()或 convert()函数*

时间: 2024-12-23 18:33:00

MySQL必知必会笔记<2>的相关文章

MySQL必知必会 学习笔记(一)

第一章  了解SQL 模式:   关于数据库和表的布局以及特性的信息.[描述表可以存储什么样的数据,数据如何分解,各部分信息如何命名等等,可以用来描述数据库中特定的表以及整个数据库(和其中表的关系)]. 第二章 MySQL简介 MySQL是一种DBMS,即它是一种数据库软件.基于客户机----服务器的数据库. MySQL工具: 1.mysql 命令行实用程序 2.MySQL Administrator 3.MySQL query Browser 第四章 检索数据 LIMIT 5 表示MySQL返

《MySQL必知必会》读书笔记_4

PS:一个实际的存储过程案例 CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_delete_article_by_id`(IN `id` int) BEGIN #Routine body goes here... DECLARE temp INT; SET @aid = id; SELECT COUNT(*) FROM gk_reply_article WHERE a_id = @aid INTO temp; IF(temp <> 0) THEN

《MySQL必知必会》读书笔记_3

PS:这次的信息量有点大. 聚集不同值 SELECT AVG(DISTINCT prod_price) AS avg_price FROM products WHERE vend_id = 1003 #相同的值不会被计算 组合聚集函数 SELECT COUNT(*) AS num_items, MIN(prod_price) AS price_min, MAX(prod_price) AS price_max, AVG(prod_price) AS price_avg FROM products

《MySQL必知必会》学习笔记_1

#选择数据库 USE mysql #返回可用数据库列表 SHOW DATABASES #返回当前数据库中可用表 SHOW TABLES #返回表列 SHOW COLUMNS FROM db #显示特定数据库的创建语句 SHOW CREATE DATABASE mysql #显示广泛的服务器状态信息 SHOW STATUS #显示授权用户的安全权限 SHOW GRANTS 多条SQL语句必须以分号分隔. SQL语句不区分大小写,习惯性大写. 检索不同的行用DISTINCT,只返回不同的值. 限制结

《mysql必知必会》读书笔记--存储过程的使用

以前对mysql的认识与应用只是停留在增删改查的阶段,最近正好在学习mysql相关内容,看了一本书叫做<MySQL必知必会>,看了之后对MySQL的高级用法有了一定的了解.以下内容只当读书笔记. 如有转载请注明出处~ 存储过程的使用 执行存储过程 CALL productpricing() 执行名为productpricing的存储过程 创建存储过程 CREATE PROCEDURE productpricing() BEGIN SELECT avg(prod_price) AS pricea

《mysql必知必会》笔记-部分

<mysql必知必会>笔记-部分 注释: 开始时整理笔记,记录自己看书过程的疑问和重点,后来发现记录没太多意义,还不如直接去翻原书,所以就放弃了. 因此,这个笔记只有一部分,不过依旧分享出来. 1.语言分类: 客户机可以是MySQL提供的工具.脚本语言(如perl).Web应用开发语言(如ASP.ColdFusion.JSP和PHP).程序设计语言(如C.C+kJava)等. 2.之前找不到表的原因: 虽然SQL是不区分大小写的,但有些标识符(如数据库名.表名.列名)可能不同:在MySQL4.

《MySQL必知必会学习笔记》:正则表达式

正则表达式的应用 前面的几节的过滤例子允许用匹配.比较和通配操作符来寻找数据.对于基本的数据过滤,这样就足够了.但是随着过滤条件的复杂性的增加,where子句本身的复杂性也有必要增加.这也就是正则表达式变得有用的地方. 正则表达式是用来匹配文本中特殊的字符集合. 正则表达式不是自己第一次见,在JAVA/C++ 这些语言中,都有正则表达式,不过他们的用途是一样的,都是匹配文本中的字符串.可能具体的用法不太一样,但也差不多.下面将一一进行学习.介绍. 基本字符的匹配 当我们想查找某列中的字符中是否有

《MySQL必知必会》学习笔记

<MySQL必知必会>注重实用性,操作性很强,适用于广大软件开发和数据库管理人员学习参考,Amazon全五星评价.学习与参考皆宜.

读《MySql必知必会》笔记

MySql必知必会 2017-12-21 意义:记录个人不注意的,或不明确的,或不知道的细节方法技巧,此书250页 登陆: mysql -u root-p -h myserver -P 9999 SHOW STATUS,用于显示广泛的服务器状态信息 DESCRIBE tableName;是SHOW COLUMNS FROM tableName;的一种快捷方式 SHOW CREATE DATABASE和SHOW CREATE TABLE,分别用来显示创建特定数据库或表的MySQL语句 SHOW G

《 MySQL必知必会》笔记_持续更新

< MySQL必知必会> structured querylanguage,MySQL是一个数据库系统管理软件软件,也可以理解为为数据库服务器.读音,my sequel,/?si?kw?l / see kuo 第1.2.3章 schema,提要纲要,column列.row行 数据库:一某种有组织的方式来储存的数据集合 DBMS databasemanegersystem数据库管理系统 table,表,某种特殊类型数据的结构化清单 一个数据中,表名称有唯一性 表的特性,我们用schema[模式]