目次
基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程),开题-mysql
ホームページ php教程 php手册 基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程),开题-mysql

基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程),开题-mysql

Jun 13, 2016 am 08:51 AM
mysql

基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程),开题-mysql

  hi

感觉论文开题基本确定了,凯森

1、MySQL

-----自定义函数-----

----基本

两个必要条件:参数和返回值(两者没有必然联系,参数不一定有,返回一定有)

函数体:合法的SQL语句;以及简单的SELECT或INSERT语句;如果为复合结构则使用BEGIN...END语句

----不带参数的自定义函数

把当前时刻转换为中文显示,效果如下

mysql> SET NAMES gbk;
Query OK, 0 rows affected (0.05 sec)

mysql> SELECT DATE_FORMAT(NOW(),'%Y年%m月%d日 %h点:%I分:%s秒');
+--------------------------------------------------+
| DATE_FORMAT(NOW(),'%Y年%m月%d日 %h点:%I分:%s秒') |
+--------------------------------------------------+
| 2015年11月11日 07点:07分:39秒 |
+--------------------------------------------------+
1 row in set (0.00 sec)

把这个功能写成函数f1()

mysql> CREATE FUNCTION f1() RETURNS VARCHAR(30)
-> RETURN DATE_FORMAT(NOW(),'%y年%m月%d日 %h点:%I分:%s秒');
Query OK, 0 rows affected (0.05 sec)

调用

mysql> SELECT f1();

----带有参数的函数

mysql> CREATE FUNCTION f2(num1 SMALLINT UNSIGNED,num2 SMALLINT UNSIGNED)
-> RETURNS FLOAT(10,2) UNSIGNED
-> RETURN (num1+num2);
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT f2(32,33);
+-----------+
| f2(32,33) |
+-----------+
| 65.00 |
+-----------+
1 row in set (0.03 sec)

我就不解释了,都看的懂

----具有复合结构体的函数

复合结构的函数往往意味着有多条语句要实现。比如往以下数据库中,创建函数实现插入参数作为新的username,返回最后插入字段的id

mysql> DESC test;
+----------+---------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+---------------------+------+-----+---------+----------------+
| id | tinyint(3) unsigned | NO | PRI | NULL | auto_increment |
| username | varchar(20) | YES | | NULL | |
+----------+---------------------+------+-----+---------+----------------+

mysql> SELECT * FROM test;
+----+----------+
| id | username |
+----+----------+
| 1 | 111 |
| 2 | JOHN |
+----+----------+

实现的时候会发现,如果直接写,会有两句话是要打分号的,不合适,改!

mysql> DELIMITER //

把结束符号改为//

实际函数就是

mysql> CREATE FUNCTION adduser(username VARCHAR(20))
-> RETURNS INT UNSIGNED
-> BEGIN
-> INSERT test(username) VALUES(username);
-> RETURN LAST_INSERT_ID();
-> END
-> //

调用检查

mysql> SELECT adduser('Rose')//
+-----------------+
| adduser('Rose') |
+-----------------+
| 3 |
+-----------------+

当然这时候可以改回来定界符

mysql> DELIMITER ;
mysql> SELECT adduser('Rose2');
+------------------+
| adduser('Rose2') |
+------------------+
| 4 |
+------------------+

----最后一点说明

一般不会用到自定义函数,很少用,用好自带函数就好

-----MySQL存储过程-----

 ----简介

一般的目的是提高MySQL的效率,去掉或者缩减其自身的存储过程

存储过程的定义是:它是SQL语句和控制语句的预编译集合,以一个名称存储并作为一个单元处理(实际理解就是说把一系列,当然也可以是某一个,操作合并/封装为一个操作;又由于这是在MySQL中的,数据库一般的操作成为存储,所以称为存储过程)

采用存储过程后,只有在第一次进行语法检查和编译,以后用户再调用就省去这两步,效率提高

---

优点:增强SQL语句的功能和灵活性;较快的执行速度(如上);减少网络流量(即缩减命令的长度);

----结构解析/创建

类似创建自定义函数,参数处不太一样

---参数

给参数可以赋值类型IN OUT INOUT

IN表示该参数的值必须在调用存储过程时指定,且不能返回

OUT表示~~~可以被存储过程改变,且可以返回

INOUT表示~~~在调用时指定,且可以被改变和返回

---结构体

类似函数体

可以是任意的SQL语句构成

复合结构也得用BEGIN...END

可以声明,循环等

----不带参数的存储过程

mysql> CREATE PROCEDURE sp1() SELECT VERSION();
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT sp1();
ERROR 1305 (42000): FUNCTION test.sp1 does not exist
mysql> CALL sp1();
+-----------+
| VERSION() |
+-----------+
| 5.6.17 |
+-----------+

存储过程的调用时CALL,且有两种调用方法-带或者不带括号

----带有IN类型参数的存储过程

删除记录的存储过程,通过id来删除

mysql> DELIMITER //
mysql> CREATE PROCEDURE removeUserById(IN id INT UNSIGNED)
-> BEGIN
-> DELETE FROM test WHERE id=id;
-> END
-> //
Query OK, 0 rows affected (0.04 sec)

mysql> DELIMITER ;

注意这里的id=id,前者是表中的id,后者是传递的参数,是可以这么写的(?)

还有要注意这里的习惯,DELIMITER开头结尾+BEGIN...END语句的写法

调用

mysql> CALL removeUserById(3);

Query OK, 4 rows affected (0.05 sec)

注意,有参数的过程,不能省略小括号

这里,数据中所有记录都被删除。所以一般过程的参数不要和数据表中字段名相同!

这里的修改只能是删除过程再重建个正确的。DROP PROCEDURE REMOVEUSERBYID;

----带有IN和OUT参数

过程定义为:删除某id的记录,返回剩余记录数量

和写正则表达式等的流程差不多,先考虑需求:两个操作,返回一个值,传递进一个值,所以两个参数,一个IN,一个OUT

mysql> DELIMITER //
mysql> CREATE PROCEDURE REMOVEIDRETURNLENGTH(IN p_id INT UNSIGNED,OUT usernums INT UNSIGNED)
-> BEGIN
-> DELETE FROM test WHERE id=p_id;
-> SELECT count(id) FROM test INTO usernums;
-> END
-> //
Query OK, 0 rows affected (0.02 sec)

mysql> DELIMITER ;

调用

mysql> CALL REMOVEIDRETURNLENGTH(3,@NUMS);
Query OK, 1 row affected (0.03 sec)

mysql> SELECT @NUMS;
+-------+
| @NUMS |
+-------+
| 4 |
+-------+
1 row in set (0.00 sec)

这里的@nums是变量

mysql> SET @QQ=2;
Query OK, 0 rows affected (0.00 sec)

这种变量称为用户变量,仅对当前用户有效,带有@符号

----带有多个OUT参数的过程

比如一个拥有很多字段的数据表

实现过程:删除某个id的字段,返回被删除的用户,以及返回剩余的用户

DELIMITER //

CREATE PROCEDURE removereturn2(IN p_age SMALLINT UNSIGNED,OUT remove_user SMALLINT UNSIGNED,OUT usercount SMALLINT UNSIGNED)

BEGIN

DELETE FROM test WHERE age=p_age;

SELECT ROW_COUNT() INTO REMOVE_USER;

SELECT COUNT(ID) FROM test INTO USERCOUNT;

END

//

DELIMITER ;

其中,ROW_COUNT是个自带函数

CALL REMOVERETURN2(20,@A,@B);

SELECT @A,@B;

需要注意的是,由于过程的创建后不能修改,第一次创建尽量不要错,要不就不要怕麻烦

----存储过程和自定义函数的区别

存储过程功能复杂一些,常用于对表的操作;函数一般不用做对表的操作

~~~~可以返回多个值;函数一般返回一个值

~~~~一般独立的来执行;函数可以作为其他SQL语句的组成部分来出现

~~~~常用,来封装复杂过程;函数很少用

2、PHP与MySQL

明天开始学习PHP中常用的MySQL函数(?)

 

bye

 

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

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

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

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

NAVICATでデータベースパスワードを取得できますか? NAVICATでデータベースパスワードを取得できますか? Apr 08, 2025 pm 09:51 PM

NAVICAT自体はデータベースパスワードを保存せず、暗号化されたパスワードのみを取得できます。解決策:1。パスワードマネージャーを確認します。 2。NAVICATの「パスワードを記憶する」機能を確認します。 3.データベースパスワードをリセットします。 4.データベース管理者に連絡してください。

MySQLのクエリ最適化は、特に大規模なデータセットを扱う場合、データベースのパフォーマンスを改善するために不可欠です MySQLのクエリ最適化は、特に大規模なデータセットを扱う場合、データベースのパフォーマンスを改善するために不可欠です Apr 08, 2025 pm 07:12 PM

1.正しいインデックスを使用して、データの量を削減してデータ検索をスピードアップしました。テーブルの列を複数回検索する場合は、その列のインデックスを作成します。あなたまたはあなたのアプリが基準に従って複数の列からのデータが必要な場合、複合インデックス2を作成します2。選択した列のみを避けます。必要な列のすべてを選択すると、より多くのサーバーメモリを使用する場合にのみサーバーが遅くなり、たとえばテーブルにはcreated_atやupdated_atやupdated_atなどの列が含まれます。

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

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

MySQLでテーブルをコピーする方法 MySQLでテーブルをコピーする方法 Apr 08, 2025 pm 07:24 PM

MySQLでテーブルをコピーするには、新しいテーブルの作成、データの挿入、外部キーの設定、インデックスのコピー、トリガー、ストアドプロシージャ、および機能が必要です。特定の手順には、同じ構造を持つ新しいテーブルの作成が含まれます。元のテーブルからデータを新しいテーブルに挿入します。同じ外部キーの制約を設定します(元のテーブルに1つがある場合)。同じインデックスを作成します。同じトリガーを作成します(元のテーブルに1つがある場合)。同じストアドプロシージャまたは関数を作成します(元のテーブルが使用されている場合)。

MariadBのNAVICATでデータベースパスワードを表示する方法は? MariadBのNAVICATでデータベースパスワードを表示する方法は? Apr 08, 2025 pm 09:18 PM

Passwordが暗号化された形式で保存されているため、MariadbのNavicatはデータベースパスワードを直接表示できません。データベースのセキュリティを確保するには、パスワードをリセットするには3つの方法があります。NAVICATを介してパスワードをリセットし、複雑なパスワードを設定します。構成ファイルを表示します(推奨されていない、高リスク)。システムコマンドラインツールを使用します(推奨されません。コマンドラインツールに習熟する必要があります)。

mysqlを表示する方法 mysqlを表示する方法 Apr 08, 2025 pm 07:21 PM

次のコマンドでmysqlデータベースを表示します。サーバーに接続します:mysql -u username -pパスワードrun showデータベース。すべての既存のデータベースを取得するコマンド[データベース]を選択します。データベース名を使用します。テーブルを表示:表を表示します。テーブル構造を表示:テーブル名を説明してください。データを表示:[テーブル名]から[ *]を選択します。

See all articles