【MsSQL】数据库基础 & 库的基本操作

打印 上一主题 下一主题

主题 666|帖子 666|积分 1998

目录
一,数据库基础
1,什么是数据库
2,主流的数据库
3,连接服务器
4,服务器,数据库,表关系
5,使用案例
二,库的操作
1,创建数据库
2,创建数据库案例
3,字符集和校验规则
1,查看系统默认字符集以及校验规则
2,查看数据库支持的字符集
3,查看数据库支持的字符集校验规则
4,校验规则对数据库的影响
4,操纵数据库
1,查看数据库
2,表现创建语句
3,修改数据库
4,数据库删除
5,备份和恢复
1,备份
2,还原
3,注意事项
6,查看连接情况


一,数据库基础

1,什么是数据库

存储数据用文件就可以了,为什么还要弄个数据库?
文件保存数据有以下几个缺点:
   文件的安全性问题
  文件倒霉于数据查询和管理
  文件倒霉于存储海量数据
  文件在程序中控制不方便
  数据库存储介质:
   磁盘
  内存
  为了办理上述问题,专家们设计出更加利于管理数据的东西——数据库,它能更有效的管理数据。数据库的水平是衡量一个程序员水平的紧张指标。

2,主流的数据库

   SQL Sever: 微软的产物,.Net程序员的最爱,中大型项目。
  
  Oracle: 甲骨文产物,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。
  
  MySQL:天下上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。重要用   在电商,SNS,论 坛。对简单的SQL处理效果好。
  
  PostgreSQL :加州大学伯克利分校盘算机系开辟的关系型数据库,不管是私用,商用,还是学术研究使用,可 以免费使用,修改和分发。
  
  SQLite: 是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设 计目标是嵌入式的,而且现在已经在很多嵌入式产物中使用了它,它占用资源非常的低,在嵌入式装备中,可 能只需要几百K的内存就够了。
  
  H2: 是一个用Java开辟的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。
  
3,连接服务器

输入:
   mysql -h 127.0.0.1 -P 3306 -u root -p
  一般我们用 mysql -u root -p 就可以了
  输出:
输入指令后,再输入暗码即可;
注意:
假如没有写 -h 127.0.0.1 默认是连接本地
假如没有写 -P 3306 默认是连接3306端口号

4,服务器,数据库,表关系

1,所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库, 一般开辟人员会针对每一个应用创建一个数据库
2,为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据
3,数据库服务器、数据库和表的关系如下:

5,使用案例

创建数据库
   create database helloworld;
  


使用数据库
   use helloworld;
  


创建数据库表
   create table student(
          id int,
          name varchar(32),
          gender varchar(2)
  );
  


表中插入数据
   insert into student (id, name, gender) values (1, '张三', '男');
  insert into student (id, name, gender) values (2, '李四', '女');
  insert into student (id, name, gender) values (3, '王五', '男');
  


查询表中的数据
   select * from student;
  


二,库的操作

1,创建数据库

语法:
   CREATE DATABASE
  [IFNOTEXISTS]db_name[create_specification[,create_specification] ...]
  
  create_specification:
          [DEFAULT] CHARACTER SET charset_name
          [DEFAULT] COLLATE collation_name
    说明:
  大写的表现关键字
[ ] 是可选项
CHARACTER SET: 指定数据库接纳的字符集
COLLATE: 指定数据库字符集的校验规则

2,创建数据库案例

创建名为 db1 的数据库
   create database db1;
  说明:
  当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8
  校验规则是:utf8_ general_ ci
  创建一个使用utf8字符集的 db2 数据库

show databases; 指令是查看数据库

创建一个使用utf8字符集的 db2 数据库
   create database db2 charset=utf8;
  
创建一个使用utf字符集,并带校对规则的 db3 数据库。
   create database db3 charset=utf8 collate utf8_general_ci;
  


3,字符集和校验规则

1,查看系统默认字符集以及校验规则

   show variables like 'character_set_database';
  show variables like 'collation_database';
  


2,查看数据库支持的字符集

   show charset;
  

字符集重要是控制用什么语言。比如utf8就可以使用中文。

3,查看数据库支持的字符集校验规则

   show collation;
  

假如想快速知道指定数据库的字符集和校验集的话:
   var/lib/mysql 在这个目录内里,mysql 的数据库在内里就是一个目录;
  


   进入想要查看的数据库目录,内里有文件 db.opt 内里存放了字符集和校验集; 
  


4,校验规则对数据库的影响

不区分大小写
创建一个数据库,校验规则使用utf8_ general_ ci[不区分大小写]
   create database test1 collate utf8_general_ci;
    use test1;
    create table person(name varchar(20));
    insert into person values('a');
  insert into person values('A');
  insert into person values('b');
  insert into person values('B');
  不区分大小写的查询以及结果


区分大小写
创建一个数据库,校验规则使用utf8_ bin[区分大小写]
   create database test2 collate utf8_bin;
    use test2
    create table person(name varchar(20));
    insert into person values('a');
  insert into person values('A');
  insert into person values('b');
  insert into person values('B');
  


一对比一目了然;

结果排序不区分大小写排序以及结果:


区分大小写排序以及结果:


4,操纵数据库

1,查看数据库

   show databases;
  

database 下面全是数据库;

2,表现创建语句


   说明:
  MySQL 发起我们关键字使用大写,但是不是必须的。
  数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  /*!40100 default.... */ 这个不是解释,表现当前mysql版本大于4.01版本,就执行这句话
  
3,修改数据库

语法:
   ALTER DATABASE db_name
  [alter_spacification [,alter_spacification]...]
  alter_spacification:
  [DEFAULT] CHARACTER SET charset_name
  [DEFAULT] COLLATE collation_name
  说明:
对数据库的修改重要指的是修改数据库的字符集,校验规则

实例: 将 test1 数据库字符集改成 gbk


4,数据库删除

   DROP DATABASE [IF EXISTS] db_ name;
  执行删除之后的结果:
        数据库内部看不到对应的数据库
        对应的数据库文件夹被删除,
        级联删除,内里的数据表全部被删
注意:不要随意删除数据库


5,备份和恢复

1,备份

语法:
   # mysqldump -P3306 -u root -p 暗码 -B 数据库名 > 数据库备份存储的文件路径
  示例:将 test2 库备份到文件(退出连接)
   # mysqldump -P3306 -u root -p123456 -B mytest > D:/mytest.sql
  


因为我这个 mytest 数据库是新建的内里没有东西;
我们看看另一个 D:test2.sql 的;

内里就有很多东西了;

2,还原

   mysql> source D:/mysql-5.7.22/mytest.sql;
  

先删除原数据库;

还原;


也是成功还原了;

3,注意事项

假如备份的不是整个数据库,而是此中的一张表,怎么做?
   # mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql
  同时备份多个数据库
   # mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径
  假如备份一个数据库时,没有带上-B参数, 在恢复数据库时,需要先创建空数据库,然后使用数据库,再使用 source来还原。

6,查看连接情况

语法:
   show processlist
  

可以告诉我们当前有哪些用户连接到我们的MySQL,假如查出某个用户不是你正常登陆的,很有大概你的数据库被 人入侵了。以后各人发现本身数据库比力慢时,可以用这个指令来查看数据库连接情况

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

石小疯

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表