mysql的存储目录

1.MySQL的数据存储目录为datadata目录通常在C:Documents and SettingsAll UsersApplication DataMySQLMySQL Server 5.1data位置。在data下的每个目录都代表一个数据库。

2.启动和关闭mysql服务器

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

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

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

 3.

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

  • -u:后面的root是用户名,这里使用的是超级管理员root
  • -p:后面的123是密码,这是在安装MySQL时就已经指定的密码;
  • -h:后面给出的localhost是服务器主机名,它是可以省略的,例如:mysql -u root -p 123

退出:quitexit

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

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

 5.

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

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

1.2 语法要求

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

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

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

2 分类

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

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

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

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

3.3 数据(列)类型

MySQLJava一样,也有数据类型。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 DISTINCT sal FROM emp;

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

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

SELECT *,sal+comm FROM emp;

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 FROM emp;

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

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

COUNT

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

查询emp表中记录数:

SELECT COUNT(*) AS cnt FROM emp;

6.2 SUMAVG

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

l 查询所有雇员月薪和:

SELECT SUM(sal) FROM emp;

6.3 MAXMIN

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

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

 分组查询

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

7.1 分组查询

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

SELECT deptno, SUM(sal)

FROM emp

GROUP BY deptno;

7.2 HAVING子句

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

SELECT deptno, SUM(sal)

FROM emp

GROUP BY deptno

HAVING SUM(sal) > 9000;

  

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

8 LIMIT

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 TABLE stu(

sid INT PRIMARY KEY AUTO_INCREMENT,

snameVARCHAR(20),

ageINT,

genderVARCHAR(10)

3 非空

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

l 指定非空约束:

CREATE TABLE stu(

sid INT PRIMARY KEY AUTO_INCREMENT,  

sname VARCHAR(10) NOT NULL,

ageINT,

genderVARCHAR(10)

);

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

INSERT INTO stu(sid) VALUES(1);

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

4 唯一

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

CREATE TABLE tab_ab(

sid INT PRIMARY KEY AUTO_INCREMENT,

sname VARCHAR(10) UNIQUE

);

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

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

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

5 外键

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

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

创建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 表与表之间的关系

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

  • t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束;
  • t_card表的主键添加外键约束(相对t_user表),即t_card表的主键也是外键。

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

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

原文地址:https://www.cnblogs.com/panxuejun/p/5953481.html