欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL向表中添加列方法實(shí)例

 更新時(shí)間:2023年06月05日 14:17:45   作者:okokabcd  
要在MySQL的表中添加列,我們可以將ALTER命令與add column命令一起使用,下面這篇文章主要給大家介紹了關(guān)于MySQL向表中添加列的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

我們使用alter table add column語句向現(xiàn)有表中添加新列。

簡介

alter table table_name
add [column] column_name column_definition [first|after existing_column];

說明:

  • alter table子句后指定表名;
  • column關(guān)鍵字是可選的,可以省略它;
  • 可以通過first關(guān)鍵字將新列添加為表的第一列,也可以使用after existing_column子句在現(xiàn)有列之后添加新列,如果沒有明確指定會將其添加為最后一列;

若要向表中添加兩個(gè)或更多列,使用下面語法:

alter table table_name
add [column] column_name column_definition [first|after existing_column],
add [column] column_name column_definition [first|after existing_column],
...;

舉例

創(chuàng)建一個(gè)表

create database test;
use test;

create table if not exists vendor (
	id int auto_increment primary key,
  name varchar(255)
);

添加新列并指定位置

alter table vendor
add column phone varchar(15) after name;

添加新列但不指定新列位置

alter table vendor
add column vendor_group int not null;

插入記錄

insert into vendor(name, phone, vendor_group)
values('IBM', '(408)-298-2987', 1);
insert into vendor(name, phone, vendor_group)
values('Microsoft', '(408)-298-2988', 1);

同時(shí)添加兩列

alter table vendor
add column email varchar(100) not null,
add column hourly_rate decimal(10, 2) not null;

注意:email和hourly_rate兩列都是not null,但是vendor表已經(jīng)有數(shù)據(jù)了,在這種情況下,MySQL將使用這些新列的默認(rèn)值。

檢查vendor表中的數(shù)據(jù)

select id, name, phone, vendor_group, email, hourly_rate
from vendor;

查詢結(jié)果:

+----+-----------+----------------+--------------+-------+-------------+
| id | name      | phone          | vendor_group | email | hourly_rate |
+----+-----------+----------------+--------------+-------+-------------+
|  1 | IBM       | (408)-298-2987 |            1 |       |        0.00 |
|  2 | Microsoft | (408)-298-2988 |            1 |       |        0.00 |
+----+-----------+----------------+--------------+-------+-------------+
2 rows in set (0.00 sec)

email列中填充了空值,而不是NULL值,hourly_rate列填充了0.00

添加表中已存在的列

MySQL將發(fā)生錯(cuò)誤

alter table vendor
add column vendor_group int not null;

操作結(jié)果:

ERROR 1060 (42S21): Duplicate column name 'vendor_group'

檢查表中是否已存在列

對于幾列的表,很容易看到哪些列已經(jīng)存在,如果有一個(gè)飲食數(shù)百列的大表,那就比較費(fèi)勁了

select if(count(*) = 1, 'Exist', 'Not Exist') as result
from information_schema.columns
where table_schema = 'test'
	and table_name = 'vendor'
	and column_name = 'phone';

查詢結(jié)果:

+--------+
| result |
+--------+
| Exist  |
+--------+
1 row in set (0.00 sec)

在where子句中,我們傳遞了三個(gè)參數(shù):表模式或數(shù)據(jù)庫,表名和列名。我們使用if函數(shù)來返回列是否存在。

在表中已有字段后添加列名

alter table 表名 add column 列名 類型 after 已有列名 comment '注釋信息';
alter table students add column class varchar(40) after student_name   comment '學(xué)生班級';

刪除列

alter table 表名 drop column 列名;
alter table students drop column grade;

參考

https://www.begtut.com/mysql/mysql-add-column.html

總結(jié)

到此這篇關(guān)于MySQL向表中添加列的文章就介紹到這了,更多相關(guān)MySQL表中添加列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL8.0報(bào)錯(cuò)Public?Key?Retrieval?is?not?allowed的原因及解決方法

    MySQL8.0報(bào)錯(cuò)Public?Key?Retrieval?is?not?allowed的原因及解決方法

    這篇文章主要給大家介紹了MySQL8.0報(bào)錯(cuò)Public?Key?Retrieval?is?not?allowed的原因及解決方法,文中通過代碼示例和圖文介紹的非常詳細(xì),有遇到相同問題的朋友可以參考閱讀一下
    2024-01-01
  • 深度分析mysql GROUP BY 與 ORDER BY

    深度分析mysql GROUP BY 與 ORDER BY

    鑒于項(xiàng)目的需要,就從網(wǎng)上找到該文章,文章分析得很詳細(xì)也很易懂,在android里,(不知道是不是現(xiàn)在水平的限制,總之我還沒找到在用ContentProvider時(shí)可以使用子查詢),主要方法是用SQLiteDatabase 的 rawQuery,直接運(yùn)行sql語句就可以了。
    2014-06-06
  • mysql error 1130 hy000:Host''localhost''解決方案

    mysql error 1130 hy000:Host''localhost''解決方案

    本文將詳細(xì)提供mysql error 1130 hy000:Host'localhost'解決方案,需要的朋友可以參考下
    2012-11-11
  • MYSQL的主從復(fù)制知識點(diǎn)整理

    MYSQL的主從復(fù)制知識點(diǎn)整理

    在本篇文章里小編給大家整理的是一篇關(guān)于MYSQL主從復(fù)制的相關(guān)知識點(diǎn)內(nèi)容,有需要的朋友們參考學(xué)習(xí)下。
    2019-11-11
  • MySQL對JSON類型字段數(shù)據(jù)進(jìn)行提取和查詢的實(shí)現(xiàn)

    MySQL對JSON類型字段數(shù)據(jù)進(jìn)行提取和查詢的實(shí)現(xiàn)

    本文主要介紹了MySQL對JSON類型字段數(shù)據(jù)進(jìn)行提取和查詢的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • MySQL數(shù)據(jù)庫設(shè)計(jì)之利用Python操作Schema方法詳解

    MySQL數(shù)據(jù)庫設(shè)計(jì)之利用Python操作Schema方法詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫設(shè)計(jì)之利用Python操作Schema方法詳解,還是比較不錯(cuò)的,這里分享給大家,供需要的朋友參考。
    2017-11-11
  • 親手教你怎樣創(chuàng)建一個(gè)簡單的mysql數(shù)據(jù)庫

    親手教你怎樣創(chuàng)建一個(gè)簡單的mysql數(shù)據(jù)庫

    數(shù)據(jù)庫是存放數(shù)據(jù)的“倉庫”,維基百科對此形象地描述為“電子化文件柜”,這篇文章主要介紹了親手教你怎樣創(chuàng)建一個(gè)簡單的mysql數(shù)據(jù)庫,需要的朋友可以參考下
    2022-11-11
  • MySQL學(xué)習(xí)第二天 安裝和配置mysql winx64

    MySQL學(xué)習(xí)第二天 安裝和配置mysql winx64

    MySQL學(xué)習(xí)第二天,主要為大家詳細(xì)介紹了在Windows 64位操作系統(tǒng)下安裝和配置MySQL的具體步驟,整理一份mysql winx64安裝配置方法教程,感興趣的小伙伴們可以參考一下
    2016-05-05
  • mysql分表之后如何平滑上線詳解

    mysql分表之后如何平滑上線詳解

    項(xiàng)目開發(fā)中,我們的數(shù)據(jù)庫數(shù)據(jù)越來越大,隨之而來的是單個(gè)表中數(shù)據(jù)太多,以至于查詢書讀變慢,當(dāng)出現(xiàn)這種情況時(shí),我們可以考慮分表,這篇文章主要給大家介紹了關(guān)于mysql分表之后如何平滑上線的相關(guān)資料,需要的朋友可以參考下
    2021-10-10
  • MySQL存儲引擎中MyISAM和InnoDB區(qū)別詳解

    MySQL存儲引擎中MyISAM和InnoDB區(qū)別詳解

    存儲引擎說白了就是如何存儲數(shù)據(jù)、如何為存儲的數(shù)據(jù)建立索引和如何更新、查詢數(shù)據(jù)等技術(shù)的實(shí)現(xiàn)方法。因?yàn)樵陉P(guān)系數(shù)據(jù)庫中數(shù)據(jù)的存儲是以表的形式存儲的,所以存儲引擎也可以稱為表類型(即存儲和操作此表的類型)
    2016-12-12

最新評論