Inhaltsverzeichnis
1,创建一个序列列兵生成序列值
2,序列生成的行删除的效果
3,查询序列值
4,对一个已有的序列进行重新计数
5,序列化一个未序列的表
6,使用auto_increment 栏创建多重序列
7,使用auto_increment值将表进行关联
Heim Datenbank MySQL-Tutorial MySQL Cookbook第11章读书笔记

MySQL Cookbook第11章读书笔记

Jun 01, 2016 pm 01:07 PM

1,创建一个序列列兵生成序列值

使用auto_increment

image

image

如果显式地把ID设置成一个非NULL的值,有两个结果:

a,这个值在表中出现,由于id列是主键,因而不允许重复,故会出现错误

b,这个值没有出现例如,你的表中id序列值为1到8,此时你插入一个新航,并设置为20,那么下一个自动产生的序列就会从21开始,而9-19的值变得不可用。

2,序列生成的行删除的效果

例如在insect表中:

image

比如要求只能是昆虫,删除millipede,millbug,多余的蚂蚁

image

删除2会给序列中间带来一个缺口,MySQL不会补充序列中的空洞,而删除7和8会删除序列顶端的值,这样的影响取决于所用的存储引擎:

a,对于BDB表,从当前表的最大值+1开始,例如你删除7和8后,下一次将入的行将被分配序列值7

b,对于MyISAM或者InnoDB表,序列值不会被重用,即使在删除之后,插入的从9开始.

另更改存储引擎alter table tbl_name engine =MyISAM

3,查询序列值

在插入含有序列值的新航之后,想知道序列值是多少

last_insert_ID()获取auto_increment,有些max()函数查询,这种方法是不可靠的,因为没有考虑到myslq的多线程的特性,解决方法是将insert和select合并为一个事务,但是mysql提供了last_insert_ID()能够更简洁地获取正确的id值。塔返回本次链接服务器之后,最新创建的auto_increment,而不会受其他客户端操作的影响。

image

image

last_insert_id()只会返回基于服务器的每一个客户端连接,避免了不同用户之间的相互干扰。

使用python mysql api写的接口函数:

image

image

4,对一个已有的序列进行重新计数

当插入含有auto_increment列的行,并且不删除时会是连续的序列,但是如果删除其中的行时就会产生空洞

image

当你决定要进行再序列化,例如对insect表中的id列再序列化:

先删除:

image

再插入id项并配置相关的属性:

image

first关键字表示将该列设置为表中第一列,加入auto_increment,mysql会自动对所有行进行连续序列化。

image

再次序列化成功!!!

当你只是在序列顶部数值删除了一些行时,不需要完全序列化,(BDB是自动处理的)对于MyISAM和InnoDB只需要

image

使用auto_increment=n,能够指定序列起始值。

这使得MySQL把序列计算器重置为能够利用的最小值。

5,序列化一个未序列的表

例如有表:

image

添加一个序列id:

alter table tadd id int not null auto_increment,add primary key (id)
Nach dem Login kopieren

即可将未序列的表序列化。

6,使用auto_increment 栏创建多重序列

把auto_increment列和其他列链接起来,使它们都是同一索引的一部分。

可以使用primary key设置多重主键:例如你需要确认一个快递,而邮件快递可能包含类型(如顺丰、韵达)、邮件发送的人,虽然可能邮件的类型相同,发送的人也可能相同,但是但考虑两者的时候,这个时候就需要创建多栏序列。以下是书中例子:

image

image image

7,使用auto_increment值将表进行关联

你把一张表里的序列值当作另外一张表的键值,这样你就可以把两张表中的行关联起来/

假设有一张invoice表记录了客户订单的货物清单,和一张inv_item表记录了每一个客户订单的包括的每一种货物。

image

典型的使用方法是首先在主表中插入一行,然后使用last_insert_id()获取主表的ID

image

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wann könnte ein vollständiger Tabellen -Scan schneller sein als einen Index in MySQL? Wann könnte ein vollständiger Tabellen -Scan schneller sein als einen Index in MySQL? Apr 09, 2025 am 12:05 AM

Die volle Tabellenscannung kann in MySQL schneller sein als die Verwendung von Indizes. Zu den spezifischen Fällen gehören: 1) das Datenvolumen ist gering; 2) Wenn die Abfrage eine große Datenmenge zurückgibt; 3) wenn die Indexspalte nicht sehr selektiv ist; 4) Wenn die komplexe Abfrage. Durch Analyse von Abfrageplänen, Optimierung von Indizes, Vermeidung von Überindex und regelmäßiger Wartung von Tabellen können Sie in praktischen Anwendungen die besten Auswahlmöglichkeiten treffen.

Erläutern Sie InnoDB Volltext-Suchfunktionen. Erläutern Sie InnoDB Volltext-Suchfunktionen. Apr 02, 2025 pm 06:09 PM

Die Volltext-Suchfunktionen von InnoDB sind sehr leistungsfähig, was die Effizienz der Datenbankabfrage und die Fähigkeit, große Mengen von Textdaten zu verarbeiten, erheblich verbessern kann. 1) InnoDB implementiert die Volltext-Suche durch invertierte Indexierung und unterstützt grundlegende und erweiterte Suchabfragen. 2) Verwenden Sie die Übereinstimmung und gegen Schlüsselwörter, um den Booleschen Modus und die Phrasesuche zu unterstützen. 3) Die Optimierungsmethoden umfassen die Verwendung der Word -Segmentierungstechnologie, die regelmäßige Wiederaufbauung von Indizes und die Anpassung der Cache -Größe, um die Leistung und Genauigkeit zu verbessern.

Kann ich MySQL unter Windows 7 installieren? Kann ich MySQL unter Windows 7 installieren? Apr 08, 2025 pm 03:21 PM

Ja, MySQL kann unter Windows 7 installiert werden, und obwohl Microsoft Windows 7 nicht mehr unterstützt hat, ist MySQL dennoch kompatibel damit. Während des Installationsprozesses sollten jedoch folgende Punkte festgestellt werden: Laden Sie das MySQL -Installationsprogramm für Windows herunter. Wählen Sie die entsprechende Version von MySQL (Community oder Enterprise) aus. Wählen Sie während des Installationsprozesses das entsprechende Installationsverzeichnis und das Zeichen fest. Stellen Sie das Stammbenutzerkennwort ein und behalten Sie es ordnungsgemäß. Stellen Sie zum Testen eine Verbindung zur Datenbank her. Beachten Sie die Kompatibilitäts- und Sicherheitsprobleme unter Windows 7, und es wird empfohlen, auf ein unterstütztes Betriebssystem zu aktualisieren.

Differenz zwischen Clustered Index und nicht klusterer Index (Sekundärindex) in InnoDB. Differenz zwischen Clustered Index und nicht klusterer Index (Sekundärindex) in InnoDB. Apr 02, 2025 pm 06:25 PM

Der Unterschied zwischen Clustered Index und nicht klusterer Index ist: 1. Clustered Index speichert Datenzeilen in der Indexstruktur, die für die Abfrage nach Primärschlüssel und Reichweite geeignet ist. 2. Der nicht klusterierte Index speichert Indexschlüsselwerte und -zeiger auf Datenzeilen und ist für nicht-primäre Schlüsselspaltenabfragen geeignet.

Was sind einige beliebte MySQL -GUI -Tools (z. B. MySQL Workbench, PhpMyAdmin)? Was sind einige beliebte MySQL -GUI -Tools (z. B. MySQL Workbench, PhpMyAdmin)? Mar 21, 2025 pm 06:28 PM

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]

Wie behandeln Sie große Datensätze in MySQL? Wie behandeln Sie große Datensätze in MySQL? Mar 21, 2025 pm 12:15 PM

In Artikel werden Strategien zum Umgang mit großen Datensätzen in MySQL erörtert, einschließlich Partitionierung, Sharding, Indexierung und Abfrageoptimierung.

MySQL: Einfache Konzepte für einfaches Lernen MySQL: Einfache Konzepte für einfaches Lernen Apr 10, 2025 am 09:29 AM

MySQL ist ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.

Die Beziehung zwischen MySQL -Benutzer und Datenbank Die Beziehung zwischen MySQL -Benutzer und Datenbank Apr 08, 2025 pm 07:15 PM

In der MySQL -Datenbank wird die Beziehung zwischen dem Benutzer und der Datenbank durch Berechtigungen und Tabellen definiert. Der Benutzer verfügt über einen Benutzernamen und ein Passwort, um auf die Datenbank zuzugreifen. Die Berechtigungen werden über den Zuschussbefehl erteilt, während die Tabelle durch den Befehl create table erstellt wird. Um eine Beziehung zwischen einem Benutzer und einer Datenbank herzustellen, müssen Sie eine Datenbank erstellen, einen Benutzer erstellen und dann Berechtigungen erfüllen.

See all articles