mysql如何用一行命令在两个表中插入数据?
How to insert data in two tables with a single line of command in mysql?
首先,我看到了一些接近这个问题的答案,但是没有用。这就是为什么我创建了一个新问题,这里是规范:
我创建了两个 table:
CREATE TABLE car_info (
id int PRIMARY KEY AUTO_INCREMENT NOT NULL,
mileage int,
make varchar(100),
model varchar(100),
fuel varchar(100),
gear varchar(100),
offertype varchar(100)
);
CREATE TABLE sales_info (
id int PRIMARY KEY AUTO_INCREMENT NOT NULL,
FOREIGN KEY(id) REFERENCES car_info(id),
price int,
hp int,
year int
);
我加入了这两个:
select *
from (SELECT *
FROM car_info
) as a
left outer join (SELECT *
FROM sales_info
) as b on a.id = b.id
union
select *
from (SELECT *
FROM car_info
) as a
right outer join (SELECT *
FROM sales_info
) as b on a.id = b.id;
如您所见,id是这里的公共变量。在这里,是 car_info table:
+-----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+----------------+
| id | int | NO | PRI | NULL | auto_increment |
| mileage | int | YES | | NULL | |
| make | varchar(100) | YES | | NULL | |
| model | varchar(100) | YES | | NULL | |
| fuel | varchar(100) | YES | | NULL | |
| gear | varchar(100) | YES | | NULL | |
| offertype | varchar(100) | YES | | NULL | |
+-----------+--------------+------+-----+---------+----------------+
这里是 sales_info table:
+-------+------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------+------+-----+---------+----------------+
| id | int | NO | PRI | NULL | auto_increment |
| price | int | YES | | NULL | |
| hp | int | YES | | NULL | |
| year | int | YES | | NULL | |
+-------+------+------+-----+---------+----------------+
这里是我通常用来在单个 table:
中导入 SQL 数据的代码
app.post('/save', (req, res) => {
let data = { mileage: req.body.mileage, make: req.body.make, model: req.body.model, fuel: req.body.fuel, gear: req.body.gear, offertype: req.body.offertype };
let sql = "INSERT INTO car_info SET ?";
let query = connection.query(sql, data, (err, result) => {
if (err) throw err;
res.redirect('/');
});
});
当我使用此代码并从表单调用它时,它运行良好。但是,我想做的是,我想从一个表单中调用这段代码并将两个 tables 导入相关信息,如:
app.post('/save', (req, res) => {
let data = { mileage: req.body.mileage, make: req.body.make, model: req.body.model, fuel: req.body.fuel, gear: req.body.gear, offertype: req.body.offertype, price: req.body.price, hp: req.body.hp, year: req.body.year };
let sql = "**car_info and sales_info tables code here**";
let query = connection.query(sql, data, (err, result) => {
if (err) throw err;
res.redirect('/');
});
});
最后,我尝试了类似的方法:
let sql = `INSERT INTO car_info
(mileage, make, model, fuel, gear, offertype)
VALUES('${req.body.mileage}', '${req.body.make}',
'${req.body.model}', '${req.body.fuel}',
'${req.body.gear}', '${req.body.offertype}');
INSERT INTO sales_info
(price, hp, year)
VALUES('${req.body.price}', '${req.body.hp}',
'${req.body.year}');`
但这里的问题是,它只在 car_info 中插入数据,而不是在 sales_info 中,尽管我在相关字段中输入了一些值。
我希望问题很清楚,我怎样才能做到这一点?
由于你的两个表有不同的列,我建议你在两个不同的变量中创建两个查询,然后将从 req.body
收集的数据相应地插入到表中。
app.post('/save', (req, res) => {
const { milage, make, model, fuel, gear, offertype, price, hp, year } = req.body //Destructured object
const car_info_query = `INSERT into car_info VALUES (?,?,?,?,?,?)`
const sales_info_query = `INSERT into sales_info VALUES (?, ?, ?)`
let write_car_info = connection.query(car_info_query, [milage, make, model, fuel, gear, offertype] , (err, result) => {
if (err) throw err;
});
let write_sales_info = connection.query(sales_info_query, [price, hp, year], (err, result) => {
if (err) throw err
})
//Insert into as many tables as you want
res.redirect('/');
});
按照@jkalandarov 的回答,我解决了这个问题。这里的主要问题是 sales_info 的关系,其中 id 是外键。不过最后还是解决了:)
这是我的最终代码:
app.post('/save', (req, res) => {
let car_info_data = { mileage: req.body.mileage, make: req.body.make, model: req.body.model, fuel: req.body.fuel, gear: req.body.gear, offertype: req.body.offertype };
let sales_info_data = { price: req.body.price, hp: req.body.hp, year: req.body.year };
const car_info_query = 'INSERT into car_info SET ? ';
const sales_info_query = 'INSERT into sales_info SET ?';
let write_car_info = connection.query(car_info_query, car_info_data, (err, result) => {
if (err) throw err;
});
let write_sales_info = connection.query(sales_info_query, sales_info_data, (err, result) => {
if (err) throw err;
})
//Insert into as many tables as you want
res.redirect('/');
});
首先,我看到了一些接近这个问题的答案,但是没有用。这就是为什么我创建了一个新问题,这里是规范:
我创建了两个 table:
CREATE TABLE car_info (
id int PRIMARY KEY AUTO_INCREMENT NOT NULL,
mileage int,
make varchar(100),
model varchar(100),
fuel varchar(100),
gear varchar(100),
offertype varchar(100)
);
CREATE TABLE sales_info (
id int PRIMARY KEY AUTO_INCREMENT NOT NULL,
FOREIGN KEY(id) REFERENCES car_info(id),
price int,
hp int,
year int
);
我加入了这两个:
select *
from (SELECT *
FROM car_info
) as a
left outer join (SELECT *
FROM sales_info
) as b on a.id = b.id
union
select *
from (SELECT *
FROM car_info
) as a
right outer join (SELECT *
FROM sales_info
) as b on a.id = b.id;
如您所见,id是这里的公共变量。在这里,是 car_info table:
+-----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+----------------+
| id | int | NO | PRI | NULL | auto_increment |
| mileage | int | YES | | NULL | |
| make | varchar(100) | YES | | NULL | |
| model | varchar(100) | YES | | NULL | |
| fuel | varchar(100) | YES | | NULL | |
| gear | varchar(100) | YES | | NULL | |
| offertype | varchar(100) | YES | | NULL | |
+-----------+--------------+------+-----+---------+----------------+
这里是 sales_info table:
+-------+------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+------+------+-----+---------+----------------+
| id | int | NO | PRI | NULL | auto_increment |
| price | int | YES | | NULL | |
| hp | int | YES | | NULL | |
| year | int | YES | | NULL | |
+-------+------+------+-----+---------+----------------+
这里是我通常用来在单个 table:
中导入 SQL 数据的代码app.post('/save', (req, res) => {
let data = { mileage: req.body.mileage, make: req.body.make, model: req.body.model, fuel: req.body.fuel, gear: req.body.gear, offertype: req.body.offertype };
let sql = "INSERT INTO car_info SET ?";
let query = connection.query(sql, data, (err, result) => {
if (err) throw err;
res.redirect('/');
});
});
当我使用此代码并从表单调用它时,它运行良好。但是,我想做的是,我想从一个表单中调用这段代码并将两个 tables 导入相关信息,如:
app.post('/save', (req, res) => {
let data = { mileage: req.body.mileage, make: req.body.make, model: req.body.model, fuel: req.body.fuel, gear: req.body.gear, offertype: req.body.offertype, price: req.body.price, hp: req.body.hp, year: req.body.year };
let sql = "**car_info and sales_info tables code here**";
let query = connection.query(sql, data, (err, result) => {
if (err) throw err;
res.redirect('/');
});
});
最后,我尝试了类似的方法:
let sql = `INSERT INTO car_info
(mileage, make, model, fuel, gear, offertype)
VALUES('${req.body.mileage}', '${req.body.make}',
'${req.body.model}', '${req.body.fuel}',
'${req.body.gear}', '${req.body.offertype}');
INSERT INTO sales_info
(price, hp, year)
VALUES('${req.body.price}', '${req.body.hp}',
'${req.body.year}');`
但这里的问题是,它只在 car_info 中插入数据,而不是在 sales_info 中,尽管我在相关字段中输入了一些值。
我希望问题很清楚,我怎样才能做到这一点?
由于你的两个表有不同的列,我建议你在两个不同的变量中创建两个查询,然后将从 req.body
收集的数据相应地插入到表中。
app.post('/save', (req, res) => {
const { milage, make, model, fuel, gear, offertype, price, hp, year } = req.body //Destructured object
const car_info_query = `INSERT into car_info VALUES (?,?,?,?,?,?)`
const sales_info_query = `INSERT into sales_info VALUES (?, ?, ?)`
let write_car_info = connection.query(car_info_query, [milage, make, model, fuel, gear, offertype] , (err, result) => {
if (err) throw err;
});
let write_sales_info = connection.query(sales_info_query, [price, hp, year], (err, result) => {
if (err) throw err
})
//Insert into as many tables as you want
res.redirect('/');
});
按照@jkalandarov 的回答,我解决了这个问题。这里的主要问题是 sales_info 的关系,其中 id 是外键。不过最后还是解决了:)
这是我的最终代码:
app.post('/save', (req, res) => {
let car_info_data = { mileage: req.body.mileage, make: req.body.make, model: req.body.model, fuel: req.body.fuel, gear: req.body.gear, offertype: req.body.offertype };
let sales_info_data = { price: req.body.price, hp: req.body.hp, year: req.body.year };
const car_info_query = 'INSERT into car_info SET ? ';
const sales_info_query = 'INSERT into sales_info SET ?';
let write_car_info = connection.query(car_info_query, car_info_data, (err, result) => {
if (err) throw err;
});
let write_sales_info = connection.query(sales_info_query, sales_info_data, (err, result) => {
if (err) throw err;
})
//Insert into as many tables as you want
res.redirect('/');
});