美文网首页
数据库01

数据库01

作者: 四月四七日薄暮 | 来源:发表于2018-12-12 00:24 被阅读0次

    MySQL的安装:

    sudo apt-get install mysql-server mysql-client

    基本命令:

    • 1、创建数据库

    create database 数据库名称 charset=utf8;;

    • 2、删除数据库

    drop database 数据库名称;

    • 3、查看数据库

    show database;

    • 4、使用(进入)数据库

    use 数据库名称;

    • 5、查看数据库当中有多少张表

    show tables;

    • 数据类型三大类

    1、数值类型
    2、字符串类型
    3、日期和时间类型

    • 常见数据类型
    4.1 double浮点型
    例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;4.2 char
    固定长度字符串类型;
    
    char(10)'abc '
    varchar
    
    可变长度字符串类型;
    varchar(10)'abc'
    
    text
    字符串类型
    
    blob
    二进制类型
    date
    提起类型,格式为:yyyy-MM-dd;
    
    time
    时间类型,格式为:hh:mm:ss;
    
    datetime
    日期时间类型,格式为:yyyy-MM-dd hh:mm:ss
    
    
    • 6、创建学生表

    CREATE TABLE 表名(
    列名1 列名类型 [约束],
    列名2 列名类型 [约束],
    .....
    列名N 类的类型 [约束]
    )

    • 7、添加一列

    ALTER TABLE 表名 ADD 列名 数据类型;

    • 8、删除一列

    ALTER TABLE students drop nums;

    • 9、查看表的字段信息

    desc 表名

    • 10、修改一个表的字段类型

    ALTER TABLE 表名 MODIFY 字段名 数据类型;

    • 11、修改表名

    RENAME TABLE 原始表名 TO 要修改的表名;

    • 12、查看表的创建细节

    SHOW CREATE TABLE 表名;

    • 13、修改表的字符集gbk

    ALTER TABLE students character set gbk;

    • 14、修改表的列名

    ALTER TABLE students change name newname varchar(20);

    • 15、删除表

    DROP TABLE 表名;

    • 16、查询表中的所有数据

    SELETE * FROM 表名;

    • 17、插入操作:

    INSERT INTO 表名 ( 列名1,列名2 ) VALUES (列值1, 列值2...);

    • 例子

    INSERT INTO students (id,name,age,email,score) VALUES (
    2,'lisi',18,'wengwenyu@aliyun.com',null
    );

    • 18、添加多条数据(批量插入):

    VALUES后面以逗号隔开
    INSERT INTO 表名(列名1,列名2....) VALUES(列值1,列值2),(列值1,列值2)....;

    • 例子

    INSERT INTO students (id,name,age,email,score) VALUES (2,'wangwu',20,'wengwenyu2@aliyun.com',20
    ),(
    3,'maliu',21,'wengwenyu3@aliyun.com',22
    );

    • 19、更新操作

    UPDATE 表名 SET 列名1=列值1, 列名2=列值2... WHERE 列名=值

    • 20、把所有学生的分数改为90

    UPDATE students SET score=90;

    • 21、把姓名为zs的学生分数修改为60

    UPDATE students SET score=60 WHERE name='zs';

    • 22、把姓名为lisi的年龄修改为20和分数修改为70

    UPDATE students SET age=30,score=70 WHERE name='lisi';

    • 23、把wangwu的年龄在原来基础上+1岁

    UPDATE students SET age=age+1 WHERE name='wangwu'

    • 24、修改数据库密码

    mysqladmin -u root -p password 123456

    • 25、删除操作

    如果不加过滤条件就是删除所有数据
    DELETE FROM 表名 [WHERE 列名=值]
    例子:
    DELETE FROM students WHERE name='amliu'

    • 26、删除所有数据

    TRUNCATE TABLE 表名;

    • DELETE 与 TRUNCATE的区别:
    DELETE可以删除指定数据也能删除所有数据 TRUNCATE只能删除所有数据
    
    DELETE删除表中的数据,表结构还在;删除后数据还可以找回
    
    TRUNCATE删除是把表直接DROP掉,然后再创建一个同样的新表.删除的数据不能找回.执行速度比DELETE快
    
    
    • 27、查询所有列

    SELECT * FROM 表名;

    • 结果集

    结果集:
    通过查询语句查询出来的数据以表的形式展示,我们称这个表为虚拟结果集.存放再内存中。
    查询返回的结果集就是一张虚拟表

    • 28、查询指定的列

    SELECT 列名1,列名2 FROM 表名;

    • 29、条件查询:

      [图片上传失败...(image-910912-1544545449024)]

    BETWEEN...AND; 值在什么范围
    IN(set);
    IS NULL; (为空)
    IS NOT NULL; (不为空)
    AND; 与
    OR; 或
    NOT; 非

    • 30、查询性别为男,并且年龄为20的学生记录

    添加性别字段
    ALTER table students add gender varchar(2);
    查询
    SELECT * FROM students WHERE gender='男' AND age=20;

    • 31、查询学号为1001 或者 名为 zs 的记录

    SELECT * FROM students WHERE id=1001 OR name='zs';

    • 32、查询学号为1001 , 1002 ,1003的记录

    (1)SELECT * FROM students WHERE id = 1001 OR id = 1002 OR id = 1003;
    (2)SELECT * FROM students WHERE id in (1001,1002,1003);

    • 33、查询年龄为null的记录

    SELECT * FROM students WHERE age IS NULL;

    • 34、查询年龄在18-20之间的学生记录

    (1)SELECT * FROM students WHERE age>= 18 AND age<=20;
    (2)SELECT * FROM students WHERE age BETWEEN 18 AND 20;

    • 35、查询性别非男的学生记录

    SELECT * FROM students WHERE gender != '男';

    • 36、查询姓名不为null的学生记录

    SELECT * FROM students WHERE name IS NOT NULL;

    模糊查询

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

    5个字母就是5个下划线
    SELECT * FROM students WHERE name LIKE '_____';

    • 38、查询姓名由5个字母构成,并且第5个字母为's'的学生记录

    SELECT * FROM students WHERE name LIKE '____s';

    • 39、查询姓名以'm'开头的学生记录

    SELECT * FROM students WHERE name LIKE 'm%';

    • 40、查询姓名中第二个字母为'u'的学生记录

    SELECT * FROM students WHERE name LIKE '_u%';

    • 41、查询姓名中包含's'字母的学生记录

    SELECT * FROM students WHERE name LIKE '%s%';

    • 42、去除重复记录 。 查询所有学生name信息,去除重复信息SELECT

    SELECT DISTINCT name FROM students;

    • 43、把查询字段的结果进行运算,必须都要是数值型

    SELECT *,字段1+字段2 FROM 表名;

    • 举例:

    查出所有内容,又添加了一个新的列为age和score的和,注意* 表示查出所有,然后逗号隔开,然后age+score SELECT *,age+score FROM students;

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

    SELECT *,age+IFNULL(score,0) FROM students;

    • 对查询结果起别名 在上面的查询中出现列名为sx+IFNULL(yw,0),这很不美观,现在我们给这一列起一个别名,为total:

    SELECT *,yw+IFNULL(sx,0) AS total FROM score;
    省略
    AS SELECT *,yw+IFNULL(sx,0) total FROM score;

    • 排序

    关键字 ORDER BY
    排序类型(默认是ASC)
    升序ASC 从小到大
    降序DESC 从大到小

    • 根据 id排序

    SELECT * FROM employee ORDER BY salary DESC,id DESC;

    相关文章

      网友评论

          本文标题:数据库01

          本文链接:https://www.haomeiwen.com/subject/zigyhqtx.html