Mysql 明月三千里 (一)

MySQL数据管理结构

数据库:

            数据存储的仓库。内部存放 表。 表有行列之分。

            行: 记录、实体

            列:域、字段。

数据库简史:

            1. 萌芽阶段: 文件存储

            2. 第一代:层次模型、网状模型

            3. 第二代: 关系型数据库: SQL server、Oracle、MySQL、DB2、infomix、SQLlite

                                非关系型数据库: redis、MongoDB

安装mysql:

                按 aptitude: sudo apt-get install aptitude

                测试 MySQL是否安装 sudo  aptitude show mysql-server —— 未安装

                安装MySQL: sudo  apt-get/aptitude install mysql-server

                测试 MySQL是否安装 sudo  aptitude show mysql-server —— 已安装

                                                    mysql -V —— 获取安装版本

                MySQL配置文件 /etc/mysql/mysql.conf.d/mysqld.cnf —— 配置文件

                数据库、表存放位置 /var/lib/mysql

MySQL的启动:

        【重点】:MySQL数据库,要想使用,必须先启动MySQL服务器!!!

       启动MySQL:

                    1.  sudo /etc/init.d/mysql start —— 在其他Linux上,存储目录有变化。

                    2.  sudo service mysql start —— 在Linux中 通用。

        关闭和重启:

                    1.  sudo /etc/init.d/mysql stop/restart —— 在其他Linux上,存储目录有变化。

                    2.  sudo service mysql stop/restart —— 在Linux中 通用。

        判断是否启动成功:

                    1. sudo service mysql status —— 如果能看到 绿灯:说明启动成功。

                    2. netstat -apn | grep mysql —— 查看到 LISTENING 状态的进程

                    3. ps aux | grep mysql

MySQL登录:

                mysql -h127.0.0.1 -P3306 -uroot -p123456

                -h:主机服务器ip —— 本机可以省略不写。

                -P:端口号。默认3306 —— 可以省略不写

                -u:用户名 —— 默认root

                -p:密码 —— 隐藏密码: -p 直接回车。

退出:

                    quit、exit、\q

mysql:

                    基于数据库的数据管理系统。

Oracle:

                    基于用户的数据管理系统。

数据库的 curd:

        查询:

                        show databases; 查看当前MySQL下的数据库

                        show create database 数据库名; 查询创建 数据库的语法,以及当前数据库使用的 字符集。

        创建:

                        语法:create database [if not exists] `数据库名` [字符集]

                        create database `mydb1`; 默认创建的数据库 使用 latin1

                        create database if not exists `mydb2` charset=uf8; 创建 使用 utf8 字符集的 mydb2 数据库。

                        字符集:latin1、GBK、GB2312、utf8

        删除:

                        语法:      drop database [if exists] `数据库名`

                                        drop database if exists mydb1;

                        如果:    数据库在MySQL中已经存在,有 if exists 不会报错,会删除数据库

                                        数据库在MySQL中不存在,有 if exists 不会报错。

                                                                                        没有if exists 会报错。

        修改:

                        只能修改字符集。

                        语法:alter database `数据库名` charset=新字符集;

                        alter database mydb2 charset=gbk;

表的curd:

                        【重点】:操作表之前,必须先选定数据库。  use 数据库名;

        查询:

                            show tables; 查询当前使用的数据库中,表信息。

                            show create table 表名; 查询创建表的 sql语句。可以看到表所使用的引擎和字符集。

                            show craete table 表名\G 按行展示表数据

                            desc 表名; 查看表结构。su

        创建:

                            语法:create table [if not exists] `表名`(

                            字段名  数据类型 [not null | null] [auto_increment] [primary key] [comment],

                            字段名  数据类型 [default]....,

                                ....

                          ) engine=innodb charset=gbk;

        创建简单表:

                            create table t3( id int, age int, name varchar(10) );

        创建复杂表:

                            create table if not exists t2(

                           id int(9) auto_increment primary key comment '主键',

                           name varchar(20) not null comment '姓名',

                           phone varchar(20) comment '电话',

                           addr varchar(20) default '地址不确定' comment '地址'

                           )engine=innodb charset=gbk;

                           在 A 数据库中,向B数据库 创建表:

                                   create table 数据库名.表名(字段名  数据类型,....);

        删除:

                           语法:drop table [if exists] 表1,表2,… ;

        修改:

                           语法: alter table 表名 【修改的形式】。

                            增加一个字段:

                                                      语法:alter table 表名 add [column] 字段名  数据类型 [位置];

                                                                  alter table t2 add column age int(5) first;

                                                                  alter table t2 add sex char(2) after id;

                           删除一个字段:

                                                      语法: alter table 表名 drop [column] 字段名;

                           修改一个字段:改名、改类型:

                                                      语法:alter table 表名 change  [column] 旧字段名 新字段名 数据类型;

                                                              alter table t2 change name fullname char(10);

                           修改一个字段:只改类型:

                                                      语法:alter table 表名 modify [column] 字段名  新数据类型;

                                                      alter table t2 modify column fullname varchar(15);

                           只修改表名:

                                                      rename table t2 to t8; 或 alter table t8 rename to tb2;

                           修改默认引擎:

                                                      alter table tb2 engine=myisam;

        复制表:

                           只复制表数据,不复制表属性。

                                                      语法: create table 新表名 select 字段名, 字段名,... from 表名。

                                                      create table tt8 select * from tb2;

                           只复制表属性,不复制表数据。

                                                      语法: create table 新表名 like 旧表名。

                                                      create table tt9 like tb2;

                           想得到两张相同的表:

                                                      1.  复制表属性。 create table tt9 like tb2;

                                                      2.  复制表数据。 insert into tt9 select * from tb2;

表数据的curd:

        插入:

                           语法:insert into 表名(字段1, 字段2 .....)values(值1, 值2...)

                           全插入:

                                   insert into tb2(id, fullname, phone, addr) values(1, '张三', '129000', '深圳');

                                   insert into tb2 values(2, '张三', '129000', '深圳');

                           指定列插入:

                                   语法:insert into 表名(字段1,字段5, 字段3)values(值1, 值5, 值3);

                                   insert into tb2(id,fullname)vaules(3, '李白');

                           显示插入空值:

                                   在允许为空的列,插入时,值传 null

                           隐式插入空值:

                                   在允许为空的列,插入时,不插入数据。MySQL数据库会自动写入 null

                           隐式插入如默认值:

                                   对于有默认值的 列, 插入时,不插入数据。MySQL数据库会自动写入 默认值。

                           插入多行:

                                   insert into tb2 values(null, '陆游', null, default), (null, '李清照', '7777', '济南'), (null, '辛弃疾', '88888', '北京');

                           更新:

                                   语法:update 表名 set 字段名=值 [where 条件];

                           修改一条记录的一个字段:

                                   update tb2 set fullname='杜甫' where id = 4;

                                   如果没有 where 条件,会修改整张表。

                           修改一条记录的 多个字段:

                                    update tb2 set fullname='杜牧', phone='123987', addr='西安' where id=5;

                           修改多条记录:

                                   update tb2 set phone='88888' where id =1 or id=3 or id=5 or id=7;

                           删除:

                                   语法: delete from 表名 [ where 条件 ]

                                               delete from tb2 where id >=5;

                           清空表:

                                   delete from 表名;

                                   将表中的数据,清空,表空间没有被释放。速度慢

                                   truncate 表名;

                                    将表摧毁,重建新表。表空间会被释放。速度快。

                           查询:

                                   语法:select 列名,列名… from 表名 [ where 条件 ]

                                   select id, name, addr from tb2 where id >=3;

SQL语句分类:

                                   DML:insert、update、delete、select

                                   DDL:  create、truncate、drop、alter

                                   DCL:commit、rollback

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352