gpt4 book ai didi

sql - SQLite创建表AS,但重命名列并保留原始数据类型,键?

转载 作者:行者123 更新时间:2023-12-03 17:56:39 25 4
gpt4 key购买 nike

SQLite目标

我想从一个联接(或一系列联接/子查询)创建一个新表。我希望新表保留原始表中的数据类型以及唯一索引。

另外,我想在此过程中重命名某些列。为了在SQLite中做到这一点,我觉得我需要执行以下步骤:



创建联接表作为临时表
用所需的列名称,数据类型和索引创建一个空的新表
将临时表插入新表。



问题:是否有更好或更简洁的方法来完成此任务?

以上过程的代码示例:

--create joined table as tmp
DROP TABLE if exists tmp;

CREATE TABLE tmp AS
SELECT
individual_contributions.cmte_id,
cmte_pty_affiliation,
name,
employer,
transaction_dt,
transaction_amt,
file_num,
cand_id,
sub_id
FROM individual_contributions LEFT JOIN committee_master
ON individual_contributions.cmte_id=committee_master.cmte_id
WHERE employer LIKE "Goldman Sachs"
GROUP BY sub_id;


--create new table with desired specs
DROP TABLE if exists cm_indiv;

CREATE TABLE cm_indiv (
cmte_id TEXT NOT NULL,
cmte_pty_affiliation TEXT,
contributor_name TEXT,
contributor_employer TEXT,
contributor_transaction_dt TEXT,
cand_id TEXT,
transaction_amt TEXT,
file_num NUMERIC,
sub_id NUMERIC NOT NULL
);

CREATE UNIQUE INDEX idx_cm_indiv ON cm_indiv (sub_id);


--insert joined table into new table
INSERT INTO cm_indiv (
cmte_id,
cmte_pty_affiliation,
contributor_name,
contributor_employer,
contributor_transaction_dt,
cand_id,
transaction_amt,
file_num,
sub_id
)
SELECT
cmte_id,
cmte_pty_affiliation,
name,
employer,
transaction_dt,
cand_id,
transaction_amt,
file_num,
sub_id
FROM tmp;

最佳答案

此CTAS使用SQL Fiddle(SQLite-WebSQL)为我工作。因此,在创建表时,请在如下所示的select语句中使用首选的列名。

create table tbl( id int);

insert into tbl values (1);

create table new_tbl
as
select id as new_id
from tbl;

select new_id from new_tbl;

Result:
new_id
1

关于sql - SQLite创建表AS,但重命名列并保留原始数据类型,键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49076009/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com