ホームページ データベース mysql チュートリアル 跟我一起学习MySQL技术内幕(第五版):(第三章学习日记3)

跟我一起学习MySQL技术内幕(第五版):(第三章学习日记3)

Jun 07, 2016 pm 02:50 PM
mysql 勉強 テクノロジー ジャーナル 第三章

3.2MySQL数据类型 3.2.1数据类型概述 3.2.2表定义里的特殊列类型 3.2.3指定列的默认值 ——————————————————————————————— 3.2.1数据类型概述 MySQL数字类型包括整数,定点数,浮点数和位值。除bit外其他的数据类型可以带有正

3.2MySQL数据类型
3.2.1数据类型概述
3.2.2表定义里的特殊列类型
3.2.3指定列的默认值
———————————————————————————————
3.2.1数据类型概述

MySQL数字类型包括整数,定点数,浮点数和位值。除bit外其他的数据类型可以带有正负号,也可以不带正负号。

<code>类型名称               含义
tinyint               非常小的整数
smallint              小整数
mediumint             中等大小的整数
int                   标准的整数
bigint                大整数
decimal               定点数
float                 单精度浮点数
double                双精度浮点数
bit                   位域
</code>
ログイン後にコピー

字符串可以容纳任何内容,可以容纳表示图像和声音的二进制数据,可以按照大写进行比较,也可以进行模式匹配。

<code>类型名称               含义
char                  固定长度的非二进制字符串
varchar               可变长度的非二进制串
binary                固定长度的二进制串
varbinary             可变长度的二进制串
tinyblob              非常小型的blob(二进制大对象)
blob                  小型blob
mediumblob            中型blob
longblob              大型blob
tinytext              非常小型的非二进制串
text                  小型非二进制串
mediutext             中等大小的非二进制串
longtext              大型非二进制串
enum                  枚举集合
set                   集合(每个列取值可以为若干个集合元素)
</code>
ログイン後にコピー

时态类型:
MySQL提供的类型有:
日期与时间(合并或者分开表示)
时间戳(专门记载某个行最近一次修改时间的类型)

<code>类型名称              含义
date                 日期值,格式为‘ccyy-mm-dd’
time                 时间值,格式为‘hh:mm:ss’
datetime             日期加时间值,格式为‘ccyy-mm-dd hh:mm:ss’
timestamp            时间戳值,格式为‘ccyy-mm-dd hh:mm:ss’
year                 年份值,格式为ccyy或yy 
</code>
ログイン後にコピー

分别表示:

<code>        cc      yy       mm     dd      hh      mm      ss      
        世纪、   年、      月 、   日   、 小时  、 分钟   、秒
</code>
ログイン後にコピー

3.2.2表定义里的特殊 列 类型

<code class=" hljs sql"><span class="hljs-operator"><span class="hljs-keyword">create</span> <span class="hljs-keyword">table</span> mytabl1
(
   f <span class="hljs-keyword">float</span>(<span class="hljs-number">10</span>,<span class="hljs-number">4</span>),
   c <span class="hljs-keyword">char</span> (<span class="hljs-number">15</span>)  <span class="hljs-keyword">not</span> <span class="hljs-keyword">null</span> <span class="hljs-keyword">default</span> <span class="hljs-string">'none'</span>
   i tinyint unsigned <span class="hljs-keyword">null</span>
);</span></code>
ログイン後にコピー

列定义的语法如下:

<code class=" hljs bash">col_name col_<span class="hljs-built_in">type</span> [<span class="hljs-built_in">type</span>_attrs] [general_attrs]</code>
ログイン後にコピー

col_type表示列类型,即表明这一列可以用来容纳何种类型的值。
1.有些类型说明符会表明存储在列里的值所允许的最大长度(char(10))
2.有些类型说明符允许长度隐含在名称里(tinytext)
3.有些类型说明符允许你指定一个最大显示宽度
4.对于定点类型和浮点类型,还可以指定有效位和小数位

在列的数据类型后面,除了指定多个通用属性外,还可以指定一些类型特有的可选属性。这些属性的作用是对该类型做进一步的修饰和限定

<code>1.所允许的特有类型取决于具体的数据类型   
2.通用属性可用于任何一种数据类型
3.如果存在多个属性,通常将数据类型特有的属性放在通用属性的前面
</code>
ログイン後にコピー

3.2.3指定列的默认值

除了blob与text类型、空间类型或者具有auto_increment属性的列以外,

还可以指定default def_value 子句.用以表明创建新的行时,如果没有显示地指定某个值,该列将会被默认值 def_value

除了timestamp列和datetime列有限制以外,这里的默认值def_value必须是一个常量。他不能为表达式,也不能引用其他列

如果没有显式包含default子句,且该列允许为null值,那么其默认值为NULL

如果该列不允许为NULL值,也没有default子句,这就会影响MySQL对列的处理:

<code>1.如果没有启用SQL的严格模式,这列将会被设置成其数据类型的隐含默认值。
2.启用SQL严格模式之后,如果表是事务性的,就会出现错误。这条语句会中止执行,然后回滚。对于非事务性的表,
如果这行是该语句插入的第一个行,那么会出现一个错误,该语句中止执行,
如果不是第一行,那么可以选择中止执行,或选择把这列设置为它的隐含默认值,同时发出一条警告信息
</code>
ログイン後にコピー

列的隐含默认值取决于它的数据类型。

<code>1.对于数字列(不包含那些具有auto_increment属性的列),其默认值为0.
  对于auto_increment列,默认值是下一个列的列序号。
2.对于大多数时态类型列,其默认值为该类型的“零”值
  对于enum列,默认值为枚举集里的第一个元素,
  对于set列,如果不允许NULL值,默认值将是一个空集不过它等价于空串。              
</code>
ログイン後にコピー
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

MySQL:初心者向けのデータ管理の容易さ MySQL:初心者向けのデータ管理の容易さ Apr 09, 2025 am 12:07 AM

MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

MySQL:簡単な学習のためのシンプルな概念 MySQL:簡単な学習のためのシンプルな概念 Apr 10, 2025 am 09:29 AM

MySQLは、オープンソースのリレーショナルデータベース管理システムです。 1)データベースとテーブルの作成:createdatabaseおよびcreateTableコマンドを使用します。 2)基本操作:挿入、更新、削除、選択。 3)高度な操作:参加、サブクエリ、トランザクション処理。 4)デバッグスキル:構文、データ型、およびアクセス許可を確認します。 5)最適化の提案:インデックスを使用し、選択*を避け、トランザクションを使用します。

phpmyadminを開く方法 phpmyadminを開く方法 Apr 10, 2025 pm 10:51 PM

次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。

Navicatプレミアムの作成方法 Navicatプレミアムの作成方法 Apr 09, 2025 am 07:09 AM

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

MySQLおよびSQL:開発者にとって不可欠なスキル MySQLおよびSQL:開発者にとって不可欠なスキル Apr 10, 2025 am 09:30 AM

MySQLとSQLは、開発者にとって不可欠なスキルです。 1.MYSQLはオープンソースのリレーショナルデータベース管理システムであり、SQLはデータベースの管理と操作に使用される標準言語です。 2.MYSQLは、効率的なデータストレージと検索機能を介して複数のストレージエンジンをサポートし、SQLは簡単なステートメントを通じて複雑なデータ操作を完了します。 3.使用の例には、条件によるフィルタリングやソートなどの基本的なクエリと高度なクエリが含まれます。 4.一般的なエラーには、SQLステートメントをチェックして説明コマンドを使用することで最適化できる構文エラーとパフォーマンスの問題が含まれます。 5.パフォーマンス最適化手法には、インデックスの使用、フルテーブルスキャンの回避、参加操作の最適化、コードの読み取り可能性の向上が含まれます。

NavicatでMySQLへの新しい接続を作成する方法 NavicatでMySQLへの新しい接続を作成する方法 Apr 09, 2025 am 07:21 AM

手順に従って、NAVICATで新しいMySQL接続を作成できます。アプリケーションを開き、新しい接続(CTRL N)を選択します。接続タイプとして「mysql」を選択します。ホスト名/IPアドレス、ポート、ユーザー名、およびパスワードを入力します。 (オプション)Advanced Optionsを構成します。接続を保存して、接続名を入力します。

SQLが行を削除した後にデータを回復する方法 SQLが行を削除した後にデータを回復する方法 Apr 09, 2025 pm 12:21 PM

データベースから直接削除された行を直接回復することは、バックアップまたはトランザクションロールバックメカニズムがない限り、通常不可能です。キーポイント:トランザクションロールバック:トランザクションがデータの回復にコミットする前にロールバックを実行します。バックアップ:データベースの定期的なバックアップを使用して、データをすばやく復元できます。データベーススナップショット:データベースの読み取り専用コピーを作成し、データが誤って削除された後にデータを復元できます。削除ステートメントを使用して注意してください:誤って削除されないように条件を慎重に確認してください。 WHERE句を使用します:削除するデータを明示的に指定します。テスト環境を使用:削除操作を実行する前にテストします。

単一のスレッドレディスの使用方法 単一のスレッドレディスの使用方法 Apr 10, 2025 pm 07:12 PM

Redisは、単一のスレッドアーキテクチャを使用して、高性能、シンプルさ、一貫性を提供します。 I/Oマルチプレックス、イベントループ、ノンブロッキングI/O、共有メモリを使用して同時性を向上させますが、並行性の制限、単一の障害、および書き込み集約型のワークロードには適していません。

See all articles