创建一个数据库宿舍表(宿舍号 char(6),宿舍电话)要求使用主键(宿舍号)宿舍电话:以633开头的7位电话号码
时间: 2024-04-10 07:33:14 浏览: 5
好的,以下是创建宿舍表的SQL语句:
```sql
CREATE TABLE 宿舍 (
宿舍号 CHAR(6) PRIMARY KEY,
宿舍电话 CHAR(7) CHECK (宿舍电话 LIKE '633%')
);
```
这个SQL语句创建了一个名为"宿舍"的表,包含两个字段:宿舍号和宿舍电话。宿舍号被定义为主键,确保唯一性和索引性能。宿舍电话被限制为以"633"开头的7位电话号码,使用CHECK约束来实现。
相关问题
现有关系数据库如下: 数据库名:我班同学数据库 同学表(学号 char(6),姓名,性别,年龄,民族,身份证号,宿舍号) 宿舍表(宿舍号 char(6),宿舍电话) 用SQL语言实现下列功能的sql语句代码:*/ --1.创建数据库[我班同学数据库]代码。 --2.创建数据表[宿舍表]代码; --宿舍表(宿舍号 char(6),宿舍电话) --要求使用:主键(宿舍号)、宿舍电话:以633开头的7位电话号码 --3.创建数据表[同学表]代码; --同学表(学号 char(6),姓
/* 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。
使用c语言编写一个学生宿舍管理系统,且包含折半查找和线性查找
下面是一个简单的学生宿舍管理系统的 C 语言代码示例,包含了折半查找和线性查找两种查找方式。该系统可以实现添加、删除、查找和修改学生信息等基本功能。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENT_NUM 100 // 最大学生数
#define MAX_NAME_LEN 20 // 最大姓名长度
#define MAX_ROOM_NUM 5 // 最大房间数
#define MAX_BED_NUM 4 // 最大床位数
// 学生信息结构体
typedef struct {
char name[MAX_NAME_LEN];
int room_num;
int bed_num;
} Student;
// 学生数组和学生数
Student students[MAX_STUDENT_NUM];
int student_num = 0;
// 折半查找函数
int binary_search(char name[]) {
int left = 0, right = student_num - 1;
while (left <= right) {
int mid = (left + right) / 2;
if (strcmp(students[mid].name, name) == 0) {
return mid;
} else if (strcmp(students[mid].name, name) < 0) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1;
}
// 线性查找函数
int linear_search(char name[]) {
for (int i = 0; i < student_num; i++) {
if (strcmp(students[i].name, name) == 0) {
return i;
}
}
return -1;
}
// 添加学生信息函数
void add_student() {
if (student_num >= MAX_STUDENT_NUM) {
printf("学生数已达上限\n");
return;
}
printf("请输入学生姓名:");
scanf("%s", students[student_num].name);
printf("请输入房间号(1-%d):", MAX_ROOM_NUM);
scanf("%d", &students[student_num].room_num);
printf("请输入床位号(1-%d):", MAX_BED_NUM);
scanf("%d", &students[student_num].bed_num);
student_num++;
printf("学生信息添加成功\n");
}
// 删除学生信息函数
void delete_student() {
char name[MAX_NAME_LEN];
printf("请输入要删除的学生姓名:");
scanf("%s", name);
int index = binary_search(name);
if (index == -1) {
printf("未找到该学生\n");
} else {
for (int i = index; i < student_num - 1; i++) {
students[i] = students[i + 1];
}
student_num--;
printf("学生信息删除成功\n");
}
}
// 查找学生信息函数
void find_student() {
char name[MAX_NAME_LEN];
printf("请输入要查找的学生姓名:");
scanf("%s", name);
int index = binary_search(name);
if (index == -1) {
printf("未找到该学生\n");
} else {
printf("姓名:%s,房间号:%d,床位号:%d\n", students[index].name,
students[index].room_num, students[index].bed_num);
}
}
// 修改学生信息函数
void modify_student() {
char name[MAX_NAME_LEN];
printf("请输入要修改的学生姓名:");
scanf("%s", name);
int index = binary_search(name);
if (index == -1) {
printf("未找到该学生\n");
} else {
printf("请输入新的房间号(1-%d):", MAX_ROOM_NUM);
scanf("%d", &students[index].room_num);
printf("请输入新的床位号(1-%d):", MAX_BED_NUM);
scanf("%d", &students[index].bed_num);
printf("学生信息修改成功\n");
}
}
// 显示所有学生信息函数
void display_all_students() {
printf("所有学生信息如下:\n");
for (int i = 0; i < student_num; i++) {
printf("姓名:%s,房间号:%d,床位号:%d\n", students[i].name,
students[i].room_num, students[i].bed_num);
}
}
// 主函数
int main() {
int choice;
while (1) {
printf("\n");
printf("1. 添加学生信息\n");
printf("2. 删除学生信息\n");
printf("3. 查找学生信息\n");
printf("4. 修改学生信息\n");
printf("5. 显示所有学生信息\n");
printf("6. 退出系统\n");
printf("请输入你的选择(1-6):");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
delete_student();
break;
case 3:
find_student();
break;
case 4:
modify_student();
break;
case 5:
display_all_students();
break;
case 6:
exit(0);
default:
printf("输入有误,请重新输入\n");
break;
}
}
return 0;
}
```
该程序使用折半查找和线性查找两种方式实现了学生信息的查找功能。用户可以选择添加、删除、查找和修改学生信息等操作,也可以显示所有学生信息。该程序中还使用了结构体、数组和循环等基本语法,是一个适合初学者练习的项目。