zoukankan      html  css  js  c++  java
  • 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表的外键。

  • 相关阅读:
    51nod_1445 变色DNA 最短路模板 奇妙思维
    51nod_1459 最短路 dijkstra 特调参数
    UVA_10653 公主与王子 #刘汝佳DP题刷完计划
    HOJ 13819 Height map
    51nod_1255字典序最小的子序列
    电梯设计需求调研报告
    梦断代码读后感
    求一循环数组的最大子数组的和
    求二维数组中最大子数组的和
    四则运算
  • 原文地址:https://www.cnblogs.com/panxuejun/p/5953481.html
Copyright © 2011-2022 走看看