線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:2669
推到 Plurk!
推到 Facebook!

MySQL5.0 alpha

 
conundrum
尊榮會員


發表:893
回覆:1272
積分:643
註冊:2004-01-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-06-11 01:15:05 IP:61.64.xxx.xxx 未訂閱
Peeking in MySQL5.0 alpha Enterprise Functional DennisLan(原作) http://www.itcareers.cn/bbs/showthread.asp?threadid=147 Peeking in MySQL 5.0 Enterprise Functional 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 這裏提供了詳細的解決方案.
xportal
一般會員


發表:1
回覆:3
積分:0
註冊:2004-06-18

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-06-18 14:52:44 IP:61.221.xxx.xxx 未訂閱
對於Mysql放個空氣出來的做法我是很反感,在一年多前Mysql放一個具有subquery功能的4.04版在當時是開發版,但是Mysql公司豉勵程式設計師使用,結果現在已是一年多了還是測試版,待成為正式版是不知民國幾年,害得我當時大量的用這些功能開發,程式推出來了,但是資料庫還不是正式版,我是苦不堪言,雖然4.12版我們用了一年多了,基本上是沒有什麼問題,可是用戶可能不這麼想。 免費的Xportal包含了全功能的總務行政管理,人力資源管理和客戶關係管理系統,功能強大且昜於擴充,對於不善於中文輸入的經營者或是主管們也能輕昜的上手使用。特別適合於對安全控管和注重實務功能的異地多公司(含轉投資公司)的集團企業,連鎖通路,加盟店面管理,多點經營的公司和策略連盟公司的管理....等等使用。有興建的朋友,可以到我的站台下載用Mysql4.12版的軟體。 創新且免費的企業入口網http://xportal.cn/
------
創新且免費的企業入口網http://xportal.cn/
系統時間:2024-04-29 19:56:19
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!