例子仅在windows下测试通过,没有放在linux下测试。如有问题,可以电邮给我~
1、安装node.js、mysql,此处略(自行搜索吧)…;
2、创建一个名为test的数据库,然后建一张名为user_info的表(仅供测试)…
这里假定mysql使用的用户名为root,密码为123456
相应的mysql如下:
/** * 创建名为test的数据库 */ DROP DATABASE IF EXISTS test; CREATE DATABASE test; USE test; /** * 创建user_info表 */ DROP TABLE IF EXISTS `user_info`;CREATE TABLE `user_info` ( `userId` int(10) NOT NULL AUTO_INCREMENT, `userName` varchar(20) DEFAULT NULL, PRIMARY KEY (`userId`) ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
/** * 插入三条记录 */ INSERT INTO user_info VALUES (NULL, '张一'), (NULL, '张二'), (NULL, '张三');
3、创建存储过程(写的很冗余,故意的… 正好学习一下语法>_<);
DELIMITER $$ DROP PROCEDURE IF EXISTS `test`.`proc_simple`$$ CREATE PROCEDURE proc_simple(IN uid INT(10), OUT uName VARCHAR(2), OUT totalCount INT) BEGINDECLARE str_name VARCHAR(20);
SET @str_name = ''; SET totalCount = 0; SELECT COUNT(1),userName INTO totalCount,@str_name FROM user_info WHERE userId = uid; SET uName = @str_name; SELECT uName, totalCount; END$$ DELIMITER ;
4、写程序进行调用(假定存为名为sql.js的文件);
/** * Created with JetBrains WebStorm. * User: Meteoric_cry * Date: 12-12-28 * Time: 上午00:18 * To change this template use File | Settings | File Templates. */ var mysql = require('mysql');var connection = mysql.createConnection({ host : 'localhost', port : 3306, user : 'root', password : '123456', database : 'test', charset : 'UTF8_GENERAL_CI', debug : false });
connection.connect();
connection.query('CALL proc_simple(1, @a, @b);', function(err, rows, fields) { if (err) { throw err; }
var results = rows[0]; var row = results[0]; console.log("userName:",row.uName, " count:", row.totalCount); });
connection.end();
5、运行示例程序;
问题内容: 我在任何地方都找不到此答案,但是可以从MySQL中的另一个存储过程调用存储过程吗?我想找回标识值,并在父存储过程中使用它。我们不能再使用FUNCTIONS! 问题答案: 参数应该可以帮助您将值返回给调用过程。基于此,解决方案必须是这样的。
问题内容: 我试图在postgres 9.3上使用sql调用函数内的函数。 这个问题与我的另一篇文章有关。 我写了下面的函数。到目前为止,我还没有合并任何类型的save-output(COPY)语句,因此我试图通过创建嵌套函数print-out函数来解决此问题。 以上功能有效。 尝试创建嵌套函数。 调用嵌套函数。 输出 上面给出了这个。但是,当在print_out()中将arg1,arg2替换为’
问题内容: 我花了大约7个小时试图通过反复试验找出答案。我看到的所有在线示例都不起作用,或者不适用,或者仅显示Im所寻找内容的一半。 这是我要的内容:1.一个使用一个IN参数和一个OUT参数的MYSQL中简单存储过程的示例。2.使用C#从Visual Studio调用FUNCTIONING(确实很重要,导致在线示例有时无法工作…)的示例。文本调用或存储过程命令类型都可以。3.不推荐使用AddWit
主要内容:调用存储过程,调用存储函数存储过程和存储函数都是存储在服务器端的 SQL 语句集合。要想使用这些已经定义好的存储过程和存储函数就必须要通过调用的方式来实现。 存储过程通过 CALL 语句来调用,存储函数的使用方法与 MySQL 内部函数的使用方法相同。执行存储过程和存储函数需要拥有 EXECUTE 权限(EXECUTE 权限的信息存储在 information_schema 数据库下的 USER_PRIVILEGES 表中
本文向大家介绍C#中调用MySQL存储过程的方法,包括了C#中调用MySQL存储过程的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#中调用MySQL存储过程的方法。分享给大家供大家参考。具体如下: 这段代码演示在 C# 程序中调用 MySQL 的存储过程,没有返回值,没有参数传递。 希望本文所述对大家的C#程序设计有所帮助。
我使用JDBC这样调用这个过程: 它向我抛出一个错误,通知调用格式错误。 但是如果我像这样直接在IDE中运行调用: