zoukankan      html  css  js  c++  java
  • MySQL的部分基础语句

    (转载)http://blog.csdn.net/wangman_512/article/details/6761512

    今天复习了MySQL,说实话从高中我学的最有兴趣的一门就是数据库,所见今天听的很轻松。今天主要复习了MySQL的一些简单语句,可总结:

    MySQL的一些基础语句:

    行是记录 列是字段

    创建库

    CREATE DATABASE [IF NOT EXISTS] 数据库名 [参数[ 参数] [ 参数]...];

    参数:

    CHARACTER SET 码表名

    COLLATE 校对规则名, 详见文档10.10.1

    显示库

    SHOW DATABASES;

    显示数据库创建语句

    SHOW CREATE DATABASE 数据库名;

    修改库

    ALTER DATABASE 数据库名[ 参数[ 参数][ 参数]...];

    注意: 不能改数据库的名字

    删除库

    DROP DATABASE [IF EXISTS] 数据库名;

    操作表之前使用需要先确定使用哪个数据库

    USE 数据库名

    创建表

    CREATE TABLE 表名(列名 类型[,列名 类型][,列名 类型]...);

    查看所有表

    SHOW TABLES;

    查看表的创建语句

    SHOW CREATE TABLE 表名;

    显示表结构

    DESC 表名;

    修改表名

    RENAME TABLE 原表名 TO 新表名;

    修改字符集

    ALTER TABLE 表名 CHARACTER SET 字符集名;

    删除表

    DROP TABLE 表名;

    追加列

    ALTER TABLE 表名 ADD 列名 类型[,列名 类型][,列名 类型]...;

    修改列类型

    ALTER TABLE 表名 MODIFY 列名 类型[,列名 类型][,列名 类型]...;

    修改列

    ALTER TABLE 表名 CHANGE COLUMN 原列名 新列名 类型;

    删除列

    ALTER TABLE 表名 DROP 列名;

    插入语法:

    INSERT INTO 表名[(列名[,列名]...)] VALUES(值[,值]...);

    注意事项:

    插入值类型必须与对应列的数据类型一致

    数据不能超出长度

    插入值得为之必须与列名顺序一致

    字符和日期数据要放在单引号中

    插入空值使用null

    如果不指定插入哪一列, 就是插入所有列

    中文数据

    由于默认码表是utf8, 而cmd.exe的码表是gbk, 在插入中文数据的时候会报错, 所以我们需要修改客户端码表

    先查看系统变量: SHOW VARIABLES LIKE 'character%';

    修改客户端码表: SET character_set_client=gbk;

    修改输出数据的码表: SET character_set_results=gbk;

    修改语法

    UPDATE 表名 SET 列名=值[,列名=值]...[WHERE 条件语句];

    注意事项

    WHERE子句选择满足条件的行进行更新, 如果不写, 则更新所有行

    删除语法

    DELETE FROM 表名 [where 条件语句]

    注意事项

    如果不加where子句, 将删除表中所有记录

    delete只能用作删除行, 不能删除某一列的值, 需要用update

    在delete和update的时候需要注意表与表之间的关联关系

    删除表中所有数据可以使用: TRANCATE 表名, 这种方式会删除旧表重新创建, 在数据较多的时候使用

    备份数据库

    输入quit退出mysql, 在cmd.exe中输入:

    mysqldump –u用户名 –p密码 数据库名 > 文件名

    恢复数据库

    进入mysql.exe之后, 使用数据库之后

    source 文件名

    操作数据(查询)

    DISTINCT语法

    SELECT [DISTINCT] 列名[, 列名]... FROM 表名

    注意事项

    *可以替代列名, 表示所有列, 但是通常我们为了提高代码的可读性, 不使用*

    DISTINCT为过滤重复记录

    如果DISTINCT后面跟多列, 是过滤掉多列合并之后的重复

    列名表达式——语法

    SELECT 列名|表达式[,列名|表达式]... FROM 表名

    注意事项

    表达式只是显示时起作用, 不会改变数据库中的值

    AS——

    SELECT 列名 AS 别名 FROM 表名

    注意事项

    起别名时AS可以省略

    不会改变数据库中的值

    WHERE——

    语法

    SELECT 列名 FROM 表名 [WHERE 条件语句]

    WHERE子句中的运算符

    比较运算符

    >, <, >=, <=, =, <>

    注意不等于和Java中不同, 是<>

    BETWEEN ... AND ...

    某一区间内的值, 从 ... 到 ...

    IN(列表)

    在列表之中, 例: in(1,2,3) 代表1或2或3

    LIKE(表达式)

    模糊查询, %代表多个字符, _代表单个字符

    IS NULL

    判断是否为NULL

      逻辑运算符

    AND &&

    与, 两边都为TRUE结果为TRUE

    OR ||

    或, 一边为TRUE结果就为TRUE

    NOT !

    非, 将表达式结果取反

    ORDER BY——

    语法

    SELECT 列名 FROM 表名 ORDER BY 列名 ASC|DESC;

    注意事项

    ORDER BY 指定排序的列名可以是表中的列名, 也可以是SELECT语句后面起的别名

    ASC为升序, DESC为降序

    ORDER BY应在查询语句的结尾

    COUNT函数——

    语法

    SELECT COUNT(*)|COUNT(列名) from 表名 [WHERE 条件语句]

    注意事项

    COUNT(列名)的方式是统计指定列中有多少条记录, 不包括值为NULL的

    COUNT(*)则是统计表中有多少条数据

    COUNT(DISTINCT 列名) 统计不重复的记录数

    如果加上WHERE子句, 则是统计满足条件的记录

  • 相关阅读:
    龟兔赛跑(动态规划)
    Dividing (多重背包 搜索)
    第k大值01背包问题
    FATE(完全背包)
    01背包 和 完全背包 详解
    放苹果(动态规划)
    max Sum(简单动态规划)
    连连看 优先对列 应用2
    尺取法
    Square(强大的剪枝)
  • 原文地址:https://www.cnblogs.com/Robotke1/p/3050444.html
Copyright © 2011-2022 走看看