主页 > 其他  > 

SQL语句-中级

SQL语句-中级

 一、Mysql软件使用

1.启动/停止Mysql服务器

任务管理器

cmd命令:以管理员的身份打开cmd命令行

net start mysql80//开启 net stop mysql80//停止

2.连接与断开Mysql服务器

注意要在bin目录下执行:-u用户名root,-p密码

mysql -u root -p

可能出现的问题:

配置环境变量-右键此电脑——>点击属性——>高级设置——>系统属性——>用户变量新建——>复制Mysql的bin目录地址即可

 另一个是我遇到的,推荐这个博主文章:关于Can't connect to MySQL server on 'localhost:3306' (10061)问题-http://t.csdnimg /gjGFK

退出:

quit;

 二、数据库与表结构操作

1.对数据库的操作

数据库的创建:

create database test; create schema test1;//与上一句都是创建数据库 create database test2 character set=gbk;//创建时可设置编码格式-汉字编码 create database if not exists test;//创建时可先进行判断

修改数据库:

alter database 数据库名 default character set gbk//修改字符集编码为gbk default collate gbk_chinese_ci;//修改字符集校对规则编码为gbk,字符集编码必须要一致

删除数据库:

drop database 数据库名;

选择数据库:

use 数据库名;

2.数据类型

数据库中的数据类型对应C语言中的数据类型

tinyint---1个字节:-128~127;unsigned-0~255 smallint---2个字节: int---4个字节: bigint---8个字节:相当于long型 float(5,2)---4个字节:表示共5个数字长度,有2个小数位 unsigned表示无符号类型,即正数 char-定长字符类型,长度固定;varchar-变长字符串类型,按实际长度存储 tinytext--存储短文本字符串 date---年月日YYYY-MM-DD;time---时分秒HH:MM:SS datetime---date+time

3.表结构操作

alter table t_table1 add detail tinytext ;-- 添加新属性/字段 alter table t_table1 modify detail varchar(20) ; -- 修改属性类型/字段 alter table t_table1 change detail details varchar(20) ; -- 修改属性名/字段 alter table t_table1 drop column details;-- 删除字段 rename table t_table1 to table1;-- 修改表名 drop table if exists test;-- 删除表

三、多表操作

1.多表设计

一对多:部门与员工

create table labor( id int unsigned primary key auto_increment, username varchar(20) not null, gender tinyint unsigned not null, departure_id int unsigned, create_time datetime not null) comment '员工表'; create table departure( id int unsigned primary key auto_increment, name varchar(10) not null unique, create_time datetime not null ) comment '部门表'; //对已建表添加联系/约束:一个部门对应多个员工 alter table labor add constraint c1(约束名可任意取) foreign key(departure_id) references departure(id); //创建表时添加联系/约束 create table managers( id int unsigned primary key auto_increment, name varchar(20), departure_id int unsigned, labor_id int unsigned, constraint m1 foreign key(departure_id) references departure(id)) comment '部门经理'; //删除约束 alter table managers drop constraint c1(约束名);

一对一:用户与身份证-将单表进行拆分 

create table labor( id int unsigned primary key auto_increment, username varchar(20) not null, gender tinyint unsigned not null, departure_id int unsigned, create_time datetime not null) comment '员工表'; create table labor_card( id int unsigned primary key auto_increment, birthday date not null, idcard char(18) not null, labor_id int unsigned not null unique,//一定要加unique,否则不能实现一对一 constraint l1 foreign key (labor_id) references labor(id) ) comment '员工身份信息表';

多对多:学生与课程-借助中间表实现,分别关联两方主键

create table stu( id int auto_increment primary key, name varchar(20), num varchar(10) ) comment '学生表'; insert into stu(name,num) values('湘城','20210133'),('源思','20210522'),('砂峮','20211344'),('信肆','20212345'); create table course( id int auto_increment primary key, name varchar(20) ) comment '课程表'; insert into course(name) values('C'),('PHP'),('Java'); create table stu_cour( id int auto_increment primary key, stu_id int not null, cour_id int not null, constraint s1 foreign key (stu_id) references stu(id), constraint s2 foreign key (cour_id) references course(id) ) comment '中间表'; insert into stu_cour(stu_id,cour_id) values(1,2),(1,1),(2,2),(2,3);

2.多表查询

//查询所有 select * from stu,course;-- 笛卡尔积:A、B所有组合情况 ,包括重复记录 //内连接查询 select * from stu,course where stu.id=course.id; -- 隐式内连接查询:消除重复记录 select stu.name,course.name from stu,course where stu.id=course.id; -- 查询特定数据 select s.name,c.name from stu s,course c where s.id=c.id; -- 给表起别名 select * from stu (inner) join course on stu.id=course.id -- 显式内连接查询-inner可省略 //外连接查询 select * from stu left join course on stu.id=course.id; -- 左外连接:查询stu表的所有数据及其对应course数据 select * from stu right join course on stu.id=course.id; -- 右外连接:查询course表的所有数据及其对应stu表的数据 //子查询:嵌套查询 select * from stu where num>(select num from stu where name='湘城'); -- 单行单列 select * from course where id!=(select id from course where name='C') select * from stu where name='源思' or num=20210133 -- 多行单列查询 select * from stu where num in (20210133,20210522) select * from (select * from stu where num>20210522) t1,course where t1.id=course.id -- 多行多列,放在from后作为虚拟表进行查询

标签:

SQL语句-中级由讯客互联其他栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“SQL语句-中级