2016-12-07 3 views
2

Ich habe diesen Code (I die Variablen für mysql Testzwecken ersetzt), die in mysql & phpMyAdmin arbeitet daher ist es anhängt -1 -2 -3 und so weiter bis zum course_no:Mysql Delimiter arbeitet in mysql, aber nicht in PHP

drop trigger if exists change_course_no; 

delimiter | 

CREATE TRIGGER change_course_no BEFORE INSERT ON hybrid_locked 
FOR EACH ROW BEGIN 
declare original_course_no varchar(50); 
declare course_no_counter int; 
set original_course_no = new.course_no; 
set course_no_counter = 1; 


while exists (select true from hybrid_locked where course_no = new.course_no) do 
set new.course_no = concat(original_course_no, '-', course_no_counter); 
set course_no_counter = course_no_counter + 1; 
end while; 

END; 

| 

delimiter ; 


insert into hybrid_locked (
requestor_name, academic_unit, 
instructor_name, instructor_email, tel_number, creds, more_instructors, 
course_name, program_name, term, course_no, classroom, comments, online_exam, participants, hybrid_past1, hybrid_past2, hybrid_past3, date_requested, 

main_date_start, main_date_end, main_time_start, main_time_end, 
sec_date_start, sec_date_end, sec_time_start, sec_time_end, 
unique_date1, unique_date1_time_start, unique_date1_time_end, 
unique_date2, unique_date2_time_start, unique_date2_time_end 
) 

values ('Smith', 'test', 
'Joe', '[email protected]', '555-555-5555', 'no', '', 
'Physics', '', 'summer', 'TEST101', '1025', '', 'yes', '10', 
'unsure', 'unsure', 'unsure', '2016-12-05', 

'2016-12-06', '2016-12-29', '17:45:00', '19:45:00', 
'0000-00-00', '0000-00-00', '00:00:00', '00:00:00', 
'0000-00-00', '00:00:00', '00:00:00', 
'0000-00-00', '00:00:00', '00:00:00' 
); 

Aber wenn ich es meinen PHP-Skript hinzufügen, schlägt es mit Fehlern:

Sie haben einen Fehler in Ihrer SQL-Syntax; Überprüfen Sie das Handbuch, das Ihrer MySQL-Serverversion entspricht, nach der richtigen Syntax, die in der Nähe von 'delimiter | verwendet werden soll CREATE TRIGGER change_course_no BEFORE INSERT ON FO‘hybrid_locked in Zeile 3

Dies ist der Code in der PHP-Form:

$query_hybrid = 

" 
drop trigger if exists change_course_no; 

delimiter | 

CREATE TRIGGER change_course_no BEFORE INSERT ON hybrid_locked 
FOR EACH ROW BEGIN 
declare original_course_no varchar(50); 
declare course_no_counter int; 
set original_course_no = new.course_no; 
set course_no_counter = 1; 


while exists (select true from hybrid_locked where course_no = new.course_no) do 
set new.course_no = concat(original_course_no, '-', course_no_counter); 
set course_no_counter = course_no_counter + 1; 
end while; 

END; 

| 

delimiter ; 


insert into hybrid_locked (
requestor_name, academic_unit, 
instructor_name, instructor_email, tel_number, creds, more_instructors, 
course_name, program_name, term, course_no, classroom, comments, online_exam, participants, hybrid_past1, hybrid_past2, hybrid_past3, date_requested, 

main_date_start, main_date_end, main_time_start, main_time_end, 
sec_date_start, sec_date_end, sec_time_start, sec_time_end, 
unique_date1, unique_date1_time_start, unique_date1_time_end, 
unique_date2, unique_date2_time_start, unique_date2_time_end 
) 

values ('$requestor_name', '$academic_unit', 
'$instructor_name', '$instructor_email', '$tel_number', '$creds', '$more_instructors', '$course_name', '$program_name', '$term', '$course_no', '$classroom', '$comments', '$online_exam', '$participants', '$hybrid_past1', '$hybrid_past2', '$hybrid_past3', '$date_requested', 

'$main_date_start', '$main_date_end', '$main_time_start', '$main_time_end', 
'$sec_date_start', '$sec_date_end', '$sec_time_start', '$sec_time_end', 
'$unique_date1', '$unique_date1_time_start', '$unique_date1_time_end', 
'$unique_date2', '$unique_date2_time_start', '$unique_date2_time_end' 
)"; 

Ich kann nicht verstehen, was ich auf der PHP-Skript bin fehle?

Danke, Chris

Antwort

1

Sie sollten wahrscheinlich nicht sowieso von innen PHP tun, aber wenn Sie das tun, was Sie verwenden ist mysqli_multi_query

bool mysqli_multi_query (mysqli $link , string $query) Executes one or multiple queries which are concatenated by a semicolon.

Andere Methoden, die Sie nicht zulassen sollte um mehr als eine Abfrage in einem API-Aufruf auszuführen.

+0

Ich kann mysqli auf diesem aktuellen Server leider nicht verwenden – PAPADOC

+0

Nun, wenn Sie auf einem Server sind, der nur mysql_ * unterstützt, tun Sie sich selbst einen riesigen Nachteil, indem Sie ihn weiterhin verwenden. – e4c5

+0

froh, dass ich geholfen habe – e4c5

Verwandte Themen