MySql基本使用方法

一,基本概念
1, 常用的两种引擎:
        (1) InnoDB
        a,支持ACID,简单地说就是支持事务完整性、一致性;
        b,支持行锁,以及类似ORACLE的一致性读,多用户并发;
        c,独有的聚集索引主键设计方式,可大幅提升并发读写性能;
        d,支持外键;
        e,支持崩溃数据自修复;
        InnoDB设计目标是处理大容量数据库系统,它的CPU利用率是其它基于磁盘的关系数据库引擎所不能比的。
         它是一个可靠地事务处理引擎,不支持全文本搜索

        (2) MyISAM
        a,不支持 每次查询具有原子性
        b,只支持表所
        c,强调的是性能,其执行数 度比InnoDB类型更快,但是不提供事务支持
        d,如果执行大量的SELECT,MyISAM是更好的选择

2,  介绍:
    a,数据库-database
      保存有组织的数据的容器(通常是一个文件或一组文件)

    b,表-table
      某种特定类型数据的结构化清单
 
    c,模式-schema
      关于数据库和表的布局及特性的信息

    d,列-column
      表中的一个字段,所有表都是由一个或多个列组成的

    e,行-row

      表中的一个记录

 

    f,数据类型-datatype
      所容许的数据的类型。每个表列都有相应的数据类型,它限制(或容许)该列中存储的数据

二,mysql命令行

1,连接mysql
   格式: mysql -h主机地址 -u用户名 -p用户密码

   a, 连接到本地MYSQL
      首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root -p,
      回车后提示你输密码。 MYSQL的提示符是: mysql> 。(默认root用户没有密码)

   b,连接到远程主机上的MYSQL
     假设远程主机的IP为:218.105.110.116,用户名为root,密码为abcd123456。
     则键入以下命令:mysql -h218.105.110.116 -u root -p abcd123456;(注:u与root之间可以不用加空格,其它也一样)。

2, 启动mysql服务
   net start mysql

3,停止mysql服务
   net stop mysql

4,查询端口是否冲突

   netstat –na | findstr 8080 查看被监听的端口 , findstr用于查找后面的端口是否存在。

 

5,退出mysql
   quit或者exit退出

6,修改密码:
   格式:mysqladmin -u用户名 -p旧密码 password 新密码
   例如给root修改密码:
   mysqladmin -u root -p ab12 password djg345 

三,显示命令
    1.显示当前数据库服务器中的数据库列表
    mysql> SHOW DATABASES;

    2.显示某个数据库中的数据表

    mysql> USE 库名;//使用某个库
    mysql> SHOW TABLES;//列出库中所有的表

    3.显示数据表的结构
    mysql> DESCRIBE 表名;

    4.建立数据库
     mysql> CREATE DATABASE 库名;。

    5.建立数据表
     mysql> USE 库名。
     mysql> CREATE TABLE 表名 (字段名 VARCHAR(20), 字段名 CHAR(1));。

    6.删除数据库
     mysql> DROP DATABASE 库名;。

    7.删除数据表
     mysql> DROP TABLE 表名;。

   8.将表中记录清空
     mysql> DELETE FROM 表名;。

   9.显示表中的记录
    mysql> SELECT * FROM 表名;。

   10.往表中插入记录
   mysql> INSERT INTO 表名 VALUES (”hyq”,”M”);。

   11.更新表中数据
   mysql-> UPDATE 表名 SET 字段名1=’a',字段名2=’b’ WHERE 字段名3=’c';。

   12.用文本方式将数据装入数据表中
   mysql> LOAD DATA LOCAL INFILE “D:/mysql.txt” INTO TABLE 表名;。

   13.导入.sql文件命令
   mysql> USE 数据库名;。
   mysql> SOURCE d:/mysql.sql;。

  14.命令行修改root密码
   mysql> UPDATE mysql.user SET password=PASSWORD(’新密码’) WHERE User=’root’;。
   mysql> FLUSH PRIVILEGES;。

  15.显示use的数据库名
  mysql> SELECT DATABASE();。

  16.显示当前的user
  mysql> SELECT USER();。

 

视图

视图是一个虚拟表(非真实存在),其本质是【根据SQL语句获取动态的数据集,并为其命名】,用户使用时只需使用【名称】即可获取结果集,并可以将其当作表来使用。

SELECT
    *
FROM
    (
        SELECT
            nid,
            NAME
        FROM
            tb1
        WHERE
            nid > 2
    ) AS A
WHERE
    A. NAME > 'alex';

触发器

对某个表进行【增/删/改】操作的前后如果希望触发某个特定的行为时,可以使用触发器,触发器用于定制用户对表的行进行【增/删/改】前后的行为。

delimiter //
CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROW
BEGIN
    IF NEW. num = 666 THEN
        INSERT INTO tb2 (NAME)
        VALUES
            ('666'),
            ('666') ;
    ELSEIF NEW. num = 555 THEN
        INSERT INTO tb2 (NAME)
        VALUES
            ('555'),
            ('555') ;
    END IF;
END//
delimiter ;

存储过程

存储过程是一个SQL语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。

-- 创建存储过程
delimiter \\
create procedure p1(
    in i1 int,
    in i2 int,
    inout i3 int,
    out r1 int
)
BEGIN
    DECLARE temp1 int;
    DECLARE temp2 int default 0;
   
    set temp1 = 1;

    set r1 = i1 + i2 + temp1 + temp2;
   
    set i3 = i3 + 100;

end\\
delimiter ;

-- 执行存储过程
set @t1 =4;
set @t2 = 0;
CALL p1 (1, 2 ,@t1, @t2);
SELECT @t1,@t2;

函数

MySQL中提供了许多内置函数

delimiter \\自定义函数
create function f1(
    i1 int,
    i2 int)
returns int
BEGIN
    declare num int;
    set num = i1 + i2;
    return(num);
END \\
delimiter ;

事务

事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性。

delimiter \\
create PROCEDURE p1(
    OUT p_return_code tinyint
)
BEGIN
  DECLARE exit handler for sqlexception
  BEGIN
    -- ERROR
    set p_return_code = 1;
    rollback;
  END;

  DECLARE exit handler for sqlwarning
  BEGIN
    -- WARNING
    set p_return_code = 2;
    rollback;
  END;

  START TRANSACTION;
    DELETE from tb1;
    insert into tb2(name)values('seven');
  COMMIT;

  -- SUCCESS
  set p_return_code = 0;

  END\\
delimiter ;
函数与存储过程的区别

    存储过程和函数存在以下几个区别:

    1)一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作。

    2)对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象。函数只能返回一个变量;而存储过程可以返回多个。存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。

    3)存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。

    4)存储过程一般是作为一个独立的部分来执行( CALL 语句执行),而函数可以作为查询语句的一个部分来调用(SELECT调用)。 SQL语句中不可用存储过程,而可以使用函数