
1.增加一个字段
alter
table
user
add
COLUMN
new1
VARCHAR(20)
DEFAULT
NULL
//增加一个字段,默认为空
alter
table
user
add
COLUMN
new2
VARCHAR(20)
NOT
NULL
//增加一个字段,默认不能为空
2.删除一个字段
alter
table
user
DROP
COLUMN
new2
//删除一个字段
3.修改一个字段
alter
table
user
MODIFY
new1
VARCHAR(10)
//修改一个字段的类型
alter
table
user
CHANGE
new1
new4
int
//修改一个字段的名称,此时一定要重新
//主键
alter
table
tabelname
add
new_field_id
int(5)
unsigned
default
0
not
null
auto_increment
,add
primary
key
(new_field_id)
//增加一个新列
alter
table
t2
add
d
timestamp
alter
table
infos
add
ex
tinyint
not
null
default
‘0′
//删除列
alter
table
t2
drop
column
c
//重命名列
alter
table
t1
change
a
b
integer
//改变列的类型
alter
table
t1
change
b
b
bigint
not
null
alter
table
infos
change
list
list
tinyint
not
null
default
‘0′
//重命名表
alter
table
t1
rename
t2
加索引
mysql>
alter
table
tablename
change
depno
depno
int(5)
not
null
mysql>
alter
table
tablename
add
index
索引名
(字段名1[,字段名2
…])
mysql>
alter
table
tablename
add
index
emp_name
(name)
加主关键字的索引
mysql>
alter
table
tablename
add
primary
key(id)
加唯一限制条件的索引
mysql>
alter
table
tablename
add
unique
emp_name2(cardnumber)
删除某个索引
mysql>alter
table
tablename
drop
index
emp_name
增加字段:
mysql>
ALTER
TABLE
table_name
ADD
field_name
field_type
修改原字段名称及类型:
mysql>
ALTER
TABLE
table_name
CHANGE
old_field_name
new_field_name
field_type
删除字段:
mysql>
ALTER
TABLE
table_name
DROP
field_name
mysql修改字段长度
alter
table
表名
modify
column
字段名
类型
例如
数据库中user表
name字段是varchar(30)
可以用
alter
table
user
modify
column
name
varchar(50)
1,主键约束 (table的唯一标识)
能够作为主键列的特点:该列不能为空,不能有重复值出现
创建表时指定主键的两种方式:
CREATE TABLE stu(
sid CHAR(6) PRIMATY KEY,
sname VARCHAR(20),
age INT,
gender VARCHER(10)
);
指定sid列为主键列
CREATE TABLE stu(
sid CHAR(6),
sname VARCHAR(20),
age INT,
gender VARCHER(10),
PRIMARY KEY(sid)
);
指定sid列为主键列
修改表时指定主键:ALTER TABLE stu ADD PRIMATY KEY(sid);
删除主键:ALTER TABLE stu DROP PRIMARY KEY;
2,主键自增长
因为主键列的特性是:必须唯一,不能为空,所以我们通常会指定主键为整形,然后设置其自动增长
创建表时指定主键自增长:
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20),
age INT,
gender VARCHAR(10)
);
修改表时设置主键自增长:ALTER TABLE stu
3,非空约束
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20) NOT NULL,
age INT,
gender VARCHAR(10)
);
对sname列设置了非空约束
4,唯一约束
某些列不能设置重复的值,所以可以对列添加唯一约束
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20) NOT NULL UNIQUE,
age INT,
gender VARCHAR(10)
);
6,外键约束
外键特点:外键必须是另一个表的主键的值(外键要引用主键!),外键可以重复,外键可以为空,一张表可以有多个外键!
CREATE TABLE dept( //部门表
deptno INT PRIMARY KEY AUTO_INCREMENT,
deptname CHAR(20)
);
INSERT INTO dept VALUES(10,‘研发部’);
INSERT INTO dept VALUES(20,‘人力部’);
INSERT INTO dept VALUES(30,‘财务部’);
CREATE TABLE emp( //员工表
empno INT PRIMARY KEY AUTO_INCREMENT,
ename VARCHAR(50),
dno INT, //员工所属部门(外键),
CONSTRAINT fk_emp_dept FOREIGN KEY(dno) REFERENCES dept(deptno)
);
INSERT INTO emp(empno,ename) VALUES(NULL,‘张三’),//外键可以不传入值
INSERT INTO emp(empno,ename) VALUES(NULL,‘李四’,10),//外键可以重复
INSERT INTO emp(empno,ename) VALUES(NULL,‘王五’,10),
INSERT INTO emp(empno,ename) VALUES(NULL,‘赵六’,80),//dept表没有主键值为80的记录,sql客户端编译报错
7,一对一关系模型
创建老公表
CREATE TABLE hashand(
hid INT PRIMARY KEY AUTO_INCREMENT,
hname VARCHAR(50),
);
INSERT INTO hashand VALUES(NULL,‘刘备’);
INSERT INTO hashand VALUES(NULL,‘关羽’);
INSERT INTO hashand VALUES(NULL,‘张飞’);
SELECT * FROM hashand
//创建老婆表
CREATE TABLE wife(
wid INT PRIMARY KEY AUTO_INCREMENT,
wname VARCHAR(50),
CONSTRAINT fk_wife_hashand FOREIGN KEY(wid) REFERENCES hashand(hid)
)
/**
wid:
1,非空
2,唯一
3,引用hid
*/
INSERT INTO wife VALUES(1,‘杨贵妃’);
INSERT INTO wife VALUES(2,‘妲己’);
INSERT INTO wife VALUES(3,‘褒姒’);
SELECT * FROM wife;
对于一对一关系模型从表的主键即是外键,例如老公和老婆的关系模型,一个老公只能有一个老婆,一个老婆只能有一个老公
对于一对多关系模型主表的主键即是从表的外键,例如订单和用户的关系模型,一个用户可以下单多次,对应多个订单,而一个订单只能属于一个用户
对于多对多关系模型没有主表和从表之分,需要建立第三张表来记录这两张表的外键,建立两个外键,分别引用这两张表的主键
8,多对多关系模型
在表中简历多对多关系需要使用中间表,即需要三张表,在中间表中使用两个外键,分别引用其他两个表的主键,例如学生和老师的关系模型,一个老师可以有多个学生,一个学生可以有多个老师
CREATE TABLE student(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname CHAR(40)
);
CREATE TABLE teacher(
tid INT PRIMARY KEY AUTO_INCREMENT,
tname CHAR(40)
);
CREATE TABLE stu_tea(
sid INT,
tid INT,
ADD CONSTRAINT fk_stu_tea_sid FOREIGN KEY(sid) REFERENCES student(sid),
ADD CONSTRAINT fk_stu_tea_tid FOREIGN KEY(tid) REFERENCES teacher(tid)
);
INSERT INTO student VALUES(NULL,‘刘德华’);
INSERT INTO student VALUES(NULL,‘梁朝伟’);
INSERT INTO student VALUES(NULL,‘黄日华’);
INSERT INTO student VALUES(NULL,‘苗侨伟’);
INSERT INTO student VALUES(NULL,‘汤镇业’);
INSERT INTO teacher VALUES(NULL,‘崔老师’);
INSERT INTO teacher VALUES(NULL,‘刘老师’);
INSERT INTO teacher VALUES(NULL,‘石老师’);
SELECT * FROM student;
SELECT * FROM teacher;
INSERT INTO stu_tea VALUES(1,1); //刘德华是崔老师的学生
INSERT INTO stu_tea VALUES(2,1); //梁朝伟是崔老师的学生
INSERT INTO stu_tea VALUES(3,1);//黄日华是崔老师的学生
INSERT INTO stu_tea VALUES(4,1);//苗侨伟是崔老师的学生
INSERT INTO stu_tea VALUES(5,1);//汤镇业是崔老师的学生
INSERT INTO stu_tea VALUES(2,2);//梁朝伟是刘老师的学生
INSERT INTO stu_tea VALUES(3,2);//黄日华是刘老师的学生
INSERT INTO stu_tea VALUES(4,2);//苗侨伟是刘老师的学生
INSERT INTO stu_tea VALUES(3,3);//黄日华是石老师的学生
INSERT INTO stu_tea VALUES(5,3);//汤镇业是刘老师的学生
SELECT * FROM stu_tea;
这时在stu_tea这个中间表中的每条记录都是来说明student表和teacher表的关系的
例如在stu_tea表中的记录:sid为1001,tid为2001,这说明编号为1001的学生有一个编号为2001的老师
sid tid
1001 2001 //编号为1001的学生有一个编号为2001的老师
1001 2002 //编号为1001的学生有一个编号为2002的老师
1001 2003 //编号为1001的学生有一个编号为2003的老师
1002 2001 //编号为2001的老师有一个编号为1002的学生
1002 2004 //编号为2004的老师有一个编号为1002的学生
9,合并结果集
要求要合并的结果集中,列的类型和列数相同
UNION,去除重复行,UNION ALL,不去除重复行
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)