MySql day01

~MySql~

MySQL是一个关系型数据库管理系统,是由瑞典的MySQLAB公司研发,之后被Oracle 公司收购,
目前是甲骨文旗下的产品。
MySQL是目前最流行的关系型数据库管理系统之一在小型的web应用中,
MySQL是最好的RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个
大仓库内,这样就增加了速度并提高了灵活性。
但是注意,MYSQL中存在大量的database,用户首先选择database,之后在database中
建立表,这一点与Oracle不同。

MySQL同样使用SQL语言,此语言是用于访问数据库的最常用标准化语言。

MySQL软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,
尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

由于其社区版的性能卓越,安装简便,搭配Apache旗下的Tomcat
等工具可以组成良好的开发环境。

1:使用CMD连接mysql
mysql -u root -p etoak

*:在cmd中使用mysql命令时,我们可以直接指定要连接的数据源
mysql -u root -p etoak test

2:在开始菜单中连接mysql
开始->mysql->Line Client->enter password

查看当前有哪些可用的数据源:
show databases;

创建数据源:
create database etoak;

使用某个数据源:
use etoak;

查看当前数据源下有哪些表:
show tables;

查看表结构:
desc 表名;
explain test;
show colums from test;

mysql中的自动增长:
create table test(
tid int primary key auto_increment,
tname varchar(10),
birth date
);

mysql中添加外键:
create table test2(
id int primary key auto_increment,
name varchar(10),
tid int,
foreign key(tid) references test(tid));

alter table test2 add foreign key(tid) references test(tid);

增加:
insert into test(tid,tname,birth) values(null,'葫芦娃','2018-04-16');
insert into test values(null,'金刚','2018-04-16');
insert into test(tid,tname,birth) values(null,'喜洋洋','2018-04-16');
insert into test(tid,tname,birth) values(null,'美羊羊','2018-04-16');
insert into test(tid,tname,birth) values(null,'懒洋洋','2018-04-16');
insert into test(tid,tname,birth) values(null,'沸羊羊','2018-04-16');
insert into test(tid,tname,birth) values(null,'灰太狼','2018-04-16');
insert into test(tid,tname,birth) values(null,'暖洋洋','2018-04-16');
insert into test(tid,tname,birth) values(null,'慢羊羊','2018-04-16');
insert into test(tid,tname,birth) values(null,'潇洒哥','2018-04-16');
insert into test(tid,tname,birth) values(null,'黑大帅','2018-04-16');

删除:
delete from test where tid=3;

修改:
update test set tname = '金刚' where tid = 2;

删除表:
drop table if exists test;
删除数据保留表结构:
truncate test;

分页:
如果limit之后只有一个值,从第一条开始数五条数据
select * from test limit 5;

如果有两个参数:第一个数为>5开始,第二个数多少个条数
select * from test limit 5,5;

拿取表中记录数:
select count(*) from test;


oracle和mysql
1:主键
mysql:一般使用自动增长类型,在创建表的时候只要指定表的主键为auto_increment,
      插入记录时,不需要再指定该记录的主键值;
oracle:没有自动增长类型,主键一般使用序列,插入记录时将序列号的下一个值赋给
       该字段即可。

2:分页
mysql:limit开始位置,记录个数;
oracle:通过rownum字段标明位置进行分页。

3:分组
mysql:group by 语句可以select 没有被分组的字段;
group_concat()
select tname,group_concat(tid)
from test group by tname;
oracle:select语句后必须有group by后分组的字段。  
wm_concat()

4:引号
mysql:单引号,双引号都可以;
oracle:一般不准使用双引,用了会报error。

5:转换数据
mysql:case when;
oracle:decode();

6:空值处理
mysql:非空字段也有空的内容;
oracle:定义了非空字段就不容许有空的内容。
按照mysql的not null来定义oracle的表结构,导数据时候会产生错误;
因此导数据时要对空字符进行判断,如果为null或空字符,需要把它改成一个空格的字符串。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jerry鹿17

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值