delimiter // create procedure j2 begin select sno, sname, ssex, scredit from student where year(sbir)='1998’ and sno like'160422%'; End // delimiter call j2;有错误吗
时间: 2023-11-28 14:50:03 浏览: 129
是的,这段代码有错误。在第三行的语句中,由于单引号未正确闭合,导致语法错误。应该将第三行的代码修改为:
```
select sno, sname, ssex, scredit from student where year(sbir)='1998' and sno like '160422%';
```
另外,你还需要将第一行和最后一行的 `delimiter //` 修改为 `delimiter ;`,以便正确设置语句分隔符。完整代码如下所示:
```
delimiter ;
create procedure j2
begin
select sno, sname, ssex, scredit from student where year(sbir)='1998' and sno like '160422%';
end;
delimiter ;
call j2;
```
相关问题
说明这段代码是干什么的create database 学生选课; use 学生选课; source C:\Users\Administrator\Desktop\xuexi.sql show tables; select * from student; set @c1=1,@c2=2,@c3=3; select @c1,@c2,@c3; delimiter // create function fn1() returns datetime reads sql data begin return now(); end// select fn1() as 当前时间// select now()// delimiter // create function fn2(a int,b int) returns int reads sql data begin return a+b; end// select fn2(321,123)// select fn2(9876,3546)// show create function fn1\G drop function fn1// create procedure proc1() begin declare a int default 100; set a=a+50; select a; end// call proc1()// delimiter // create procedure aaa() begin declare v varchar(5); set v='你好'; if v is null then select '是空值'; else select '不是空值'; end if; end// call aaa()// delimiter // create procedure bbb() begin declare v int; set v=100; case v when 1 then select'值是1'; when 2 then select'值是2'; else select '值不是1也不是2'; end case; end // call bbb()// delimiter // create procedure xunhuan() begin declare pl int default 0; my_loop:loop set pl=pl+1; select '你真好看'; if pl>10 then leave my_loop; end if; end loop my_loop; end// call xunhuan()// delimiter // create procedure p_student () begin select *from student; end// call p_student()// desc student// delimiter // create procedure p_student2(dept varchar(8)) begin select * from student where sdept=dept; end// call p_student2('云计算技术')// call p_student2('人工智能系')// call p_student2('大数据技术')// delimiter // create procedure p_student3(sex char(2), out renshu int) begin if sex='男' then select count(ssex) into renshu from student where ssex='男'; else select count(ssex) into renshu from student where ssex='女'; end if; end// call p_student3('男', @renshu)// select @renshu // call p_student3('女', @renshu)// select @renshu// show create procedure p student2\G drop procedure p student2// create database 网上书店数据库; use 网上书店数据库; source C:\Users\Administrator\Desktop\online bookstore.sql show tables; select * from user; delimiter // create procedure proc_1() begin select * from user; end// call proc_1()// delimiter // create procedure proc_2(昵称 varchar(20),out 积分 int) begin select score into 积分 from user where uname=昵称; end// call proc_2( 平平人生,@积分)// select @积分// call proc_2(感动心灵’,@积分)// select @积分//
这段代码是在MySQL数据库中创建一个名为"学生选课"的数据库,然后使用该数据库,并从指定的文件路径导入SQL语句执行。接着展示数据库中的表格,查询学生表格并设置三个变量的值。接下来创建两个函数fn1和fn2,并进行测试调用。然后创建四个存储过程proc1、aaa、bbb和xunhuan,并分别进行测试调用。最后在新创建的名为"网上书店数据库"的数据库中创建两个存储过程proc_1和proc_2,并进行测试调用。
解释一下数据库代码什么意思delimiter // ysg1>create procedure p_student ( begin ->select *from student;end/luery 0K,0 rows affected (0.01 sec) wysql> cal1 p student0//RROR 1064 (42000): You have an error in your SQL syntax; check thwysql>delimiter//wysql>create procedure p_student(0)begin->select * from student.->end/!RROR 1304 (42000): PROCEDURE p_student already existswysql> delimiter //uysql> create procedure p_student -> beginselect* from student;end/!
这是一个 MySQL 存储过程的创建语句。存储过程是一些预定义 SQL 语句的集合,可以被多次调用。这个存储过程名字叫做 `p_student`。
在这个例子中,使用了 `delimiter` 命令来改变语句结束符号为 `//`,以便在存储过程中使用分号。这个命令告诉 MySQL 解释器,当遇到 `//` 时,表示当前语句的结束。这样可以避免在存储过程中使用分号时出现歧义。
第一个例子中的存储过程定义有一些语法错误。`create procedure p_student ( begin ->select *from student;end/` 中的括号后面没有加上 `)` 符号,而且在 `end/` 后面多了一个冒号。另外,查询语句的后面缺少了分号。
第二个例子中,正确使用了 `delimiter` 命令,并定义了一个名为 `p_student` 的存储过程,其中的查询语句是 `select * from student;`,它会返回 `student` 表中的所有数据行。
第三个例子中,存储过程 `p_student` 已经存在了,因此不能再次创建同名的存储过程。如果想要更新已有的存储过程,可以使用 `alter procedure` 命令。
阅读全文