1.建立存储过程ybcx(邮编查询) ybcx(in jdmc varchar(10),out qxyb varchar(6)) 输入街道名称jdmc,显示其区县邮政编码qxyb 注意:街道名称值存储在数据表jdxx的name列中 qxyb值存储在数据表qxyzbm的qxyb列中
时间: 2023-12-12 15:02:04 浏览: 238
下面是建立存储过程ybcx的SQL语句:
```
CREATE PROCEDURE ybcx
@jdmc VARCHAR(10),
@qxyb VARCHAR(6) OUTPUT
AS
BEGIN
SELECT @qxyb = qxyb
FROM qxyzbm
WHERE qxdm IN (
SELECT qxdm
FROM jdxx
WHERE name = @jdmc
)
END
```
使用示例:
```
DECLARE @qxyb VARCHAR(6)
EXEC ybcx '某某街道', @qxyb OUTPUT
SELECT @qxyb AS '区县邮政编码'
```
说明:
- 存储过程名称为ybcx,输入参数为jdmc,输出参数为qxyb。
- 存储过程的主要逻辑是查询jdxx表中name等于输入参数jdmc的记录所对应的qxdm,然后在qxyzbm表中查找qxdm等于该值的记录,从而得到对应的区县邮政编码。
- 存储过程执行后,通过输出参数qxyb返回查询结果。
相关问题
使用MySQL语句建立存储过程ybcx(邮编查询) ybcx(in jdmc varchar(10),out qxyb varchar(6)) 输入街道名称jdmc,显示其区县邮政编码qxyb 注意:街道名称值存储在数据表jdxx的name列中 qxyb值存储在数据表qxyzbm的qxyb列中2.调用存储过程ybcx,查询岳麓街道的邮编 将结果存入变量@yzbm中
好的,以下是存储过程的代码:
```
CREATE PROCEDURE ybcx
(IN jdmc varchar(10), OUT qxyb varchar(6))
BEGIN
SELECT qxyzbm.qxyb
INTO qxyb
FROM jdxx
INNER JOIN qxyzbm ON jdxx.qxid=qxyzbm.qxid
WHERE jdxx.name=jdmc;
END
```
其中,`jdxx` 表是存储街道信息的表,包括街道名称和区县ID等字段。`qxyzbm` 表是存储区县邮政编码信息的表,包括区县ID和邮政编码等字段。
调用该存储过程,可以使用以下代码:
```
SET @yzbm = '';
CALL ybcx('岳麓街道', @yzbm);
SELECT @yzbm;
```
执行后,返回的结果会存储在 `@yzbm` 变量中,并输出到控制台上。
阅读全文