当前位置:Gxlcms > 数据库问题 > MYSQL之数据库初窥

MYSQL之数据库初窥

时间:2021-07-01 10:21:17 帮助过:4人阅读


1、数据库简介
   数据库概念:是按照数据结构来组织、存储和管理数据的仓库。
2、常用术语
   数据库:是一些关联表的集合
   数据表:表是数据的矩阵,在数据库中看起来像一个简单的电子表格
   列:一列数据元素包含了相同的数据
   行:一行是一组相关的数据
   主键:主键是唯一的,一个数据表中只能包含一个主键
   外键:外键用于关联两个表
   索引:使用索引可以快速访问数据库表中的特定信息
3、常用命令
   1、链接数据库:mysql -u root -p 回车输入密码即可
   2、退出数据库:mysql>exit 或者 mysql>quit
   3、数据库帮助信息:mysql --help
   4、创建数据库:mysqladmin -u root -p test      //创建了一个名为test的数据库
   5、删除数据库:mysqladmin -u root -p drop test
   6、选择数据库:mysql>use test
4、数据库类型
   类型大致可以分为三类:数值、日期/时间和字符串类型
 
      类型             大小        用途
   1、数值
      INT/INTEGER      4字节       整数型
      MEDIUMINT        3字节       整数型
      SMALLINT         2字节       整数型
      TINYINT          1字节       整数型
      BIGINT           8字节       整数型
      FLOAT            4字节       单精度浮点型
      DOUBLE           8字节       双精度浮点型
   2、日期/时间
      DATE             3字节       YYYY-MM-DD
      TIME             3字节       HH:MM:SS
      YEAR             1字节       YYYY
      DATETIME         8字节       YYYY-MM-DD HH:MM:SS
      TIMESTAMP        8字节       YYYYMMDD HHMMSS
   3、字符串
      CHAR             1字节       字符串型
      TEXT             4字节       文本型
5、基本语法命令
   1、创建数据表
   mysql>create table student(
       ->id int not null auto_increment,
       ->name char(20) not null,
       ->age int,
       ->primary key (id)
       -> );
   注:mysql命令终止符为分号(;)。
   2、删除数据表
   mysql>drop table student;
   3、插入数据
   mysql>insert into student(id,name) values (20028,"王刚");
   4、查询数据
   mysql>select * from student;
   mysql>select name from student;
   5、更新数据
   mysql>update student set name="王强" where id=20028;
   6、删除数据
   mysql>delete from student where id=20028;
6、高级语法命令
   1、like子句
   mysql>select * from student where id like ‘%00%‘ and name="王强";
   注:"%"指匹配多个,"?"指匹配一个
   2、排序
   mysql>select * from student order by id asc/desc;
   注:asc为升序,desc为降序
   3、join子句
   mysql>select a.id,a.age,b.sex from student a, test b
       ->where a.id=b.id;
   mysql>select a.id,a.age,b.sex from student a left join test b
       ->on a.id=b.id;
   注:使用left join,该语句会读取左边的数据表(student)的所有选取的字段数据,
       即使右边表(test)中没有对应的字段值。
   4、删除、添加或修改表字段
      1、修改表名
      mysql>alter table test rename to new_test;
      2、删除表中字段
      mysql>alter table student drop age;
      注:如果数据表中只剩余一个字段则无法使用drop来删除字段
      3、添加表中字段   
      mysql>alter table student add age int;
      注:执行以上命令后,age字段会自动添加到数据表字段的末尾
      4、修改字段类型
      mysql>alter table test modify name char(30);
      5、修改字段名称
      mysql>alter table test chang name new_name char(40);
      6、修改字段默认值
      mysql>alter table test alter age set default 24;
7、正则表达式
   
      模式                  描述
       $                匹配输入字符串的结束位置
       ^                匹配输入字符串的开始位置
       .                匹配除"\n"之外的任何单个字符,要匹配"\n"可使用"[.\n]"
      [...]             字符集合,匹配包含的任一个字符,列如[abc]可以匹配"apple"中的a
      [^...]            字符集合,匹配未被包含的任意字符,列如[^abc]可以匹配"apple"中的p
       *                匹配前面的子表达式零次或多次
       +                匹配前面的子表达式一次或多次
      {n}               n是一个非负整数,匹配确定的n次,例如"o{2}"不能匹配"Bob"中的"o"但是能匹配"food"中的两个o
      {n,m}             m和n均为非负整数,其中n<=m,最少匹配n次且最多匹配m次
   1、查找name字段中以‘st‘开头的所有数据
   mysql>select name from student where name regexp ‘^st‘;
   2、查找name字段中包含‘mar‘字符的所有数据
   mysql>select name from student where name regexp ‘*mar*‘;

版权声明:有不正确的地方,还望各位指正指导,Thanks!

MYSQL之数据库初窥

标签:mysql   数据库   

人气教程排行