MySQL必知必会之5-9_MySQL

Jun 01, 2016 pm 01:18 PM

bitsCN.com

5.排序检索数据

5.1排序数据

ORDER BY

SELECT prod_name FROM products ORDER BYprod_name; //排序检索

SELECT prod_id,prod_price,prod_name

FROM products ORDER BYprod_price,prod_name;//按多个列排序

5.2指定排序方向

DESC降序排序

SELECT prod_id,prod_price,prod_name FROMproducts ORDER BY prod_price DESC;//降序排序

SELECT prod_id,prod_price,prod_name FROMproducts ORDER BY prod_price DESC,prod_name;//多个列只有指定的列为降序

5.3ORDER BY与LIMIT的组合能找出最高或最低值

SELECT prod_price FROM products ORDER BYprod_price DESC LIMIT 1;//获取最昂贵的价格

6.过滤数据

6.1使用WHERE子句

SELECT prod_name FROM products WHEREprod_price = 2.5;//只返回prod_price值为2.5的行

WHERE子句的位置:应该在ORDER BY之前

6.2WHERE子句操作符:

=,(不等于),!=(不等于), , >=, BETWEEN(在指定的两个值之间)

SELECT prod_name,prod_price FROM productsWHERE prod_price BETWEEN 3 AND 10;

6.3空值检查

在创建表时,表设计人员可以指定其中的列是否可以不包含值。在一个列不包含值时,称其为包含空值NULL。IS NULL子句来检查具有NULL值的列

输入SELECT prod_name FROM products WHERE prod_price IS NULL;

输出Empty set (0.00 sec) //说明价格必须非空

输入mysql> SELECT cust_id FROM customers WHERE cust_email IS NULL;

输出: +---------------+

| cust_id |

+---------------+

| 10002 |

| 10005 |

+---------------+

2 rows in set (0.01 sec)

说明cust_email列有空值的行,这些行对应的cust_id为10002和10005。

7.数据过滤

7.1组合WHERE子句

MySQL允许给出多个WHERE子句,这些子句以两种方式组合:AND和OR

7.1.1 AND操作符

SELECT prod_id,prod_price,prod_name FROM products

WHERE vend_id=1003 AND prod_price

7.1.2 OR操作符

SELECT prod_id,prod_price,prod_name FROM products

WHERE vend_id=1003 OR vend_id = 1002;//两个条件满足一个就可以

7.1.3计算次序

SELECT prod_id,prod_price,prod_name FROM products

WHERE vend_id=1003 OR vend_id = 1002 AND prod_price>=10;//AND操作符优先级高于OR

所以上面理解为:由供应商1003制造的任何价格为10美元以上的产品,或者由供应商1002制造的任何产品,而不管价格如何

SELECT prod_id,prod_price,prod_name FROM products

WHERE (vend_id=1003 OR vend_id = 1002) AND prod_price>=10;//()优先级最高

上面语句理解为:价格在10美元以上且有由1002或1002制造的所有产品

7.2 IN操作符

IN操作符用来指定条件范围,其作用于OR操作符相当,但更清楚直观,而且可以包含其他SELECT语句,是的能够更动态的建立where子句。

SELECT prod_price,prod_name FROM products

WHERE vend_id IN(1001,1002,1003) ORDER BY prod_name;

7.3 NOT操作符

NOT操作符:否定它之后所跟的任何条件。

SELECT prod_price,prod_name FROM products

WHERE vend_id NOT IN(1002,1003,1001) ORDER BY prod_name;

8.通用配符进行过滤

8.1 LIKE操作符

通配符(wildcard):用来匹配值的一部分的特殊字符

搜索模式(searchpattern):由字面值、通配符或两者组合构成的搜索条件

LIKE只是MySQL,后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较

8.1.1 百分号(%)通配符

%表示任何字符出现任意次数,但不能匹配NULL

SELECT prod_price,prod_name FROM products WHERE prod_name LIKE'JET%';

SELECT prod_price,prod_name FROM products WHERE prod_name LIKE'%ANVIL%';
8.1.2下划线(_)通配符

下划线匹配单个字符

8.2通配符技巧

1)不要过度使用通配符

2)把通配符放在开始处,搜索速度最慢

9.用正则表达式进行搜索

正则表达式是用来匹配文本的特护的串(字符集和)。

9.1使用mysql正则表达式

9.1.1基本字符匹配

SELECT prod_name FROM products WHERE prod_name REGEXP '.000' ORDERBY prod_name;

+--------------+

| prod_name |

+--------------+

| JetPack 1000 |

| JetPack 2000 |

+--------------+

上面语句使用了泽正表达式.000。.是正则表达式语言中一个特殊的字符。他表示匹配任意一个字符,因此,1000和2000都匹配且返回。

正则表达式匹配不区分大小写,要区分大小写可以在REGEXP后面使用BINARY关键字。

9.1.2进行or匹配

SELECT prod_name FROM products WHERE prod_name REGEXP '1000 | 2000';

这里的|是正则表达式的OR操作符

9.1.3匹配几个字符之一

SELECT prod_name FROM products

WHERE prod_name REGEXP '[123] Ton' ORDER BY prod_name;

这里的[123]表示匹配1或2或3。

9.2.4匹配范围

SELECT prod_name FROM products WHERE prod_name REGEXP '[1-5] Ton';

这里[1-5]定义了一个范围

9.2.5匹配特殊字符

SELECT vend_name FROM vendors WHERE vend_name REGEXP '//.' ORDER BYvend_name;

为了匹配特殊字符,必须用//为前导。

//-表示-

//.表示.

///表示/

//f表示换页

//n表示换行

//r表示回车

//t表示制表

//v表示纵向制表

9.2.6匹配字符类

[:alnum:] 任意字母和数字(同[a-zA-Z0-9])

[:alpha:] 任意字符(同[a-zA-Z])

[:blank:] 空格和制表符(同[//t])

[:cntrl:] ASCII控制字符(ACII 0到31和127)

[:digit:] 任意数字(同[0-9])

[:graph:] 与[:print:]相同,但不包括空格

[:lower:] 任意小写字母

[:print:] 任意可打印字符

[:punct:] 既不在[:alnum:]又不在[:cntrl:]中的任意字符

[:space:] 包括空格在内的任意空白字符(同[//f//n//r//t//v])

[:upper:] 任意大写字母(同[A-Z])

[:xdigit:] 任意十六进制数字(同[a-fA-F0-9])

9.2.6匹配多个实例

SELECT prod_name FROM products

WHERE prod_name REGEXP '//([0-9] sticks?//)' ORDER BY prod_name;//结果如下

+----------------+

| prod_name |

+----------------+

| TNT (1 stick) |

| TNT (5 sticks) |

+----------------+

正则表达式//([0-9]sticks?//)需要说明一下。//(匹配(,[0-9]匹配任意数字(这个例子中为1和5),sticks?匹配stick和sticks(s后的?使s可选,因为?匹配它掐年的任何字符的0次或1次出现),//)匹配)。

SELECT prod_name FROM products

WHERE prod_name REGEXP '[[:digit:]]{4}' ORDER BY prod_name;

+--------------+

| prod_name |

+--------------+

| JetPack 1000 |

| JetPack 2000 |

+--------------+

2 rows in set (0.00 sec)

[[:digit:]]{4}中{4}要求它前面的字符(任意数字)出现四次,所以[[:digit:]]{4}表示连在一起的任意4位数

9.2.8定位符

^ 文本的开始

$ 文本的结尾

[[:<:>

[[:>:]] 词的结尾

SELECT prod_name FROM products

WHERE prod_name REGEXP '^[0-9//.]' ORDER BY prod_name;

^[0-9//.]表示只在.或任意数字为串中第一个字符时才匹配它们。

bitsCN.com

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の 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:05 AM

完全なテーブルスキャンは、MySQLでインデックスを使用するよりも速い場合があります。特定のケースには以下が含まれます。1)データボリュームは小さい。 2)クエリが大量のデータを返すとき。 3)インデックス列が高度に選択的でない場合。 4)複雑なクエリの場合。クエリプランを分析し、インデックスを最適化し、オーバーインデックスを回避し、テーブルを定期的にメンテナンスすることにより、実際のアプリケーションで最良の選択をすることができます。

Windows 7にMySQLをインストールできますか? Windows 7にMySQLをインストールできますか? Apr 08, 2025 pm 03:21 PM

はい、MySQLはWindows 7にインストールできます。MicrosoftはWindows 7のサポートを停止しましたが、MySQLは引き続き互換性があります。ただし、インストールプロセス中に次のポイントに注意する必要があります。WindowsのMySQLインストーラーをダウンロードしてください。 MySQL(コミュニティまたはエンタープライズ)の適切なバージョンを選択します。インストールプロセス中に適切なインストールディレクトリと文字セットを選択します。ルートユーザーパスワードを設定し、適切に保ちます。テストのためにデータベースに接続します。 Windows 7の互換性とセキュリティの問題に注意してください。サポートされているオペレーティングシステムにアップグレードすることをお勧めします。

INNODBフルテキスト検索機能を説明します。 INNODBフルテキスト検索機能を説明します。 Apr 02, 2025 pm 06:09 PM

INNODBのフルテキスト検索機能は非常に強力であり、データベースクエリの効率と大量のテキストデータを処理する能力を大幅に改善できます。 1)INNODBは、倒立インデックスを介してフルテキスト検索を実装し、基本的および高度な検索クエリをサポートします。 2)一致を使用してキーワードを使用して、ブールモードとフレーズ検索を検索、サポートします。 3)最適化方法には、単語セグメンテーションテクノロジーの使用、インデックスの定期的な再構築、およびパフォーマンスと精度を改善するためのキャッシュサイズの調整が含まれます。

INNODBのクラスターインデックスと非クラスターインデックス(セカンダリインデックス)の違い。 INNODBのクラスターインデックスと非クラスターインデックス(セカンダリインデックス)の違い。 Apr 02, 2025 pm 06:25 PM

クラスター化されたインデックスと非クラスター化されたインデックスの違いは次のとおりです。1。クラスター化されたインデックスは、インデックス構造にデータを保存します。これは、プライマリキーと範囲でクエリするのに適しています。 2.非クラスター化されたインデックスストアは、インデックスキー値とデータの行へのポインターであり、非プリマリーキー列クエリに適しています。

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

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

MySQLユーザーとデータベースの関係 MySQLユーザーとデータベースの関係 Apr 08, 2025 pm 07:15 PM

MySQLデータベースでは、ユーザーとデータベースの関係は、アクセス許可と表によって定義されます。ユーザーには、データベースにアクセスするためのユーザー名とパスワードがあります。許可は助成金コマンドを通じて付与され、テーブルはCreate Tableコマンドによって作成されます。ユーザーとデータベースの関係を確立するには、データベースを作成し、ユーザーを作成してから許可を付与する必要があります。

さまざまなタイプのMySQLインデックス(Bツリー、ハッシュ、フルテキスト、空間)を説明します。 さまざまなタイプのMySQLインデックス(Bツリー、ハッシュ、フルテキスト、空間)を説明します。 Apr 02, 2025 pm 07:05 PM

MySQLは、Bツリー、ハッシュ、フルテキスト、および空間の4つのインデックスタイプをサポートしています。 1.B-Treeインデックスは、等しい値検索、範囲クエリ、ソートに適しています。 2。ハッシュインデックスは、等しい値検索に適していますが、範囲のクエリとソートをサポートしていません。 3.フルテキストインデックスは、フルテキスト検索に使用され、大量のテキストデータの処理に適しています。 4.空間インデックスは、地理空間データクエリに使用され、GISアプリケーションに適しています。

mysqlとmariadbは共存できますか mysqlとmariadbは共存できますか Apr 08, 2025 pm 02:27 PM

MySQLとMariaDBは共存できますが、注意して構成する必要があります。重要なのは、さまざまなポート番号とデータディレクトリを各データベースに割り当て、メモリ割り当てやキャッシュサイズなどのパラメーターを調整することです。接続プーリング、アプリケーションの構成、およびバージョンの違いも考慮する必要があり、落とし穴を避けるために慎重にテストして計画する必要があります。 2つのデータベースを同時に実行すると、リソースが制限されている状況でパフォーマンスの問題を引き起こす可能性があります。

See all articles