Heim >Datenbank >MySQL-Tutorial >Erinnern Sie sich an die „L's in MySQL?

Erinnern Sie sich an die „L's in MySQL?

Java后端技术全栈
Java后端技术全栈nach vorne
2023-08-24 15:45:261058Durchsuche

Hallo zusammen, heute möchte ich mit euch teilen: Erinnert ihr euch an die „L“s in MySQL?

Wenn wir gerade erst mit dem Erlernen von Datenbankkenntnissen beginnen, werden wir zunächst mit verschiedenen L in Kontakt kommen, wobei L der erste Buchstabe der Sprache Sprache ist.

Es gibt ungefähr folgende Typen:

  • DQL
  • DML
  • DCL
  • DDL
  • TCL

Im Folgenden möchte ich Sie einzeln durchgehen.

DQL

bezieht sich aufselect查询语句(Data query language),基本结构是由 select子句,from子句,whereusw.

Einzeltabellenabfrage

-- 格式
SELECT selection_list /*要查询的列名称*/
  FROM table_list /*要查询的表名称*/
  WHERE condition /*行条件*/
  GROUP BY grouping_columns /*对结果分组*/
  HAVING condition /*分组后的行条件*/
  ORDER BY sorting_columns /*对结果排序*/
  LIMIT offset_start, row_count /*结果限定*/

Spezifizierte Spalten nach Bedingungen abfragen

SELECT t_man.Mname,t_man.Mage FROM t_man WHERE t_man.Mage > 30

-- --------------查询条件----------------------------

-- 1.逻辑运算符
-- NOT : 取反
WHERE NOT t_man.Mage > 30
-- AND : 逻辑与
WHERE t_man.Mage > 30 AND t_man.Mname LIKE '_'
-- OR : 逻辑或
WHERE t_man.Mage > 30 OR t_man.Mname LIKE '_'

-- 2.比较运算符
=、<>、!=、>、>=、!>、<、<=、!<

-- 3.LIKE,用于模糊查询
-- % : 后面可以跟零个或多个字符
-- _ : 匹配任意单个字符
-- [ ] : 查询一定范围内的单个字符,包括两端数据
WHERE t_man.Mname LIKE &#39;[周李]%&#39;
-- [^] [!]: 表示不在一定范围内的单个字符,包括两端数据

-- 4.BETWEEN
between xx and xx
WHERE t_man.Mage BETWEEN 30 AND 31 (等同于 t_man.Mage>=30 AND t_man.Mage<=31)
not between xx and xx

-- 5.is (not) null
-- 在 where 子句中,需要用 is (not) null 判断空值,不能使用 = 判断空值
WHERE t_man.Mage is not null

-- 6.in 多条件
WHERE t_man.Mage IN (30,31)

-- 7.ALL SOME ANY
-- Some 和 any 等效,all 是大于最大者,any 是小于最小者
WHERE t_man.Mage > ALL(SELECT t_man.Mage FROM t_man WHERE t_man.Mname LIKE &#39;张%&#39;)

-- 8.exists 和 no exists
WHERE exists (select * from t_man where t_man.Mid = 8001)

-- 9.Group by 分组
SELECT AVG(t_man.Mage) FROM t_man GROUP BY t_man.Msex

-- 10.Having 分组后条件
SELECT AVG(t_man.Mage) AS mk,t_man.Msex FROM t_man GROUP BY t_man.Msex HAVING mk > 30

-- 11.ORDER BY 排序 ASC,DESC
SELECT * FROM t_man ORDER BY t_man.Mid ASC

-- 12.DISTINCT 去重
SELECT DISTINCT(t_man.Msex) FROM t_man

-- 13.LIMIT 分页(显示第一行数据)
SELECT * FROM t_man LIMIT 0,1

Verbindungsabfrage

-- 交叉连接(Cross Join),没有链接条件的表查询会出现笛卡儿积
SELECT * FROM t_man,t_dept
SELECT * FROM t_man JOIN t_dept

-- 内连接(inner Join 或 Join),两表中都有才显示,即两表的交集
SELECT * FROM t_man JOIN t_dept ON t_man.Mid = t_dept.Mid

-- 左外连接(Left outer Join),以左边表为主,左表全部显示,没有对应的就显示空,即左并集
SELECT * FROM t_man LEFT JOIN t_dept ON t_man.Mid = t_dept.Mid

-- 右外连接(Right outer Join),与左外连接相反
SELECT * FROM t_man RIGHT JOIN t_dept ON t_man.Mid = t_dept.Mid

-- 全连接(Full outer Join),默认不支持,但也其他方式可以实现。
SELECT * FROM t_man LEFT JOIN t_dept ON t_man.Mid = t_dept.Mid
UNION
SELECT * FROM t_man RIGHT JOIN t_dept ON t_man.Mid = t_dept.Mid

-- UNION ALL 与 UNION 区别是允许重复

Verwenden Sie Bilder, um es anschaulicher auszudrücken:

Erinnern Sie sich an die „L's in MySQL?
img

DML

DML bezieht sich auf die Datenmanipulationssprache, der vollständige englische Name ist Data Manipulation Language, die zum Aktualisieren von Datensätzen in Tabellen in der Datenbank verwendet wird. Schlüsselwörter: Einfügen, Löschen, Aktualisieren usw. werden zum Bearbeiten von Daten verwendet.

Einfügen

Einfügen einfügen

insert into 表 (列名1,列名2,列名3...) values (值1,值2,值3...); //向表中插入某些列
insert into 表 values (值1,值2,值3...);  //向表中插入所有列

Hinweis:

  1. Die Anzahl der Spaltennamen entspricht der Anzahl der Werte nach Werten
  2. Die Reihenfolge der Spalten ist konsistent mit der Reihenfolge der eingefügten Werte
  3. Der Typ des Spaltennamens muss mit dem eingefügten Wert übereinstimmen
  4. Beim Einfügen des Werts darf dieser die maximale Länge nicht überschreiten
  5. Wenn der Wert eine Zeichenfolge ist oder Datum, es muss zitiert werden ''

aktualisieren

Daten aktualisieren

update 表名 set 字段名=值,字段名=值...;
update 表名 set 字段名=值,字段名=值... where 条件;

注意:

  1. 列名的类型与修改的值要一致
  2. 修改值的时候不能超过最大长度
  3. 值如果是字符串或者日期要加’’

delete

delete删除数据

delete from 表名 [where 条件];

注意:

删除表中所有记录使用delete from 表名;还是truncate table 表名;?删除方式:delete一条一条的删除,不清空auto_increment(自增)记录数;truncate 直接删除表,重新建表,auto_increment讲置为0,重新开始。事务方面:delete删除的数据,如果在一个事务中可以找回;truncate 删除的数据找不回来。

DCL

DCL是数据控制语言Data Control Language)的简称,它包含诸如GRANT之类的命令,并且主要涉及数据库系统的权限,权限和其他控件。

  • GRANT :允许用户访问数据库的权限
  • REVOKE:撤消用户使用GRANT命令赋予的访问权限

DCL 语句主要是DBA 用来管理系统中的对象权限时所使用,一般的开发人员很少使用。

案例演示

下面 通过一个例子来简单说明一下。创建一个数据库用户plf,具有对plf数据库中所有表的SELECT/INSERT 权限:

mysql> grant select,insert on plf.* to &#39;plf&#39;@&#39;%&#39; identified by &#39;123456&#39;;
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

mysql> quit
Bye



[root@mysql ~]# mysql -uplf -p123456 -h 192.168.3.100
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 7
Server version: 5.6.37 Source distribution

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type &#39;help;&#39; or &#39;\h&#39; for help. Type &#39;\c&#39; to clear the current input statement.

mysql> use mysql;
ERROR 1044 (42000): Access denied for user &#39;plf&#39;@&#39;%&#39; to database &#39;mysql&#39;
mysql> use plf
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed

由于权限变更,需要将 plf 的权限变更,收回 INSERT,只能对数据进行 SELECT 操作,这时我们需要使用root账户进行上述操作:

mysql> revoke insert on plf.* from &#39;plf&#39;@&#39;%&#39;;
Query OK, 0 rows affected (0.00 sec)

mysql> quit
Bye





[root@mysql ~]# mysql -uplf -p123456 -h 192.168.3.100
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.6.37 Source distribution

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type &#39;help;&#39; or &#39;\h&#39; for help. Type &#39;\c&#39; to clear the current input statement.

mysql> use plf
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+---------------+
| Tables_in_plf |
+---------------+
| dept          |
| emp           |
| hk_info       |
| log_info      |
| user_info     |
+---------------+
5 rows in set (0.00 sec)

mysql> insert into dept values(7,&#39;plf&#39;);
ERROR 1142 (42000): INSERT command denied to user &#39;plf&#39;@&#39;192.168.3.100&#39; for table &#39;dept&#39;
mysql> select*from dept;
+--------+----------+
| deptno | deptname |
+--------+----------+
|      1 | tech     |
|      2 | sale     |
|      3 | hr       |
|      5 | fin      |
+--------+----------+
4 rows in set (0.00 sec)

以上例子中的grant和revoke分别授出和收回了用户plf的部分权限,达到了我们的目的。

DDL

DDL是数据定义语言(Data Definition Language)的简称,它处理数据库schemas和描述数据应如何驻留在数据库中。

  • CREATE:创建数据库及其对象(如表,索引,视图,存储过程,函数和触发器)
  • ALTER:改变现有数据库的结构
  • DROP:从数据库中删除对象
  • TRUNCATE:从表中删除所有记录,包括为记录分配的所有空间都将被删除
  • COMMENT:添加注释
  • RENAME:重命名对象

常用命令如下:

# 建表
CREATE TABLE sicimike  (
  id int(4) primary key auto_increment COMMENT &#39;主键ID&#39;,
  name varchar(10) unique,
  age int(3) default 0,
  identity_card varchar(18)
  # PRIMARY KEY (id) // 也可以通过这种方式设置主键
  # UNIQUE KEY (name) // 也可以通过这种方式设置唯一键
  # key/index (identity_card, col1...) // 也可以通过这种方式创建索引
) ENGINE = InnoDB;

# 设置主键
alter table sicimike add primary key(id);

# 删除主键
alter table sicimike drop primary key;

# 设置唯一键
alter table sicimike add unique key(column_name);

# 删除唯一键
alter table sicimike drop index column_name;

# 创建索引
alter table sicimike add [unique/fulltext/spatial] index/key index_name (identity_card[(len)] [asc/desc])[using btree/hash]
create [unique/fulltext/spatial] index index_name on sicimike(identity_card[(len)] [asc/desc])[using btree/hash]
example: alter table sicimike add index idx_na(name, age);

# 删除索引
alter table sicimike drop key/index identity_card;
drop index index_name on sicimike;

# 查看索引
show index from sicimike;

# 查看列
desc sicimike;

# 新增列
alter table sicimike add column column_name varchar(30);

# 删除列
alter table sicimike drop column column_name;

# 修改列名
alter table sicimike change column_name new_name varchar(30);

# 修改列属性
alter table sicimike modify column_name varchar(22);

# 查看建表信息
show create table sicimike;

# 添加表注释
alter table sicimike comment &#39;表注释&#39;;

# 添加字段注释
alter table sicimike modify column column_name varchar(10) comment &#39;姓名&#39;;

TCL

TCL是事务控制语言Transaction Control Language)的简称,用于处理数据库中的事务

  • COMMIT: Transaktion festschreiben
  • COMMIT:提交事务
  • ROLLBACK:在发生任何错误的情况下回滚事务
  • 事务的概念

    事务是由一条或多条SQL语句组成的一个执行单元,这个单元作为一个不可分割的执行整体,要么全部执行成功,要么全部执行失败。若其中有一条执行失败则事务会回滚到事务开始之前的状态。事务有四个属性(ACID):原子性、一致性、隔离性、持久性

    • 原子性(Atomicity):指事务是一个不可分割的整体,事务中的操作要么都执行,要么都不执行。
    • 一致性(Consistency):事务必须是数据库从一个一致性状态变为另一个一致性状态。
    • 隔离性(Isolation):指一个事务的执行不能被其他事务干扰,即一个事务内部的操作及其使用的数据对并发的其他事务是隔离的,并发执行的各个事务之前不能相互干扰。这个在高并发环境下尤为重要,事务隔离的程度跟选择的隔离级别有很大关系。
    • 持久性:一个事务一旦提交,对数据库中数据的改变就是永久性的。

    注意:

    事务仅对数据的增删改操作有效,对于表的定义、表结构的变化等是没有事务的概念的。

    存储引擎和事务

    存储引擎是指数据存储时使用的不同的技术,并不是所有的存储引擎都支持事务,Mysql中常用的存储引擎中只有InnoDB是支持事务的,MyIsam和Memory则不支持事务。

    Mysql中查看存储引擎的方式:show engines;

    ROLLBACK: Rollback der Transaktion im Fehlerfall <h3 data-tool="mdnice editor" style="font-weight: Bold;font-size: 20px;line-height: 1.4;padding-top: 10px;margin-top: 10px;margin-bottom: 5px ;"> <span style="display: none;"></span><span style="color: rgb(81, 81, 81);font-size: 1em;padding-left: 20px;border-left: 3px solid rgb(249, 191, 69);">Konzept von Transaktionen</span><span style="display: none;"></span> </h3> <p data-tool="mdnice editor" style=" margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58);">Eine Transaktion ist eine Ausführungseinheit, die aus einer oder mehreren SQL-Anweisungen besteht. Diese Einheit ist auch ein unteilbares Ganzes Alle Ausführungen sind erfolgreich oder alle Ausführungen schlagen fehl. Wenn einer von ihnen nicht ausgeführt werden kann, wird die Transaktion auf den Zustand vor Beginn der Transaktion zurückgesetzt. Transaktionen haben vier Attribute (ACID): Atomizität, Konsistenz, Isolation und Haltbarkeit: bedeutet, dass eine Transaktion ein unteilbares Ganzes ist und alle Vorgänge in der Transaktion entweder ausgeführt werden oder nicht. 🎜🎜Konsistenz: Eine Transaktion muss die Datenbank von einem Konsistenzzustand in einen anderen ändern. 🎜🎜Isolation (Isolation): bedeutet, dass die Ausführung einer Transaktion nicht durch andere Transaktionen beeinträchtigt werden kann, dh die Vorgänge innerhalb einer Transaktion und die verwendeten Daten werden von anderen gleichzeitigen Transaktionen isoliert und gleichzeitig ausgeführt Die einzelnen Transaktionen können sich vorher nicht gegenseitig stören. Dies ist besonders wichtig in Umgebungen mit hoher Parallelität. Der Grad der Transaktionsisolation hängt stark von der gewählten Isolationsstufe ab. 🎜🎜Persistenz: Sobald eine Transaktion festgeschrieben wurde, sind die Änderungen an den Daten in der Datenbank dauerhaft. </p> <p data-tool="mdnice editor" style="margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58); ">Hinweis: 🎜</p> <blockquote data-tool="mdnice editor" style="border-top: none;border-right: none;border-bottom: none;font-size: 0.9em;overflow: auto;color: rgb( 106, 115, 125);padding: 10px 10px 10px 20px;margin-unten: 20px;margin-top: 20px;border-left-color: rgb(255, 177, 27);background: rgb(255, 245 , 227 );"><p style="font-size: 16px;line-height: 26px;color: rgb(89, 89, 89);">Transaktionen sind nur für Vorgänge zum Hinzufügen, Löschen und Ändern von Daten sowie für Tabellen gültig Definitionen, Tabellenstrukturänderungen usw. haben kein Transaktionskonzept. 🎜</p></blockquote> <h3 data-tool="mdnice editor" style="font-weight: Bold;font-size: 20px;line-height: 1.4;padding-top: 10px;margin-top: 10px;margin - unten: 5px;"> <span style="display: none;"></span><span style="color: rgb(81, 81, 81);font-size: 1em;padding-left: 20px; border -left: 3px solid rgb(249, 191, 69);">Speicher-Engines und Transaktionen</span><span style="display: none;"></span> </h3> <p data-tool=" mdnice editor" style="margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58);">Speicher-Engines beziehen sich auf verschiedene Technologien, die bei der Datenspeicherung verwendet werden, nicht alle. Alle Speicher-Engines unterstützen Transaktionen Von den in MySQL häufig verwendeten Speicher-Engines unterstützt nur InnoDB Transaktionen, während MyIsam und Memory keine Transaktionen unterstützen. 🎜</p> <p data-tool="mdnice editor" style="margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58);">So zeigen Sie die Speicher-Engine in MySQL an:Show Engines;🎜<figure data-tool="mdnice编辑器" style="margin-top: 10px;margin-bottom: 10px;display: flex;flex-direction: column;justify-content: center;align-items: center;"><img src="https://img.php.cn/upload/article/001/273/727/aa32515dbe5f6974289605941e35341e-1.png" alt="Erinnern Sie sich an die „L's in MySQL?" ><figcaption style="max-width:90%">在这里插入图片描述</figcaption></figure></p> <h3 data-tool="mdnice编辑器" style="font-weight: bold;font-size: 20px;line-height: 1.4;padding-top: 10px;margin-top: 10px;margin-bottom: 5px;"> <span style="display: none;"></span><span style="color: rgb(81, 81, 81);font-size: 1em;padding-left: 20px;border-left: 3px solid rgb(249, 191, 69);">事务的分类</span><span style="display: none;"></span> </h3> <p data-tool="mdnice编辑器" style="margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58);">事务有隐式事务和显示事务之分,区别在于有没有显式的事务开启和结束标记。</p> <p data-tool="mdnice编辑器" style="margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58);">默认的INSERT、UPDATE、DELETE语句都是会自动提交的,事务提交后是不能够回滚的。这跟数据库的autocommit属性的设置有关,默认情况下都是开启自动提交的。</p> <p data-tool="mdnice编辑器" style="margin-bottom: 20px;line-height: 1.8em;color: rgb(58, 58, 58);">可通过<code style='font-size: 14px;border-radius: 4px;font-family: "Operator Mono", Consolas, Monaco, Menlo, monospace;word-break: break-all;color: rgb(155, 110, 35);background-color: rgb(255, 245, 227);padding: 3px;margin: 3px;'>SHOW VARIABLES;查看数据库的属性设置。

    Erinnern Sie sich an die „L's in MySQL?
    img

    隐式事务举例:默认情况下的增删改

    DELETE FROM table_a WHERE id = 1;

    显示事务:在开启显示事务之前一定要关闭事务的自动提交

    #关闭事务的自动提交
    SET autocommit = 0;#该语句仅对当前事务有效

    显示事务举例:具有明显的事物开启和结束标记,事务结束要么提交要么回滚

    #开启事务
    SET autocommit = 0;#有了这句代码就会开启事务
    START TRANSACTION;#这句代码可省略
    #事务的执行语句
    UPDATE account
    SET balance = 500
    WHERE
     username = &#39;张无忌&#39;;
    UPDATE account
    SET balance = 1500
    WHERE
     username = &#39;赵敏&#39;;
    #事务提交
    COMMIT;
    #ROLLBACK;#事务回滚

    事务的隔离级别

    对于并发运行的多个事务,当这些事务访问相同的数据时,如果没有采取必要的隔离机制,就会导致各种并发问题:

    • 脏读:对于两个事务T1、T2,T1读取了已经被T2更新但还没有提交的数据之后,T2回滚了,则T1读取的数据就是无效的,这就是脏读。
    • 不可重复读:对于两个事务T1、T2,T1读取数据后,T2更新了T1读取的数据,此时T1再次读取该数据时会和前一次不一样,这称为不可重复读。
    • 幻读:对于两个事物T1、T2,T1读取一个表中的数据后,T2向该表中插入了新的数据,T1再次读取这个表时发现多出了新的数据,这称为幻读。

    事务的隔离级别:一个事务与其他事务隔离的程度称为隔离级别,数据库中有多种隔离级别,不同的隔离级别对应不同的干扰程度,隔离级别越高,数据一致性就越好,但并发性越弱。

    数据库的4种事务隔离级别:

    Erinnern Sie sich an die „L's in MySQL?


    注意:

    可重复读是行锁,行锁只能保证事务中被操作的数据行不能被其他事务修改,但是无法保证其他事务向该表中插入新数据,因此无法解决幻读的问题;串行化则是表锁,表锁是说在一个事务中一旦操作了某个表,则在该事务提交或回滚之前所有对该表的增删改查操作都将等待,因此可以解决幻读的问题,但是效率低下。

    Oracle支持READ COMMITTED和SERIALIZABLE两种隔离级别,默认为READ COMMITTED;Mysql支持上述4中事务隔离级别,默认为REPEATABLE READ(可重复读)

    查看隔离级别:SELECT @@tx_isolation;

    设置隔离级别:

    #设置当前连接的隔离级别:SESSION可以省略
    SET [SESSION] TRANSACTION ISOLATION LEVEL 隔离级别;
    #设置全局的隔离级别
    SET GLOBAL TRANSACTION ISOLATION LEVEL 隔离级别;

    事务的保存点

    事务的保存点(SAVEPIONT)其实就是指定事务可回滚到的一个节点,有时我们并不一定要将整个事务的所有操作都进行回滚,而是只回滚该事务中的某一部分操作,这个时候就需要用到事务的保存点,一个事务中可以有多个保存点,多个保存点间根据名称区分。

    SET autocommit = 0;
    START TRANSACTION;
    DELETE FROM account WHERE id = 2;
    SAVEPOINT a; #设置一个保存点
    DELETE FROM account WHERE id = 3;
    ROLLBACK TO a; #回滚到a保存点

    好了,以上便是今天分享的MySQL中的各种L(Language)。

    Das obige ist der detaillierte Inhalt vonErinnern Sie sich an die „L's in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Stellungnahme:
    Dieser Artikel ist reproduziert unter:Java后端技术全栈. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen