mysql存储目录_mysql的存储目录

1.MySQL的数据存储目录为data,data目录通常在C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server 5.1\data位置。在data下的每个目录都代表一个数据库。

2.启动和关闭mysql服务器

l 启动:net start mysql(后面不加分号);

l 关闭:net stop mysql(后面不加分号);

在启动mysql服务后,打开windows任务管理器,会有一个名为mysqld.exe的进程运行,所以mysqld.exe才是MySQL服务器程序。

3.

l 登录:mysql -u root -p 123 -h localhost;

-u:后面的root是用户名,这里使用的是超级管理员root;

-p:后面的123是密码,这是在安装MySQL时就已经指定的密码;

-h:后面给出的localhost是服务器主机名,它是可以省略的,例如:mysql -u root -p 123;

l 退出:quit或exit;

登录MySQL需要使用MySQL的客户端程序:mysql.exe

在登录成功后,打开windows任务管理器,会有一个名为mysql.exe的进程运行,所以mysql.exe是客户端程序。

cbd2171f2e16ec92acaae3a7de849b2d.png

5.

SQL(Structured Query Language)是“结构化查询语言”,它是对关系型数据库的操作语言。它可以应用到所有关系型数据库中,例如:MySQL、Oracle、SQL Server等。

虽然SQL可以用在所有关系型数据库中,但很多数据库还都有标准之后的一些语法,我们可以称之为“方言”。例如MySQL中的LIMIT语句就是MySQL独有的方言,其它数据库都不支持!当然,Oracle或SQL Server都有自己的方言。

1.2语法要求

l SQL语句可以单行或多行书写,以分号结尾;

l 可以用空格和缩进来来增强语句的可读性;

l 关键字不区别大小写,建议使用大写;

2分类

l DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;

l DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);

l DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;

l DQL(Data Query Language):数据查询语言,用来查询记录(数据)。

3.3数据(列)类型

MySQL与Java一样,也有数据类型。MySQL中数据类型主要应用在列上。

常用类型:

l int:整型

l double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;

l decimal:浮点型,在表示钱方面使用该类型,因为不会出现精度缺失问题;

l char:固定长度字符串类型;

l varchar:可变长度字符串类型;

l text:字符串类型;

l blob:字节类型;

l date:日期类型,格式为:yyyy-MM-dd;

l time:时间类型,格式为:hh:mm:ss

l timestamp:时间戳类型;

1.2查询指定列

SELECT sid, sname, age FROM stu;

2条件查询

2.1条件查询介绍

条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:

3模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE。

3.1查询姓名由5个字母构成的学生记录

SELECT *

FROM stu

WHERE sname LIKE '_____';

模糊查询必须使用LIKE关键字。其中 “_”匹配任意一个字母,5个“_”表示5个任意字母。

4字段控制查询

4.1去除重复记录

去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:

SELECT DISTINCTsalFROMemp;

4.2查看雇员的月薪与佣金之和

因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不是数值类型,那么会出错。

SELECT *,sal+commFROMemp;

comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL。下面使用了把NULL转换成数值0的函数IFNULL:

SELECT *,sal+IFNULL(comm,0) FROM emp;

4.3给列名添加别名

在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total:

SELECT *, sal+IFNULL(comm,0) AS total FROMemp;

给列起别名时,是可以省略AS关键字的:

SELECT *,sal+IFNULL(comm,0)total FROMemp;

COUNT

当需要纵向统计时可以使用COUNT()。

l 查询emp表中记录数:

SELECT COUNT(*) AS cnt FROM emp;

6.2SUM和AVG

当需要纵向求和时使用sum()函数。

l 查询所有雇员月薪和:

SELECT SUM(sal) FROM emp;

6.3MAX和MIN

l 查询最高工资和最低工资:

SELECT MAX(sal), MIN(sal) FROM emp;

分组查询

当需要分组查询时需要使用GROUP BY子句,例如查询每个部门的工资和,这说明要使用部分来分组。

7.1分组查询

l 查询每个部门的部门编号和每个部门的工资和:

SELECT deptno, SUM(sal)

FROM emp

GROUP BY deptno;

7.2HAVING子句

l 查询工资总和大于9000的部门编号以及工资和:

SELECT deptno, SUM(sal)

FROM emp

GROUP BY deptno

HAVING SUM(sal) > 9000;

注意,WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。

8LIMIT

LIMIT用来限定查询结果的起始行,以及总行数。

8.1查询5行记录,起始行从0开始

SELECT * FROM emp LIMIT 0, 5;

注意,起始行从0开始,即第一行开始!

8.2查询10行记录,起始行从3开始

SELECT * FROM emp LIMIT 3, 10;

1主键

当某一列添加了主键约束后,那么这一列的数据就不能重复出现。这样每行记录中其主键列的值就是这一行的唯一标识。例如学生的学号可以用来做唯一标识,而学生的姓名是不能做唯一标识的,因为学习有可能同名。

主键列的值不能为NULL,也不能重复!

指定主键约束使用PRIMARY KEY关键字(primary key);

2主键自增长

MySQL提供了主键自动增长的功能!这样用户就不用再为是否有主键是否重复而烦恼了。当主键设置为自动增长后,在没有给出主键值时,主键的值会自动生成,而且是最大主键值+1,也就不会出现重复主键的可能了。

l 创建表时设置主键自增长(主键必须是整型才可以自增长):

CREATE TABLEstu(

sid INT PRIMARY KEY AUTO_INCREMENT,

snameVARCHAR(20),

ageINT,

genderVARCHAR(10)

3非空

指定非空约束的列不能没有值,也就是说在插入记录时,对添加了非空约束的列一定要给值;在修改记录时,不能把非空列的值设置为NULL。(int primary key auto_incement);

l 指定非空约束:

CREATE TABLEstu(

sid INT PRIMARY KEY AUTO_INCREMENT,

snameVARCHAR(10) NOT NULL,

ageINT,

genderVARCHAR(10)

);

当为sname字段指定为非空后,在向stu表中插入记录时,必须给sname字段指定值,否则会报错:

INSERT INTOstu(sid) VALUES(1);

插入的记录中sname没有指定值,所以会报错!

4唯一

还可以为字段指定唯一约束!当为字段指定唯一约束后,那么字段的值必须是唯一的。这一点与主键相似!例如给stu表的sname字段指定唯一约束:

CREATE TABLE tab_ab(

sid INT PRIMARY KEY AUTO_INCREMENT,

snameVARCHAR(10) UNIQUE

);

INSERT INTOsname(sid, sname) VALUES(1001,'zs');

INSERT INTOsname(sid, sname) VALUES(1002,'zs');

当两次插入相同的名字时,MySQL会报错!

5外键

主外键是构成表与表关联的唯一途径!

外键是另一张表的主键!例如员工表与部门表之间就存在关联关系,其中员工表中的部门编号字段就是外键,是相对部门表的外键。

l 创建t_section表,指定sid为主键列,u_id为相对t_user表的uid列的外键:

CREATE TABLE t_section(

sidINT PRIMARY KEY AUTO_INCREMENT,

snameVARCHAR(30),

u_idINT,

Constraint fk_t_user foreign key(u_id) referen ces t_user(uid)

CONSTRAINT fk_t_user FOREIGN KEY(u_id) REFERENCES t_user(uid)

);

7.

6表与表之间的关系

l 一对一:例如t_person表和t_card表,即人和身份证。这种情况需要找出主从关系,即谁是主表,谁是从表。人可以没有身份证,但身份证必须要有人才行,所以人是主表,而身份证是从表。设计从表可以有两种方案:

在t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束;

给t_card表的主键添加外键约束(相对t_user表),即t_card表的主键也是外键。

l 一对多(多对一):最为常见的就是一对多!一对多和多对一,这是从哪个角度去看得出来的。t_user和t_section的关系,从t_user来看就是一对多,而从t_section的角度来看就是多对一!这种情况都是在多方创建外键!

l 多对多:例如t_stu和t_teacher表,即一个学生可以有多个老师,而一个老师也可以有多个学生。这种情况通常需要创建中间表来处理多对多关系。例如再创建一张表t_stu_tea表,给出两个外键,一个相对t_stu表的外键,另一个相对t_teacher表的外键。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值