MySQLÖÐʹÓô洢¹ý³Ì(ÕûÀí)
MySQLÖÐʹÓô洢¹ý³Ì
ʹÓÃCallableStatementsÖ´Ðд洢¹ý³Ì
mysql°æ±¾:5.0
Connector/JµÄ°æ±¾:3.1.1ÒÔÉÏ(java.sql.CallableStatement½Ó¿ÚÒÑÍêȫʵÏÖ,³ýÁËgetParameterMetaData()·½·¨)
MySQLµÄ´æ´¢¹ý³ÌÓï·¨ÔÚMySQL²Î¿¼ÊÖ²áµÄ"´æ´¢¹ý³ÌºÍº¯Êý"Ò»ÕÂ.
http://www.mysql.com/doc/en/Stored_Procedures.html
ÏÂÃæÊÇÒ»¸ö´æ´¢¹ý³Ì,·µ»ØÒ»¸öinOutParamÔö1ºóµÄÖµ,ÒÔResultSetÐÎʽ´«ÈëÒ»¸ö×Ö·û´®²ÎÊýinputParam.
CREATE PROCEDURE demoSp(IN inputParam VARCHAR(255), INOUT inOutParam INT)
BEGIN
DECLARE z INT;
SET z = inOutParam + 1;
SET inOutParam = z;
SELECT inputParam;
SELECT CONCAT('zyxw', inputParam);
END
Ҫͨ¹ýconnector/JʹÓÃdemoSpÕâ¸ö´æ´¢¹ý³Ì,Òª¾¹ý¼¸¸ö²½Öè:
1.Connection.prepareCall()
import java.sql.CallableStatement;
...
//
// Prepare a call to the stored procedure 'demoSp'
// with two parameters
//
// Notice the use of JDBC-escape syntax ({call ...})
//
CallableStatement cStmt = conn.prepareCall("{call demoSp(?, ?)}");
cStmt.setString(1, "abcdefg");
Connection.prepareCall()·½·¨·Ç³£ÏûºÄ×ÊÔ´,ÒòΪjdbcÇý¶¯Í¨¹ýÔªÊý¾Ý(metadata)µÄ»ñȡ֧³ÖÊä³ö²ÎÊý.³öÓÚÖ´ÐÐЧÂʵĿ¼ÂÇ,Ó¦¸Ã¾¡¿ÉÄܼõÉÙ²»±ØÒªµÄprepareCallµ÷ÓÃ,ÖØÓÃCallableStatement¶ÔÏó.
2.×¢²áÊä³ö²ÎÊý(Èç¹ûÓеϰ)
ÒªµÃµ½Êä³ö²ÎÊýµÄÖµ(´´½¨´æ´¢¹ý³ÌʱÉèÖõÄOUTºÍINOUT),JDBCÒªÇóÕâЩ²ÎÊý±ØÐëÒªÔÚÊý¾Ý¿â²Ù×÷Ö´ÐÐ֮ǰͨ¹ýregisterOutputPrameter()·½·¨ÉèÖÃ.
import java.sql.Types;
...
//
// ÏÂÃæ¸ø³öÁËÉèÖÃÊä³ö²ÎÊýµÄ¼¸¸ö·½·¨
//
// ×¢²áµÚ¶þ¸ö²ÎÊýΪÊä³ö²ÎÊý
//
cStmt.registerOutParameter(2);
//
// ×¢²áµÚ¶þ¸ö²ÎÊýΪÊä³ö²ÎÊý,É趨getObjectµÃµ½µÄ·µ»ØÖµµÄÀàÐÍΪÕûÐÍ
//
cStmt.registerOutParameter(2, Types.INTEGER);
//
// ×¢²áÃûΪ"inOutParam"µÄ²ÎÊýΪÊä³ö²ÎÊý
//
cStmt.registerOutParameter("inOutParam");
//
// ×¢²áÃûΪ"inOutParam"µÄ²ÎÊýΪÊä³ö²ÎÊý,É趨getObjec
Ïà¹ØÎĵµ£º
¼Ù¶¨±ítbl_name¾ßÓÐÒ»¸öPRIMARY KEY»òUNIQUEË÷Òý£¬±¸·ÝÒ»¸öÊý¾Ý±íµÄ¹ý³ÌÈçÏ£º
1¡¢Ëø¶¨Êý¾Ý±í£¬±ÜÃâÔÚ±¸·Ý¹ý³ÌÖУ¬±í±»¸üÐÂ
mysql>LOCK
TABLES READ tbl_name;
¹ØÓÚ±íµÄËø¶¨µÄÏêϸÐÅÏ¢£¬½«ÔÚÏÂÒ»Õ½éÉÜ¡£
2¡¢µ¼³öÊý¾Ý
mysql>SELECT
* INTO OUTFILE ‘tbl_name.bak’ from tbl_name;
3¡¢½âË ......
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using MySql.Data.Types;
using MySql.Data.MySqlCl ......
mysqlÓÐÒ»¸ö¹¦ÄܾÍÊÇ¿ÉÒÔlogÏÂÀ´ÔËÐеıȽÏÂýµÄsqlÓï¾ä£¬Ä¬ÈÏÊÇûÓÐÕâ¸ölogµÄ£¬ÎªÁË¿ªÆôÕâ¸ö¹¦ÄÜ£¬
ÒªÐÞ¸Ämy.cnf»òÕßÔÚmysqlÆô¶¯µÄʱºò¼ÓÈëһЩ²ÎÊý¡£Èç¹ûÔÚmy.cnfÀïÃæÐ޸ģ¬ÐèÔö¼ÓÈçϼ¸ÐÐ
long_query_time = 1
log-slow-queries = /var/youpath/slow.log
log-queries-not-using-indexes
long_query_time ÊÇÖ¸Ö´ ......
²é¿´·þÎñÆ÷Ŀǰ״̬ÐÅÏ¢µÄÃüÁÁ½ÖÖ·½Ê½£º
1. ÃüÁîÐУ¬½øÈëmysql/binĿ¼Ï£¬ÊäÈëmysqladmin extended-status
2. Á¬½Óµ½mysql£¬ÊäÈëshow status;
3. Èç¹ûÒª²é¿´Ä³¸öÊý¾Ý£¬¿ÉÒÔ
mysql> show s ......