V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
qiyue0726
V2EX  ›  程序员

[SQL] 请问怎么查除某字段外其他字段

  •  
  •   qiyue0726 ·
    qiyue0726 · 2020-12-11 10:16:05 +08:00 · 2066 次点击
    这是一个创建于 1443 天前的主题,其中的信息可能已经有所发展或是发生改变。
    比如一张表有超多字段,但是需要的字段是其中的大部分,又不想一个一个字段手动敲出来,能不能查除了那些不需要的字段外其它全部字段
    6 条回复    2020-12-11 18:23:49 +08:00
    l00t
        1
    l00t  
       2020-12-11 10:28:35 +08:00
    不能。SQL 没这功能。建议用代码生成 SQL 的方式来实现少敲点字段的目的。
    Cbdy
        2
    Cbdy  
       2020-12-11 10:48:12 +08:00   ❤️ 2
    能,不过如果要用 SQL 实现,不同数据库可能不太一样,我举个 MySQL 的例子

    SELECT GROUP_CONCAT(col.COLUMN_NAME)
    FROM information_schema.COLUMNS col
    WHERE col.TABLE_SCHEMA = 'test'
    AND col.TABLE_NAME = 'user'
    AND COLUMN_NAME NOT IN ('created_at', 'updated_at')
    INTO @cols;

    SET @s = CONCAT('SELECT ', @cols, ' FROM test.user');

    PREPARE stmt FROM @s;
    EXECUTE stmt;
    chaffy
        3
    chaffy  
       2020-12-11 11:28:01 +08:00
    应该都有相应的系统表吧
    goodboy95
        4
    goodboy95  
       2020-12-11 11:57:38 +08:00
    这种时候我一般都直接 select *了,然后把不能提供出去的字段删了
    GroupF
        5
    GroupF  
       2020-12-11 15:43:58 +08:00
    我是从 Table info 中复制出表结构,拉进去 sublime 里面,alt 选取多行处理。。
    zhuweiyou
        6
    zhuweiyou  
       2020-12-11 18:23:49 +08:00
    我一般都是 先全部查出来 再把不要的干掉
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   914 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 21:44 · PVG 05:44 · LAX 13:44 · JFK 16:44
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.