分享
 
 
 

MySQL5.0 Alpha & Create Procedure

王朝mysql·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

程序员大本营 2004-02-02

MySQL5.0 Alpha 發佈, 我們期待已久的 Create Function 和 Create Procedure 的功能終於有了. 詳細的資訊請參考 MySQL AB 的官方網站的 新聞. 早就想要的功能,出來了還不趕快試試....

本文以 Windows XP PRO os 為例< :) 我可不是有意來替 M$ 宣傳,只是我用的是 Windows,沒有辦法啦 >來說明,其它OS 類同, 先下載 MySQL5.0, 為了免除安裝,我們直接下載 Without installer (unzip in C:\) 的版本,到 http://www.mysql.com/downloads/mysql-5.0.html 下載.

1. 直接 unzip 後把其放到 C:\ 下, 並把 root Directory 改為 mysql(不改也可,那在 my.ini 中要把其中的 mysql 改為你的實際名稱)

2. 下面是 my.ini 的配置文件,如果你對配置不熟的話,你可以直接 Copy 過去存為 my.ini 後放到 C:\windows 下即可 (我電腦的 RAM = 256)

========================================================================================================

# Example mysql config file.

# Copy this file to c:\my.cnf to set global options

#

# One can use all long options that the program supports.

# Run the program with --help to get a list of available options

# This will be passed to all mysql clients

[client]

#password=my_password

port=3306

#socket=MySQL

# Here is entries for some specific programs

# The following values assume you have at least 32M ram

# The MySQL server

[mysqld]

port=3306

#socket=MySQL

skip-locking

set-variable = key_buffer=16M

set-variable = max_allowed_packet=1M

set-variable = table_cache=64

set-variable = sort_buffer=512K

set-variable = net_buffer_length=8K

set-variable = myisam_sort_buffer_size=8M

server-id = 1

# Uncomment the following if you want to log updates

#log-bin

# Uncomment the following rows if you move the MySQL distribution to another

# location

#basedir = d:/mysql/

#datadir = d:/mysql/data/

# Uncomment the following if you are NOT using BDB tables

#skip-bdb

# Uncomment the following if you are using BDB tables

#set-variable = bdb_cache_size=4M

#set-variable = bdb_max_lock=10000

# Uncomment the following if you are using Innobase tables

innodb_data_file_path = ibdata1:400M

innodb_data_home_dir = C:/mysql/InnoDB/ibdata # InnoDB 及 ibdata 的資料夾你要自己動手

innodb_log_group_home_dir = C:/mysql/InnoDB/iblogs # iblogs 的資料夾同樣你要自己動手

innodb_log_arch_dir = C:/mysql/innodb/iblogs

set-variable = innodb_mirrored_log_groups=1

set-variable = innodb_log_files_in_group=3

set-variable = innodb_log_file_size=5M

set-variable = innodb_log_buffer_size=8M

innodb_flush_log_at_trx_commit=1

innodb_log_archive=0

set-variable = innodb_buffer_pool_size=16M

set-variable = innodb_additional_mem_pool_size=2M

set-variable = innodb_file_io_threads=4

set-variable = innodb_lock_wait_timeout=50

[mysqldump]

quick

set-variable = max_allowed_packet=16M

[mysql]

no-auto-rehash

# Remove the next comment character if you are not familiar with SQL

#safe-updates

[isamchk]

set-variable = key_buffer=20M

set-variable = sort_buffer=20M

set-variable = read_buffer=2M

set-variable = write_buffer=2M

[myisamchk]

set-variable = key_buffer=20M

set-variable = sort_buffer=20M

set-variable = read_buffer=2M

set-variable = write_buffer=2M

[mysqlhotcopy]

interactive-timeout

[WinMySQLAdmin]

Server=C:/mysql/bin/mysqld-nt.exe

============================================================================

3. Create InnoDB table table space 如果運行沒有問題,你應該可以看到如下內容:

==========================================================

C:\mysql\bin>mysqld --console

InnoDB: The first specified data file C:\mysql\InnoDB\ibdata\ibdata1 did not exist:

InnoDB: a new database to be created!

040113 15:12:54 InnoDB: Setting file C:\mysql\InnoDB\ibdata\ibdata1 size to 400 MB

InnoDB: Database physically writes the file full: wait...

InnoDB: Progress in MB: 100 200 300 400

040113 15:13:19 InnoDB: Log file C:\mysql\InnoDB\iblogs\ib_logfile0 did not exist: new to be created

InnoDB: Setting log file C:\mysql\InnoDB\iblogs\ib_logfile0 size to 5 MB

InnoDB: Database physically writes the file full: wait...

040113 15:13:19 InnoDB: Log file C:\mysql\InnoDB\iblogs\ib_logfile1 did not exist: new to be created

InnoDB: Setting log file C:\mysql\InnoDB\iblogs\ib_logfile1 size to 5 MB

InnoDB: Database physically writes the file full: wait...

040113 15:13:20 InnoDB: Log file C:\mysql\InnoDB\iblogs\ib_logfile2 did not exist: new to be created

InnoDB: Setting log file C:\mysql\InnoDB\iblogs\ib_logfile2 size to 5 MB

InnoDB: Database physically writes the file full: wait...

InnoDB: Doublewrite buffer not found: creating new

InnoDB: Doublewrite buffer created

InnoDB: Creating foreign key constraint system tables

InnoDB: Foreign key constraint system tables created

040113 15:13:26 InnoDB: Started; log sequence number 0 0

mysqld: ready for connections.

Version: '5.0.0-alpha-max-debug' socket: '' port: 3306

==========================================================

安裝 Ok, 進去看看吧,沒想到一進 Mysql 馬上就來了個下馬威, 原來的 '' 這個 user 不能用 mysql 的 databases

=========================================================

C:\mysql\bin>mysql

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 2 to server version: 5.0.0-alpha-max-debug

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> use mysql

ERROR 1044 (42000): Access denied for user: ''@'localhost' to database 'mysql

==========================================================

沒有辦法,只有用 root 進去:

==========================================================

C:\mysql\bin>mysql -u root -p

Enter password:

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 5 to server version: 5.0.0-alpha-max-debug

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql>

==========================================================

:) root 的密碼還是勤快一點把它改掉吧

4. 體驗一下 Create Function 吧

CREATE FUNCTION MyFunc (s CHAR(20)) RETURNS CHAR(50) RETURN CONCAT('Hello ',s,' DLL',' !');

==========================================================

mysql> CREATE FUNCTION MyFunc (s CHAR(20)) RETURNS CHAR(50) RETURN CONCAT('Hello

',s,'.Lan',' !');

Query OK, 0 rows affected (0.00 sec)

mysql>

mysql> select MyFunc('Dennis');

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

| MyFunc('Dennis') |

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

| Hello Dennis.Lan ! |

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

1 row in set (0.01 sec)

mysql>

==========================================================

5. Drop Function

==========================================================

mysql> drop function MyFunc;

Query OK, 0 rows affected (0.00 sec)

mysql>

==========================================================

6. Create 一個 Procedure 試試吧!

CREATE PROCEDURE MyProc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param1 FROM sys_forms; END;

千萬記住,下面這樣子不行喲, 我試了 n 次, 每次都是錯誤, 我還以為 Mysql 有問題呢,原來不是

==========================================================

mysql> use test;

Database changed

mysql> CREATE PROCEDURE MyProc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param

1 FROM sys_forms; END;

ERROR 1064 (42000): You have an error in your SQL syntax. Check the manual that

corresponds to your MySQL server version for the right syntax to use near 'SELE

CT COUNT(*) INTO param1 FROM sys_forms' at line 1

==========================================================

正確的做法是:

==========================================================

mysql> delimiter | # 因為你的 Procedure 或 Function中難免會用到 ";" 作為 sql statement 的結束符, 所以還是請你把這個結束符號改一下吧,不然就會出現上面的 error 1064(42000)

mysql> CREATE PROCEDURE MyProc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param1 FROM mysql.user; END;

-> |

Query OK, 0 rows affected (0.00 sec)

==========================================================

OK, 你的成功了嗎?

強烈建議你先看看這個 http://www.mysql.com/doc/en/CREATE_PROCEDURE.html

Procedure Create 成功了,測試一下吧!

Step 1:

==========================================================

mysql> CALL MyProc(@a)|

Query OK, 0 rows affected (0.01 sec)

==========================================================

Step 2:

==========================================================

mysql> select @a;

-> |

+------+

| @a |

+------+

| 0 |

+------+

1 row in set (0.00 sec)

mysql>

==========================================================

來個完整的:

==========================================================

mysql> CREATE PROCEDURE MyProc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param

1 FROM mysql.user; END;

-> |

Query OK, 0 rows affected (0.00 sec)

mysql> call MyProc(@a)|

Query OK, 0 rows affected (0.03 sec)

mysql> select @a |

+------+

| @a |

+------+

| 4 |

+------+

1 row in set (0.00 sec)

==========================================================

7. Drop Procedures:

這樣子做怎麼又不對呀?

==========================================================

mysql> drop procedure myproc;

-> |

ERROR 1289 (42000): PROCEDURE myproc does not exist

==========================================================

原來 Windows 下的 MySQL 在 Procedure 的問題上又區分起輩份的大小了,下面這樣才對啊!

==========================================================

mysql> drop procedure MyProc|

Query OK, 0 rows affected (0.00 sec)

==========================================================

注: 如果你在和應用程式連結的時候出現

Client does not support authentication protocol requested by server; consider upgrading MySQL client

請參考 http://www.mysql.com/doc/en/Old_client.html 這里提供了詳細的解決方案.

Enjoy it yourself!

Good Luck!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有