数据库基础语法二

发布于:2024-05-11 ⋅ 阅读:(49) ⋅ 点赞:(0)

一、数据库
1、登陆数据库
2、创建数据库zoo
3、修改数据库zoo字符集为gbk
4、选择当前数据库为zoo
5、查看创建数据库zoo信息
6、删除数据库zoo

mysql -uroot -p       #登陆数据库
create database zoo;  #创建数据库zoo
alter database zoo character set gbk collate gbk_chines
e_ci;                 #修改数据库zoo字符集为gbk
use zoo;              #选择当前数据库为zoo


#查看创建数据库zoo信息
mysql> show create database zoo;
+----------+------------------------------------------------------------------------------------------------+
| Database | Create Database
                                              |
+----------+------------------------------------------------------------------------------------------------+
| zoo      | CREATE DATABASE `zoo` /*!40100 DEFAULT CHARACTER SET gbk */ /*!80016 DEFAULT ENCRYPTION='N' */ |
+----------+------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

drop database zoo;   #删除数据库zoo

二、创建表
1、创建一个名称为db_system的数据库

#创建名为db_system的数据库
mysql> create database db_system;
mysql> use db_system;

2、在该数据库下创建两张表,具体要求如下
员工表 user
字段 类型 约束 备注
id 整形 主键,自增长 id
NAME 字符型 非空 姓名
gender 字符 非空 性别
birthday 日期型 生日
entry_date 日期型 非空 入职时间
job 字符型 非空 职位

-- 切换到db_system数据库  
USE db_system;  
  
-- 创建员工表 user 
mysql> CREATE TABLE user (
    -> id INT AUTO_INCREMENT PRIMARY KEY,
    -> NAME VARCHAR(255) NOT NULL COMMENT '姓名',
    -> gender CHAR(1) NOT NULL COMMENT '性别',
    -> birthday DATE COMMENT '生日',
    -> entry_date DATE NOT NULL COMMENT '入职时间',
    -> job VARCHAR(255) NOT NULL COMMENT '职位'
    -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

员工绩效表 salary
字段 类型 约束 备注
id 整形 主键,自增长 id
userId 字符型 非空,外键,关联的是user表的id字段 用户id
baseSalary 小数 非空 基本工资
month 整数 非空 月份
allowances 小数 非空,默认为0 补贴

-- 创建员工绩效表 salary
mysql> CREATE TABLE salary (
    -> id INT AUTO_INCREMENT PRIMARY KEY,
    -> userId INT NOT NULL COMMENT '用户id',
    -> baseSalary DECIMAL(10, 2) NOT NULL COMMENT '基本工资',
    -> onth INT NOT NULL COMMENT '月份',
    -> allowances DECIMAL(10, 2) NOT NULL DEFAULT 0 COMMENT '补贴',
    -> FOREIGN KEY (userId) REFERENCES user(id) ON DELETE CASCADE ON UPDATE CASCADE
    -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

三、修改表
1、在上面员工表的基本上增加一个image列,类型是blob,长度255。

ALTER TABLE user ADD image BLOB COMMENT '员工图片';

2、修改job列,使其长度为60。

ALTER TABLE user MODIFY job VARCHAR(60) NOT NULL COMMENT '职位';

3、删除gender列。

ALTER TABLE user DROP COLUMN gender;

4、表名salary改为usersalary。

RENAME TABLE salary TO usersalary;

5、修改表的字符集为utf8;

ALTER TABLE user CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;

6、列名name修改为username

ALTER TABLE user CHANGE NAME username VARCHAR(255) NOT NULL COMMENT '用户名';