zoukankan      html  css  js  c++  java
  • mysql

    delimiter //
    drop PROCEDURE proc_member_preprocessor;//
    CREATE PROCEDURE proc_member_preprocessor (IN param_uid int(10))
    main:BEGIN 
        SELECT COUNT(uid) INTO @proc_has_user FROM pre_common_member WHERE uid=param_uid;
    
        IF @proc_has_user < 1 THEN
            LEAVE main;
        END IF;
    
        INSERT INTO pre_common_member_tongji (uid,username,friends,posts,doings) (SELECT uid,'admin',friends,posts,doings FROM pre_common_member_count WHERE uid=param_uid);
    END;//
    CREATE TRIGGER trigger_pre_post AFTER INSERT ON pre_forum_thread FOR EACH ROW CALL proc_member_preprocessor(NEW.authorid);

     解释下触发器的语法:

    CREATE TRIGGER TIME(BEFORE | AFTER) EVENT(INSERT | UPDATE | DELETE) ON table FOR EACH ROW sql 

    UPDATE包含(NEW,OLD)INSERT(NEW)DELETE只有(OLD)

    http://www.cnblogs.com/amboyna/archive/2008/01/27/1055178.html 这个文章里面说的非常详细。

    /*定义存储过程*/
    delimiter //
    DROP PROCEDURE pro_demo; //
    CREATE PROCEDURE pro_demo()
        SELECT * FROM pre_forum_thread;
    
    //
    
    
    /*传入变量*/
    delimiter //
    DROP PROCEDURE pro_demo; //
    CREATE PROCEDURE pro_demo(IN param_user varchar(30))
        SET @username = param_user;
    //
    
    
    /*传出变量*/
    delimiter //
    DROP PROCEDURE pro_demo; //
    CREATE PROCEDURE pro_demo(OUT param_uid int)
    BEGIN
        SET param_uid = 5;
    END; //
    CALL pro_demo(@y);//
    /*赋值并插入到数据表*/
    delimiter //
    DROP PROCEDURE pro_demo; //
    CREATE PROCEDURE pro_demo()
    BEGIN
        SET @a = '6';
        SET @b = 'xixi';
        INSERT INTO pre_proc_demo (k,v) VALUES (@a,@b);
    END; //
    /* 定义变量 @ INT,CHAR,VARCHAR..*/
    delimiter //
    DROP PROCEDURE pro_demo; //
    CREATE PROCEDURE pro_demo()
    BEGIN
        DECLARE a VARCHAR(5);
        DECLARE b VARCHAR(5);
        SET a='12345';
        SET b='awddwaadw';
        INSERT INTO pre_proc_demo (k,v) VALUES (a,b);
    END; //
    /* 存储过程中if else的使用 */
    delimiter //
    DROP PROCEDURE sp_demo; //
    CREATE PROCEDURE sp_demo(IN param_var int(10))
    BEGIN
        DECLARE a INT(10);
        SET a = param_var + 1;
        
        if a = 0 then
        SELECT 0;
        elseif a % 2 = 0 then
        SELECT 2;
        else
        SELECT 1;
        end if;
    END;//
    
    /* case语句的使用 */
    delimiter //
    DROP PROCEDURE sp_demo; //
    CREATE PROCEDURE sp_demo(IN param_uid int(10))
    BEGIN
        case param_uid
        when 0 then SELECT "这是0";
        when 1 then SELECT "这是1";
        else SELECT "没找到";
        end case;
    END; //
    
    /* while do..while的使用 */
    delimiter //
    DROP PROCEDURE sp_demo; //
    CREATE PROCEDURE sp_demo(IN param_i int(10))
    BEGIN
        while param_i < 10 
        do
        SELECT param_i;
        set param_i=param_i+1;
        end while;
    END; //
    
    /* repeat的使用 */
    delimiter //
    DROP PROCEDURE sp_demo; //
    CREATE PROCEDURE sp_demo(IN param_i int(10))
    BEGIN
        repeat 
        SELECT param_i;
        set param_i = param_i + 1;
        until param_i > 10
        end repeat;
    END; //
    
    /* loop的使用 */
    delimiter //
    DROP PROCEDURE sp_demo; //
    CREATE PROCEDURE sp_demo(IN param_i int(10))
    BEGIN
    
        LOOP_DEMO:loop
        SELECT param_i;
        set param_i = param_i + 1;
    
        if param_i > 5 then
        leave LOOP_DEMO;
        end if;
    
        end loop;
    END; //
  • 相关阅读:
    数据结构笔记(第三章)
    数据结构笔记(第二章)
    Java第三阶段学习(四、缓冲流)
    Java第三阶段学习(三、字符流、转换流)
    Java第三阶段学习(二、IO流--------递归,字节流Stream)
    Java学习(异常类)
    Java学习(异常类练习题)
    Java学习(JDBC java连接数据库)
    Java学习(Map接口)
    Java学习(set接口、HashSet集合)
  • 原文地址:https://www.cnblogs.com/yimiao/p/3230298.html
Copyright © 2011-2022 走看看