基础
# 每一列都要指定对应的类型
# 字符串:varchar(N)
# 整数:int
# 小数:double
# 年月日:date
# 年月日时分秒:datetime
# 创建表
create table if not exists db_bigdata.student(
stuid varchar(10),
stuname varchar(10),
age int,
sex varchar(2),
email VARCHAR(100)
);
# 列举表
use db_bigdata;
show tables ;
# 描述表
desc db_bigdata.student;
# 删除表
drop table if exists db_bigdata.student;
# 修改列的数据类型
ALTER TABLE db_bigdata.student modify stuname VARCHAR(50);
# 修改列的字符集
ALTER TABLE db_bigdata.student MODIFY stuname VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
# 修改列的约束
ALTER TABLE db_bigdata.student MODIFY age INT NOT NULL;
# 综合示例
ALTER TABLE db_bigdata.student
MODIFY stuname VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci,
MODIFY age INT NOT NULL,
MODIFY email VARCHAR(100) UNIQUE NOT NULL;
进阶
# 进阶
CREATE TABLE if not exists db_bigdata.student (
student_id INT AUTO_INCREMENT PRIMARY KEY, -- 学生ID,自动递增
first_name VARCHAR(50) NOT NULL, -- 名
last_name VARCHAR(50) NOT NULL, -- 姓
gender VARCHAR(10), -- 性别
birth_date DATE, -- 出生日期
enrollment_date DATE NOT NULL, -- 入学日期
email VARCHAR(100), -- 邮箱
phone_number VARCHAR(20), -- 电话号码
address VARCHAR(255), -- 地址
city VARCHAR(100), -- 城市
state VARCHAR(100), -- 州/省
zip_code VARCHAR(20), -- 邮编
country VARCHAR(100), -- 国家
major VARCHAR(100), -- 主修专业
gpa DOUBLE, -- 平均成绩点数
credits_completed INT, -- 已修学分
advisor_id INT, -- 导师ID
emergency_contact_name VARCHAR(100), -- 紧急联系人姓名
emergency_contact_phone VARCHAR(20), -- 紧急联系人电话
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, -- 创建时间
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP -- 更新时间
);
# 列说明
# student_id: 学生ID,主键,自动递增。
# first_name: 学生的名字,非空。
# last_name: 学生的姓氏,非空。
# gender: 学生的性别,可以为空。
# birth_date: 学生的出生日期。
# enrollment_date: 学生的入学日期,非空。
# email: 学生的邮箱地址。
# phone_number: 学生的电话号码。
# address: 学生的住址。
# city: 学生所在的城市。
# state: 学生所在的州或省。
# zip_code: 学生的邮编。
# country: 学生所在的国家。
# major: 学生的主修专业。
# gpa: 学生的平均成绩点数。
# credits_completed: 学生已修的学分。
# advisor_id: 学生导师的ID。
# emergency_contact_name: 紧急联系人的姓名。
# emergency_contact_phone: 紧急联系人的电话号码。
# created_at: 记录的创建时间,默认当前时间戳。
# updated_at: 记录的更新时间,默认当前时间戳并在每次更新时自动更新。