一、操作库
-- 创建库
create database db1;
-- 创建库是否存在,不存在则创建
create database if not exists db1;
-- 创建数据库,指定编码,指定排序方式
create database if not exists db_BigData
default character set utf8mb4
default collate utf8mb4_danish_ci;
-- 查看所有数据库
show databases;
-- 查看当前在哪个数据库当中
select database();
-- 切换数据库
use db_test01;
-- 查看某个数据库的定义信息
show create database db1;
-- 修改数据库字符信息
alter database db1 character set utf8;
-- 删除数据库
drop database db1;
二、操作表
# 每一列都要指定对应的类型
# 字符串:varchar(N)
# 整数:int
# 小数:double
# 年月日:date
# 年月日时分秒:datetime
--创建表
create table student(
id int,
name varchar(32),
age int ,
score double(4,1),
birthday date,
insert_time timestamp
);
-- 列举表
use db_bigdata;
show tables ;
-- 查看表结构
desc 表名;
-- 查看创建表的SQL语句
show create table 表名;
-- 修改表名
alter table 表名 rename to 新的表名;
-- 添加一列
alter table 表名 add 列名 数据类型;
-- 修改列的数据类型
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;
-- 删除列
alter table 表名 drop 列名;
-- 删除表
drop table 表名;
drop table if exists 表名 ;
给一张复杂一点的表
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: 记录的更新时间,默认当前时间戳并在每次更新时自动更新。
1293

被折叠的 条评论
为什么被折叠?



