MySQLの実践機能まとめ
mysql ビデオチュートリアル コラムでは実践的な機能を紹介します。
関連する無料学習の推奨事項: mysql ビデオ チュートリアル
MySQL 関数事典と関数の解説。MYSQL データの管理に必ず使用します。
注: mysqlの添え字は1から始まります
-
ASCII(str)
文字列を返します。ASCII
str の左端の文字のコード値。 str が空の文字列の場合、0 が返されます。 str がNULL
の場合、NULL
を返します。
mysql> select ASCII('2'); -> 50 mysql> select ASCII(2); -> 50 mysql> select ASCII('dx'); -> 100
-
ORD(str)
文字列 str の左端の文字がマルチバイト文字の場合は、((最初のバイト) の形式で渡します。 ASCII コード) 256 (2 バイト目の ASCII コード))[256 3 バイト目の ASCII コード...] は、マルチバイト文字コードを返す文字のASCII
コード値を返します。左端の文字がマルチバイト文字ではない場合。ASCII()
関数によって返されるのと同じ値を返します。
mysql> select ORD('2'); -> 50
-
CONV(N,from_base,to_base)
異なる基本システム間で数値を変換します。 from_base ベースから to_base ベースに変換された数値N
の文字列番号を返します。パラメータがNULL
の場合は、NULL
を返します。パラメータN
は整数として解釈されますが、整数または文字列として指定することもできます。最小の底は 2、最大の底は 36 です。 to_base が負の数値の場合、N
は符号付き数値とみなされ、それ以外の場合、N
は符号なし数値とみなされます。CONV
64 ビット精度で動作します。
つまり:N
は変換されるデータ、from_base
は元のベース、to_base
はターゲット ベースです。
mysql> select CONV("a",16,2); -> '1010' mysql> select CONV("6E",18,8); -> '172' mysql> select CONV(-17,10,-18); -> '-H' mysql> select CONV(10+"10"+'10'+0xa,10,10); -> '40'
-
BIN(N)
バイナリ値 N の文字列表現を返します。N
は長整数 (BIGINT
) 数値。これはCONV(N,10,2)
に相当します。N
がNULL
の場合は、NULL
を返します。
mysql> select BIN(12); -> '1100'
-
OCT(N)
8 進数値 N の文字列表現を返します (N は長整数)。これは At ## と同等です。 #CONV(N,10,8)。
Nが
NULLの場合、「」を返します。
mysql> select OCT(12); -> '14'
- HEX(N)
16 進値
N文字列表現を返します。N は長整数 (#) ##BIGINT
) 数値。これはCONV(N,10,16)
に相当します。N
がNULL
の場合は、NULL
を返します。mysql> select HEX(255); -> 'FF'
ログイン後にコピー
- CHAR(N,...)
-
パラメータを整数として解釈し、値を返します。これらの整数のASCII
コード文字で構成される文字列。NULL
値はスキップされます。mysql> select CHAR(77,121,83,81,'76'); -> 'MySQL' mysql> select CHAR(77,77.3,'77.3'); -> 'MMM'
ログイン後にコピー
- CONCAT(str1,str2,...)
-
パラメータ接続から文字列を返します。いずれかの引数が
NULL
の場合は、NULL
を返します。 2 つ以上のパラメータを指定できます。数値引数は、同等の文字列形式に変換されます。mysql> select CONCAT('My', 'S', 'QL'); -> 'MySQL' mysql> select CONCAT('My', NULL, 'QL'); -> NULL mysql> select CONCAT(14.3); -> '14.3'
ログイン後にコピー9.
、OCTET_LENGTH(str)
、CHAR_LENGTH(str)
、CHARACTER_LENGTH( str)
文字列 str の長さを返します。
注意
マルチバイト文字の場合、CHAR_LENGTH() は 1 回だけ計算されることに注意してください。 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">mysql> select LENGTH('text');
-> 4
mysql> select LENGTH('简书');
-> 6
mysql> select OCTET_LENGTH('text');
-> 4
mysql> select OCTET_LENGTH('简书');
-> 6
mysql> select CHAR_LENGTH('text');
-> 4
mysql> select CHAR_LENGTH('简书');
-> 2
mysql> select CHARACTER_LENGTH('text');
-> 4
mysql> select CHARACTER_LENGTH('简书');
-> 2</pre><div class="contentsignin">ログイン後にコピー</div></div>
- LOCATE(substr,str)
- 、
POSITION(substr IN str)
文字列 str の位置で最初に出現した部分文字列 substr を返します。 substr が str にない場合は、0 を返します。
mysql> select LOCATE('bar', 'foobarbar'); -> 4 mysql> select LOCATE('xbar', 'foobar'); -> 0
ログイン後にコピーこの関数はマルチバイトの信頼性があります。
- LOCATE(substr,str,pos)
-
部分文字列 substr が文字列 str 内で最初に出現する位置を pos の位置から返します。 substr が str 内にない場合は、0 を返します。
mysql> select LOCATE('bar', 'foobarbar',5); -> 7
ログイン後にコピーこの関数はマルチバイトの信頼性があります。
-
INSTR(str,substr)
返回子串substr在字符串str中的第一个出现的位置。这与有2个参数形式的LOCATE()相同,除了参数被颠倒。
mysql> select INSTR('foobarbar', 'bar'); -> 4 mysql> select INSTR('xbar', 'foobar'); -> 0
-
LPAD(str,len,padstr)
返回字符串str,左面用字符串padstr填补直到str是len个字符长。
mysql> select LPAD('hi',7,'abc'); -> 'abcabhi'
-
RPAD(str,len,padstr)
返回字符串str,右面用字符串padstr填补直到str是len个字符长。
mysql> select RPAD('hi',7,'abc'); -> 'hiabcab'
-
LEFT(str,len)
返回字符串str的最左面len个字符。
mysql> select LEFT('foobarbar', 5); -> 'fooba'
-
RIGHT(str,len)
返回字符串str的最右面len个字符。
mysql> select RIGHT('foobarbar', 4); -> 'rbar'
-
SUBSTRING(str,pos,len)
、SUBSTRING(str FROM pos FOR len)
、MID(str,pos,len)
从字符串str返回一个len个字符的子串,从位置pos开始。使用FROM的变种形式是ANSI SQL92语法。
mysql> select SUBSTRING('Quadratically',5,6); -> 'ratica' mysql> select SUBSTRING('helloworld' FROM 2 FOR 5); -> 'ellow' mysql> select MID('helloworld' FROM 2 FOR 5); -> 'ellow'
注: SUBSTR
用法同SUBSTRING
-
SUBSTRING_INDEX(str,delim,count)
返回从字符串str的第count个出现的分隔符delim之后的子串。如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符。如果count是负数,返回最后的分隔符到右边的所有字符(从右边数)。
mysql> select SUBSTRING_INDEX('www.mysql.com', '.', 2); -> 'www.mysql' mysql> select SUBSTRING_INDEX('www.mysql.com', '.', -2); -> 'mysql.com'
-
LTRIM(str)
返回删除了其前置空格字符的字符串str。
mysql> select LTRIM(' barbar'); -> 'barbar'
-
RTRIM(str)
返回删除了其拖后空格字符的字符串str。
mysql> select RTRIM('barbar '); -> 'barbar'
-
TRIM([remstr FROM] str)
、TRIM([[BOTH | LEADING | TRAILING] [remstr] FROM] str)
返回字符串str,其所有remstr前缀或后缀被删除了。如果没有修饰符BOTH、LEADING或TRAILING给出,BOTH被假定。如果remstr没被指定,空格被删除(中间空格不删除)。
mysql> SELECT TRIM(' bar bar '); -> 'bar bar' mysql> SELECT TRIM(LEADING 'x' FROM 'xxxbarxxx'); --删除指定的首字符 x -> 'barxxx' mysql> SELECT TRIM(BOTH 'x' FROM 'xxxbarxxx'); --删除指定的首尾字符 x -> 'bar' mysql> SELECT TRIM(TRAILING 'xyz' FROM 'barxxyz'); --删除指定的尾字符 x -> 'barx'
-
SOUNDEX(str)
返回str的一个同音字符串。听起来“大致相同”的2个字符串应该有相同的同音字符串。一个“标准”的同音字符串长是4个字符,但是SOUNDEX()
函数返回一个任意长的字符串。你可以在结果上使用SUBSTRING()
得到一个“标准”的 同音串。所有非数字字母字符在给定的字符串中被忽略。所有在A-Z之外的字符国际字母被当作元音。
mysql> select SOUNDEX('Hello'); -> 'H400' mysql> select SOUNDEX('Quadratically'); -> 'Q36324'
-
SPACE(N)
返回由N
个空格字符组成的一个字符串。
mysql> select SPACE(6); -> ' '
-
REPLACE(str,from_str,to_str)
返回字符串str,其字符串from_str的所有出现由字符串to_str代替。
mysql> select REPLACE('www.mysql.com', 'w', 'Ww'); -> 'WwWwWw.mysql.com'
-
REPEAT(str,count)
返回由重复countTimes次的字符串str组成的一个字符串。如果count <= 0,返回一个空字符串。如果str或count是NULL
,返回NULL
。
mysql> select REPEAT('MySQL', 3); -> 'MySQLMySQLMySQL'<ol start="26"><li> <code>REVERSE(str)</code><br> 返回颠倒字符顺序的字符串str。</li></ol> <pre class="brush:php;toolbar:false">mysql> select REVERSE('abc'); -> 'cba'
-
INSERT(str,pos,len,newstr)
返回字符串str,在位置pos起始的子串且len个字符长得子串由字符串newstr代替。
mysql> select INSERT('Quadratic', 3, 4, 'What'); -> 'QuWhattic'
-
ELT(N,str1,str2,str3,...)
如果N= 1
,返回str1,如果N= 2
,返回str2,等等。如果N
小于1或大于参数个数,返回NULL
。ELT()
是FIELD()
反运算。
mysql> select ELT(1, 'ej', 'Heja', 'hej', 'foo'); -> 'ej' mysql> select ELT(4, 'ej', 'Heja', 'hej', 'foo'); -> 'foo'
-
FIELD(str,str1,str2,str3,...)
返回str在str1, str2, str3, ...清单的索引。如果str没找到,返回0。FIELD()
是ELT()
反运算。
mysql> select FIELD('ej', 'Hej', 'ej', 'Heja', 'hej', 'foo'); -> 2 mysql> select FIELD('fo', 'Hej', 'ej', 'Heja', 'hej', 'foo'); -> 0
-
FIND_IN_SET(str,strlist)
如果字符串str在由N
子串组成的表strlist
之中,返回一个1到N的值。一个字符串表是被“,”分隔的子串组成的一个字符串。如果第一个参数是一个常数字符串并且第二个参数是一种类型为SET
的列,FIND_IN_SET()
函数被优化而使用位运算!如果str不是在strlist里面或如果strlist是空字符串,返回0。如果任何一个参数是NULL
,返回NULL
。如果第一个参数包含一个“,”,该函数将工作不正常。
mysql> SELECT FIND_IN_SET('b','a,b,c,d'); -> 2
-
MAKE_SET(bits,str1,str2,...)
返回一个集合 (包含由“,”字符分隔的子串组成的一个字符串),由相应的位在bits集合中的的字符串组成。str1对应于位0,str2对应位1,等等。在str1, str2, ...中的NULL
串不添加到结果中。
mysql> SELECT MAKE_SET(1,'a','b','c'); -> 'a' mysql> SELECT MAKE_SET(1 | 4,'hello','nice','world'); -> 'hello,world' mysql> SELECT MAKE_SET(1 | 4,'hello','nice',NULL,'world'); -> 'hello' mysql> SELECT MAKE_SET(0,'a','b','c'); -> ''
说明:
bits应将期转为二进制,如,1为,0001,倒过来排序,则为1000,将bits后面的字符串str1,str2等,放置在这个倒过来的二进制排序中,取出值为1对应的字符串,则得到hello.1|4表示进行或运算,为0001 | 0100,得0101,倒过来排序,为1010,则'hello','nice','world'得到的是hello word。'hello','nice',
NULL
,'world'得到的是hello。NULL
不取,只有1才取对应字符串.
-
EXPORT_SET(bits,on,off,[separator,[number_of_bits]])
返回一个字符串,在这里对于在“bits”中设定每一位,你得到一个“on”字符串,并且对于每个复位(reset)的位,你得到一个“off”字符串。每个字符串用“separator”分隔(缺省“,”),并且只有“bits”的“number_of_bits” (缺省64)位被使用。
mysql> select EXPORT_SET(5,'Y','N',',',4) -> Y,N,Y,N
-
LCASE(str)
、LOWER(str)
返回字符串str,根据当前字符集映射(缺省是ISO-8859-1 Latin1)把所有的字符改变成小写。该函数对多字节是可靠的。
mysql> select LCASE('QUADRATICALLY'); -> 'quadratically'
-
UCASE(str)
、UPPER(str)
返回字符串str,根据当前字符集映射(缺省是ISO-8859-1 Latin1)把所有的字符改变成大写。该函数对多字节是可靠的。
mysql> select UCASE('Hello'); -> 'HELLO'
-
LOAD_FILE(file_name)
读入文件并且作为一个字符串返回文件内容。文件必须在服务器上,你必须指定到文件的完整路径名,而且你必须有file权限。文件必须所有内容都是可读的并且小于max_allowed_packet。如果文件不存在或由于上面原因之一不能被读出,函数返回NULL
。
mysql> UPDATE table_name SET blob_column=LOAD_FILE("/tmp/picture") WHERE id=1;
-
CONCAT(str1,str2,...)
将多个字符串连接成一个字符串,返回结果为连接参数产生的字符串。如有任何一个参数为NULL
,则返回值为NULL
。或许有一个或多个参数。 如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型cast
, 例如:SELECT CONCAT(CAST(int_col AS CHAR), char_col)
mysql> SELECT CONCAT('My','S','ql'); -> ‘MySQL’ mysql> SELECT CONCAT('My', NULL, 'ql'); -> NULL mysql> SELECT CONCAT(14.3); -> '14.3'
MySQL必要时自动变换数字为字符串,并且反过来也如此:
mysql> SELECT 1+"1"; -> 2 mysql> SELECT CONCAT(2,' test'); -> '2 test'
-
CONCAT_WS(separator,str1,str2,…)
CONCAT_WS()
代表 CONCAT With Separator ,是CONCAT()
的特殊形式。 第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为NULL
,则结果为NULL
。函数会忽略任何分隔符参数后的NULL
值。
mysql>select CONCAT_WS(',','First name','Second name','Last Name'); -> 'First name,Second name,Last Name' mysql> select CONCAT_WS(',','First name',NULL,'Last Name'); -> 'First name,Last Name'
注 CONCAT_WS()
不会忽略任何空字符串。 (然而会忽略所有的 NULL
)。
以上がMySQLの実践機能まとめの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

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

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

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