石小疯 发表于 2024-6-15 03:38:16

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

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

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 就可以了
输出:
https://img-blog.csdnimg.cn/direct/d2e5291e7fb3410499d9dca3b4a6a9b2.png输入指令后,再输入暗码即可;
注意:
假如没有写 -h 127.0.0.1 默认是连接本地
假如没有写 -P 3306 默认是连接3306端口号

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

1,所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库, 一般开辟人员会针对每一个应用创建一个数据库
2,为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据
3,数据库服务器、数据库和表的关系如下:
https://img-blog.csdnimg.cn/direct/c876664c0bf04bcd9ad098bd8f03a39d.png
5,使用案例

创建数据库
   create database helloworld;
https://img-blog.csdnimg.cn/direct/4a3912d9fbc34c758f9060c093375682.png

使用数据库
   use helloworld;
https://img-blog.csdnimg.cn/direct/8b0a012e9dc8405f8855fba515a6595f.png

创建数据库表
   create table student(
        id int,
        name varchar(32),
        gender varchar(2)
);
https://img-blog.csdnimg.cn/direct/fa80be72ca0a4b1ea20c00f59bfbffcc.png

表中插入数据
   insert into student (id, name, gender) values (1, '张三', '男');
insert into student (id, name, gender) values (2, '李四', '女');
insert into student (id, name, gender) values (3, '王五', '男');
https://img-blog.csdnimg.cn/direct/9c55f37fa4924021bcf92724b5272b02.png

查询表中的数据
   select * from student;
https://img-blog.csdnimg.cn/direct/9e0af450f9924bd6a8655a0724358fc3.png

二,库的操作

1,创建数据库

语法:
   CREATE DATABASE
db_name ...]

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

2,创建数据库案例

创建名为 db1 的数据库
   create database db1;
说明:
当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8
校验规则是:utf8_ general_ ci
创建一个使用utf8字符集的 db2 数据库
https://img-blog.csdnimg.cn/direct/9cad42a0a8a249ec8e43c1c228aa0373.png
show databases; 指令是查看数据库

创建一个使用utf8字符集的 db2 数据库
   create database db2 charset=utf8;

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

https://img-blog.csdnimg.cn/direct/51331770fd374bec8ba49bb2560d872c.png

3,字符集和校验规则

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

   show variables like 'character_set_database';
show variables like 'collation_database';
https://img-blog.csdnimg.cn/direct/9062fc64a2a941d0bc946c2a7b692305.png

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

   show charset;
https://img-blog.csdnimg.cn/direct/d1b74dac1db2420a8c507de1ae1cfd6f.png
字符集重要是控制用什么语言。比如utf8就可以使用中文。

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

   show collation;
https://img-blog.csdnimg.cn/direct/42417cfbd9c94c3d9455ea4e98435bab.png
假如想快速知道指定数据库的字符集和校验集的话:
   var/lib/mysql 在这个目录内里,mysql 的数据库在内里就是一个目录;
https://img-blog.csdnimg.cn/direct/14cef9b29d0d42b7aebb30bf91745cf2.png

   进入想要查看的数据库目录,内里有文件 db.opt 内里存放了字符集和校验集; 
https://img-blog.csdnimg.cn/direct/d18914074b364d93a5985d8a0a3937f2.png

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');
不区分大小写的查询以及结果
https://img-blog.csdnimg.cn/direct/d9e3147c3343406399c8f4802a65eabd.png

区分大小写
创建一个数据库,校验规则使用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');
https://img-blog.csdnimg.cn/direct/f310fa3bb26d46e59e7e8f8f130c878a.png
https://img-blog.csdnimg.cn/direct/3321ecb7e7dd43a19fcbf35d52464f1f.png
一对比一目了然;

结果排序不区分大小写排序以及结果:
https://img-blog.csdnimg.cn/direct/15bfbbb95a6b4d57b599332eac63ba80.png

区分大小写排序以及结果:
https://img-blog.csdnimg.cn/direct/5ab29004269b4caa96e7f67eabc2df1d.png

4,操纵数据库

1,查看数据库

   show databases;
https://img-blog.csdnimg.cn/direct/53306a4ecf8b48fab66aab87ff318f90.png
database 下面全是数据库;

2,表现创建语句

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

3,修改数据库

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

实例: 将 test1 数据库字符集改成 gbk
https://img-blog.csdnimg.cn/direct/809a3f7c78c947dea5a7b09a29621ab3.png

4,数据库删除

   DROP DATABASE db_ name;
执行删除之后的结果:
        数据库内部看不到对应的数据库
        对应的数据库文件夹被删除,
        级联删除,内里的数据表全部被删
注意:不要随意删除数据库
https://img-blog.csdnimg.cn/direct/dbe39613aee84821b052e44286ea0fbb.png

5,备份和恢复

1,备份

语法:
   # mysqldump -P3306 -u root -p 暗码 -B 数据库名 > 数据库备份存储的文件路径
示例:将 test2 库备份到文件(退出连接)
   # mysqldump -P3306 -u root -p123456 -B mytest > D:/mytest.sql
https://img-blog.csdnimg.cn/direct/074650cb26534d51a93be4e161e635c1.png
https://img-blog.csdnimg.cn/direct/880085ed86e848c5aee0c8a65695a168.png
因为我这个 mytest 数据库是新建的内里没有东西;
我们看看另一个 D:test2.sql 的;
https://img-blog.csdnimg.cn/direct/618edad84fcc4c35b5160e5548b9655e.png
内里就有很多东西了;

2,还原

   mysql> source D:/mysql-5.7.22/mytest.sql;
https://img-blog.csdnimg.cn/direct/f01fd1f551e648378ce55d92c89c8aef.png
先删除原数据库;

还原;
https://img-blog.csdnimg.cn/direct/1a586f5411db4c50abf3e91bb76acc90.png
https://img-blog.csdnimg.cn/direct/47a3fb78b74b4c189c804e894b11676a.png
也是成功还原了;

3,注意事项

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

6,查看连接情况

语法:
   show processlist
https://img-blog.csdnimg.cn/direct/4545902aafe84278acaa0b51c40576dc.png
可以告诉我们当前有哪些用户连接到我们的MySQL,假如查出某个用户不是你正常登陆的,很有大概你的数据库被 人入侵了。以后各人发现本身数据库比力慢时,可以用这个指令来查看数据库连接情况

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 【MsSQL】数据库基础 & 库的基本操作