时间:2021-07-01 10:21:17 帮助过:20人阅读
cmd>services.msc //打开服务界面
找到mysql
启动
cmd>netstat -ano //查看端口
查询
查看当前数据库服务器中的所有数据库: Show databases;
查看前面创建的mydb2数据库的定义信息 :Show create database mydb2;
删除前面创建的mydb3数据库 :Drop database mydb3;
修改
查看服务器中的数据库,并把mydb2的字符集修改为utf8; alter database mydb2 character set utf8;
删除 :Drop database mydb3;
其他: 查看当前使用的数据库: Select database();
切换数据库: Use mydb2;
常用数据类型:
int:整型
double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
char:固定长度字符串类型; char(10) ‘aaa ‘ 占10位 varchar:可变长度字符串类型;
varchar(10) ‘aaa‘ 占3为 text:字符串类型;
blob:字节类型;
date:日期类型,格式为:yyyy-MM-dd;
time:时间类型,格式为:hh:mm:ss timestamp:
时间戳类型 :yyyy-MM-dd hh:mm:ss 会自动赋值 datetime:
日期时间类型: yyyy-MM-dd hh:mm:ss
当前数据库中的所有表 :SHOW TABLES;
查看表的字段信息 :DESC employee;
在上面员工表的基本上增加一个image列: ALTER TABLE employee ADD image blob;
修改job列,使其长度为60: ALTER TABLE employee MODIFY job varchar(60);
删除image列,一次只能删一列 :ALTER TABLE employee DROP image;
表名改为user: RENAME TABLE employee TO user;
查看表格的创建细节: SHOW CREATE TABLE user;
修改表的字符集为gbk: ALTER TABLE user CHARACTER SET gbk;
列名name修改为username :ALTER TABLE user CHANGE name username varchar(100);
删除表: DROP TABLE user ;
查询表中的所有数据 SELECT * FROM 表名;
DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。
INSERT 、UPDATE、 DELETE
小知识: 在mysql中,字符串类型和日期类型都要用单引号括起来。 空值:null
语法: INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...);
注意:列名与列值的类型、个数、顺序要一一对应。
可以把列名当做java中的形参,把列值当做实参。 参不要超出列定义的长度。 如果插入空值,请使用null 插入的日期和字符一样,都使用引号括起来。
语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 ...... WHERE 列名=值
语法 : DELETE 表名 【WHERE 列名=值】
查询关键字:SELECT 语法:
SELECT 列名 FROM表名 【WHERE --> BROUP BY -->HAVING--> ORDER BY】
语法: SELECT selectionlist /要查询的列名称/
FROM tablelist /要查询的表名称/
WHERE condition /行条件/
GROUP BY groupingcolumns /对结果分组/
HAVING condition /分组后的行条件/
ORDER BY sortingcolumns /对结果分组/
LIMIT offsetstart, rowcount /结果限定/
条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:
=、!=、<>、<、<=、>、>=;
BETWEEN…AND; IN(set); IS NULL; AND; OR; NOT;
通配符: _ 任意一个字母
%:任意0~n个字母
使用distinct:
asc升序; desc降序
COUNT():统计指定列不为NULL的记录行数;
MAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
MIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
SUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
AVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;
当需要分组查询时需要使用GROUP BY子句,
例如查询每个部门的工资和,这说明要使用部分来分组。
注: 凡和聚合函数同时出现的列名,则一定要写在group by 之后
having与where的区别:
1.having是在分组后对数据进行过滤. where是在分组前对数据进行过滤
2.having后面可以使用分组函数(统计函数) where后面不可以使用分组函数。
WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。
LIMIT用来限定查询结果的起始行,以及总行数。
分页查询
查询语句书写顺序:select – from- where- group by- having- order by-limit
查询语句执行顺序:from - where -group by - having - select - order by-limit
实体完整性: 域完整性: 引用完整性:
实体:即表中的一行(一条记录)代表一个实体(entity) 实体完整性的作用:标识每一行数据不重复.
约束类型: 主键约束(primary key) 唯一约束(unique) 自动增长列(auto_increment)
注:每个表中要有一个主键。 特点:数据唯一,且不能为null 例:
第一种添加方式: CREATE TABLE student( id int primary key, name varchar(50) );
第二种添加方式:此种方式优势在于,可以创建联合主键
CREATE TABLE student( id int, name varchar(50), primary key(id) );
CREATE TABLE student( classid int, stuid int, name varchar(50), primary key(classid,stuid) );
第三种添加方式: CREATE TABLE student( id int, name varchar(50) );
ALTER TABLE student ADD PRIMARY KEY (id);
特点:数据不能重复。
CREATE TABLE student( Id int primary key, Name varchar(50) unique );
给主键添加自动增长的数值,列只能是整数类型
CREATE TABLE student( Id int primary key auto_increment, Name varchar(50) );
INSERT INTO student(name) values(‘tom’);
外键约束:FOREIGN KEY
CREATE TABLE student(
sid int pirmary key,
name varchar(50) not null,
sex varchar(10) default ‘男’
);
create table score(
id int,
score int,
sid int , -- 外键列的数据类型一定要与主键的类型一致
CONSTRAINT fk_score_sid foreign key (sid) references student(id)
);
第二种添加外键方式。 ALTER TABLE score1 ADD CONSTRAINT fkstuscore FOREIGN KEY(sid) REFERENCES stu(id);
合并结果集;UNION 、 UNION ALL
连接查询
内连接 [INNER] JOIN ON
外连接 OUTER JOIN ON
左外连接 LEFT [OUTER] JOIN
右外连接 RIGHT [OUTER] JOIN
全外连接(MySQL不支持)FULL JOIN
自然连接 NATURAL JOIN
子查询
一个select语句中包含另一个完整的select语句。
子查询就是嵌套查询,即SELECT中包含SELECT,如果一条语句中存在两个,或两个以上SELECT,那么就是子查询语句了。
子查询出现的位置: where后,作为条为被查询的一条件的一部分;
from后,作表;
当子查询出现在where后作为条件时,还可以使用如下关键字:
any all
子查询结果集的形式: 单行单列(用于条件) 单行多列(用于条件) 多行单列(用于条件) 多行多列(用于表)
MySql知识点
标签:服务器 结构化 合并 ase size insert ati 开头 分页