我正在编写sql和c ++代码,将技术人员添加到数据库中。必须执行3个sql insert语句。我有我的代码,但我的代码不符合或做的问题。这就是问题。
程序应该提示用户输入ssn。
如果ssn / employee已经在Employee表中,程序应通知用户该员工已经在DB中,并询问用户是否要更新该员工的union-membership号;如果用户的回答是肯定的,程序应该询问用户新的union-member-number并在DB中更新它。
如果ssn / employee不在DB中,程序应该询问用户该员工的union-membership号,然后将该记录存储在Employee表中。假设员工是技术人员,程序应该要求用户存储有关该技术人员的信息(姓名,地址和电话号码)并将其存储在技术人员表中;然后程序应该询问用户技术人员是专家的飞机型号,并将相应的记录添加到专家表中。
这是我的代码:
void add_technician() {
EXEC SQL BEGIN DECLARE SECTION;
char sn[9];
int s=0;
char answer;
int umn;
char tname[30];
char tadd[30];
char tpho[10];
char tmod[15];
EXEC SQL END DECLARE SECTION;
cout << "Enter social security number:";
cin >> sn;
EXEC SQL SELECT SSN into :s from Employee where SSN= :sn;
if (s == sn)
{
cout << "Employee already exists in the database.";
cout <<"Would you like to update the union-membership-number?";
cin >> answer;
if (answer == 'y'|| 'Y')
{cout <<"Enter new union member number:";
cin >> umn;
EXEC SQL
INSERT INTO Employee (ssn, union_member_no)
VALUES (:sn, :umn);
}
}
else {
cout << "Enter in union membership number of the new employee: ";
cin >> umn;
EXEC SQL INSERT INTO Employees (ssn, union_member_no)
VALUES (:sn, :umn);
EXEC SQL COMMIT WORK;
cout << "Enter the address of the technician.";
cin >> tadd;
cout << "Enter the name technician name.";
cin >> tname;
EXEC SQL INSERT INTO Technicians (address, name, phone)
VALUES (:tadd, :tname, :tpho);
EXEC SQL COMMIT WORK;
cout << "Enter airplane model number that you are an expert on." ;
cin >> tmod;
EXEC SQL INSERT INTO Experts (model_no, ssn)
VALUES (:tmod);
EXEC SQL COMMIT WORK; }
}
当我运行程序时,它会跳过前两个IF语句。我似乎无法理解为什么。
答案 0 :(得分:0)
您将值存储回s的方式不正确。
请查看一个好例子ESQL Programmer's guide
我会说你有一个MySQL方法来解决这个问题。相反,我会做这样的事情(粗略的方法):
int s = 0;
EXEC SQL SELECT rowSSN into :s from Employee where SSN= :sn;
if (s == sn)
...
s的值实际上是它自己的行的值。 考虑通过计算从查询返回的行数来查看CURSOR以获得一种方法。