esolve
V2EX  ›  问与答

mysql 的几个理解

  •  
  •   esolve · Apr 25, 2017 · 1822 views
    This topic created in 3316 days ago, the information mentioned may be changed or developed.

    我看一个 sql 数据库文件,如下

    DROP DATABASE IF EXISTS employees; CREATE DATABASE IF NOT EXISTS employees; USE employees;

    SELECT 'CREATING DATABASE STRUCTURE' as 'INFO';

    DROP TABLE IF EXISTS dept_emp, dept_manager, titles, salaries, employees, departments;

    set storage_engine = InnoDB; -- set storage_engine = MyISAM; -- set storage_engine = Falcon; -- set storage_engine = PBXT; -- set storage_engine = Maria;

    select CONCAT('storage engine: ', @@storage_engine) as INFO;

    有两个问题 1 这里的 SELECT 'CREATING DATABASE STRUCTURE' as 'INFO'; 和 select CONCAT('storage engine: ', @@storage_engine) as INFO; 是个什么语法?是定义变量 INFO ? 为何一个有''一个没有引号?

    2 这个 DROP TABLE 语句什么意思啊? drop 哪个 table ?

    4 replies    2017-04-26 00:49:36 +08:00
    billlee
        1
    billlee  
       Apr 25, 2017
    SELECT <字面值> AS <字段名>
    返回一行数据,只有一个字段 INFO, 值为字符串 CREATING DATABASE STRUCTURE
    字段名只要不和保留字冲突,可以不加引号
    billlee
        2
    billlee  
       Apr 25, 2017
    第二个 CONCAT 是个内置函数,这个和 SELET COUNT(*) 是一样的语法
    第三个就是把 dept_emp, dept_manager, titles, salaries, employees, departments 都 DROP 掉,这个应该 reference manual 写得很清楚吧
    esolve
        3
    esolve  
    OP
       Apr 25, 2017
    @billlee
    谢谢
    返回一行数据? 这个 INFO 是啥?变量?表的一项?用来做啥的? 为何有时候加‘’有时候不加
    ivvei
        4
    ivvei  
       Apr 26, 2017 via Android
    @esolve info 就是返回的结果集的字段别名。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5823 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 45ms · UTC 06:39 · PVG 14:39 · LAX 23:39 · JFK 02:39
    ♥ Do have faith in what you're doing.