现有关系数据库如下: 数据库名:我班同学数据库 同学表(学号 char(6),姓名,性别,年龄,民族,身份证号,宿舍号) 宿舍表(宿舍号 char(6),宿舍电话) 用SQL语言实现下列功能的sql语句代码:*/ --1.创建数据库[我班同学数据库]代码。 --2.创建数据表[宿舍表]代码; --宿舍表(宿舍号 char(6),宿舍电话) --要求使用:主键(宿舍号)、宿舍电话:以633开头的7位电话号码 --3.创建数据表[同学表]代码; --同学表(学号 char(6),姓
时间: 2024-02-11 20:08:27 浏览: 164
/* 1.创建数据库[我班同学数据库]代码。*/
CREATE DATABASE 我班同学数据库;
/* 2.创建数据表[宿舍表]代码; */
CREATE TABLE 宿舍表 (
宿舍号 char(6) PRIMARY KEY,
宿舍电话 char(7) CHECK (宿舍电话 LIKE '633%')
);
/* 3.创建数据表[同学表]代码; */
CREATE TABLE 同学表 (
学号 char(6) PRIMARY KEY,
姓名 varchar(20) NOT NULL,
性别 char(2) CHECK (性别 IN ('男', '女')),
年龄 tinyint CHECK (年龄 >= 0),
民族 varchar(20),
身份证号 char(18),
宿舍号 char(6) REFERENCES 宿舍表(宿舍号)
);
```
解释一下上述SQL语句:
1. 第一条SQL语句用于创建数据库,数据库名为“我班同学数据库”;
2. 第二条SQL语句用于创建数据表“宿舍表”,包含两个字段:宿舍号和宿舍电话。宿舍号作为主键,宿舍电话必须以“633”开头,且长度为7位;
3. 第三条SQL语句用于创建数据表“同学表”,包含七个字段:学号、姓名、性别、年龄、民族、身份证号和宿舍号。学号作为主键,宿舍号作为外键参照宿舍表的宿舍号字段。其中,性别字段只能是“男”或“女”,年龄字段必须大于等于0。
相关问题
数据库名:我班同学数据库 同学表(学号 char(6),姓名,性别,年龄,民族,身份证号,宿舍号) 宿舍表(宿舍号 char(6),宿舍电话) 用SQL语言实现下列功能的sql语句代码:*/ --1.创建数据库[我班同学数据库]代码。
首先,我们需要创建数据库。在MySQL中,你可以使用`CREATE DATABASE`语句来完成这个任务,如果数据库不存在的话。以下是创建名为"我班同学数据库"的SQL语句:
```sql
CREATE DATABASE IF NOT EXISTS 我班同学数据库;
```
接下来,我们分别创建`同学表`和`宿舍表`。假设它们是在新的数据库中创建的,可以分别使用以下语句:
**创建同学表:**
```sql
USE 我班同学数据库; -- 切换到新创建的数据库
CREATE TABLE 同学 (
学号 CHAR(6) PRIMARY KEY,
姓名 VARCHAR(50),
性别 ENUM('男', '女'),
年龄 INT,
民族 VARCHAR(20),
身份证号 CHAR(18),
宿舍号 CHAR(6)
);
```
**创建宿舍表:**
```sql
CREATE TABLE 宿舍 (
宿舍号 CHAR(6) PRIMARY KEY,
宿舍电话 VARCHAR(20)
);
```
至于查询相关的功能,比如添加、更新、删除数据,或者关联查询等,需要具体的操作指令,例如插入一条同学信息:
```sql
INSERT INTO 同学 (学号, 姓名, 性别, 年龄, 民族, 身份证号, 宿舍号)
VALUES ('20220101', '张三', '男', 20, '汉族', '123456789012345678', 'A01');
```
数据库名: student 同学表(学号 char (6),姓名,性别,年龄,民族,身份证号,宿舍号) 宿舍表(宿舍号 char (6),宿舍电话) 用 SQL 语言实现下列功能的 sql 语句代
数据库名 `student` 包含了两个相关的表:
1. **同学表** (`students`):
- 字段:学号(`stu_id`, char(6)),姓名(`name`),性别(`gender`),年龄(`age`),民族(`nationality`),身份证号(`id_number`),宿舍号(`dormitory_no`)。
2. **宿舍表** (`dormitories`):
- 字段:宿舍号(`dormitory_no`, char(6)),宿舍电话(`phone_number`)。
下面是一些基本的 SQL 操作示例,包括创建表、插入数据、查询等:
### 创建表
```sql
CREATE TABLE students (
stu_id CHAR(6) PRIMARY KEY,
name VARCHAR(50),
gender CHAR(1),
age INT,
nationality VARCHAR(20),
id_number VARCHAR(20),
dormitory_no CHAR(6)
);
CREATE TABLE dormitories (
dormitory_no CHAR(6) PRIMARY KEY,
phone_number VARCHAR(15)
);
```
### 插入数据
```sql
INSERT INTO students(stu_id, name, gender, age, nationality, id_number, dormitory_no)
VALUES('202201', '张三', 'M', 20, '汉', '123456789012345678', 'A01');
INSERT INTO dormitories(dormitory_no, phone_number)
VALUES('A01', '010-12345678');
```
### 查询关联数据
- 查询特定学生信息及其宿舍电话:
```sql
SELECT students.name, dormitories.phone_number
FROM students
JOIN dormitories ON students.dormitory_no = dormitories.dormitory_no
WHERE students.stu_id = '202201';
```
- 获取所有宿舍的信息及该宿舍的学生信息:
```sql
SELECT s.*, d.phone_number
FROM students s
JOIN dormitories d ON s.dormitory_no = d.dormitory_no;
```
阅读全文