50天精通Golang(第14天)

一、数据库

1.1 数据库 基本知识

DB:

DBMS:

数据库,数据表,表的结构。。

DB:是指datebase(数据库)
数据库是存储数据的一个集合,数据库中通常使用数据表等组成,而数据表是由数据的字段和数据的值等信息组成。
DBMS:是指datebase mangement systerm(数据库管理系统)
它是操作数据库和管理数据库的一个系统,比如mysql、sqlserver等都是属于数据库管理软件,人们通过这些系统或者工具来管理数据库内的数据。
DBS:是指datebase systerm (数据库系统)
数据库系统又数据库和数据库管理软件等组成,数据库是一个逻辑上的存储数据的概念,而对应的是实体是数据库管理软件存储存储在硬盘上的数据库,所以数据库系统包含数据库和数据库管理软件。

1.2 Mysql的安装和卸载

1.3 登录

方式一:DOS窗口:输入以下命令:

C:\Users\ruby>mysql -u root -p
回车后输入密码即可

方式二:通过Mysql的Command Line来登录:

直接输入密码即可

方式三:通过其他的可视化工具软件:

1.4 创建数据库:

1.创建数据库:

//create database [if not exists]数据库名 [default charset utf8 collate utf8_general_ci];
mysql> create database my1905 character set utf8;
Query OK, 1 row affected (0.00 sec)

2.显示有哪些数据库:

mysql> show databases;

3.切换到数据库:以后的操作都是针对该数据库的,比如建表。。

mysql> use my1905;

4.查看当前数据库有哪些数据表:

mysql> show tables;

5.删除数据库:

mysql> drop database if exists my1905;

1.5 数据类型

char(10)–>定长的字符串

​ "wangergou "

​ "abc "

varchar(10)–>变长

​ “wangergou”

​ “abc”

1.6 数据表的操作

1.创建数据库:

mysql> create database if not exists my1905 default charset utf8 collate utf8_ge
neral_ci;

2.创建数据表:

mysql> create table users(-> id int(4) primary key auto_increment,-> username varchar(20),-> pwd varchar(30));

3.查看表结构:desc–>describe

mysql> desc users;

4.显示检表语句:

mysql> show create table users;

注意点:

1.先创建数据库

mysql:

​ database1–>oa

​ database2–>bluebird

​ 。。。。

2.切换数据库

​ use 数据库名

3.创建数据表

mysql>create table test1(

​ ->id int(4) auto_increment primary key,

​ ->…);

5.插入一条数据:

mysql> insert into users(id,username,pwd) values(1,'admin','123456');
Query OK, 1 row affected (0.02 sec)

6.查询数据:

mysql> select * from users;
+----+----------+--------+
| id | username | pwd    |
+----+----------+--------+
|  1 | admin    | 123456 |
+----+----------+--------+
1 row in set (0.00 sec)

1.7 修改表结构

alter table 表名 xxx。。。

  1. 添加字段:add

    mysql> alter table users add(-> age int(4),-> birthday date);
    
  2. 修改已有字段的数据类型:modify

    mysql> alter table users modify age float(4,1);
    

注意点:并不能随意的更改已有列的数据类型。尤其是表中已经有数据了

​ A:兼容类型:长度可以从小到大,不能已有的数据越界。

​ B:不兼容类型:varchar–>int,更改失败。

3.更改列的名字:change

mysql> alter table users change pwd password varchar(30);

  1. 删除某列:drop

    mysql> alter table users drop birthday;
    

如果该列存在数据,那么数据也会被删掉。

5.表重命名:rename to

mysql> alter table users rename to user2;
mysql> rename table user2 to user3;

6.删除表:drop table

mysql> drop table user3;

1.8 插入数据

1.插入数据:

insert into 表名(列1,列2,列3.。。) values(值1,值2,值3.。。)

全列插入:如果有所有列都要插入数据,那么可以省略列的名字

缺省插入:如果有某一个或一些字段没有数值,那么就要写清楚列名和值。

同时插入多行:

1.9 修改数据

语法结构:

update 表名 set 列1=值1,列2=值2...[where 条件];

where后是修改条件:为true,才会修改数据。

运算符:=,数值相等!=,<>,数值不等between ... and,区间><>=<=orandin(值1,值2,值3.。)

1.修改学号为1006的同学姓名为陈聪

mysql> update student set name='陈聪' where no=1006;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0mysql> select * from student;
+------+--------+------+------+------------+
| no   | name   | age  | sex  | birthday   |
+------+--------+------+------+------------+
| 1001 | 王二狗 |   18 | 男   | 2007-10-10 |
| 1002 | rose   |   19 | 女   | 2006-09-09 |
| 1003 | jack   |   20 | 男   | 2005-08-06 |
| 1004 | 张三   |   18 | 女   | 1990-12-12 |
| 1005 | 李四   |   21 | 男   | 1991-06-08 |
| 1006 | 陈聪   |   22 | 男   | 1992-10-10 |
+------+--------+------+------+------------+
6 rows in set (0.00 sec)

2.年龄小于19岁的同学,性别改为女

mysql> update student set sex='女' where age < 19;
Query OK, 1 row affected (0.01 sec)
Rows matched: 2  Changed: 1  Warnings: 0mysql> select * from student;
+------+--------+------+------+------------+
| no   | name   | age  | sex  | birthday   |
+------+--------+------+------+------------+
| 1001 | 王二狗 |   18 | 女   | 2007-10-10 |
| 1002 | rose   |   19 | 女   | 2006-09-09 |
| 1003 | jack   |   20 | 男   | 2005-08-06 |
| 1004 | 张三   |   18 | 女   | 1990-12-12 |
| 1005 | 李四   |   21 | 男   | 1991-06-08 |
| 1006 | 陈聪   |   22 | 男   | 1992-10-10 |
+------+--------+------+------+------------+
6 rows in set (0.01 sec)

3.年龄大于等于18岁,并且小于等于19岁的同学姓名改为马冬梅

mysql> update student set name='马冬梅' where age >= 18 and age <= 19;
Query OK, 3 rows affected (0.01 sec)
Rows matched: 3  Changed: 3  Warnings: 0mysql> select *from student;
+------+--------+------+------+------------+
| no   | name   | age  | sex  | birthday   |
+------+--------+------+------+------------+
| 1001 | 马冬梅 |   18 | 女   | 2007-10-10 |
| 1002 | 马冬梅 |   19 | 女   | 2006-09-09 |
| 1003 | jack   |   20 | 男   | 2005-08-06 |
| 1004 | 马冬梅 |   18 | 女   | 1990-12-12 |
| 1005 | 李四   |   21 | 男   | 1991-06-08 |
| 1006 | 陈聪   |   22 | 男   | 1992-10-10 |
+------+--------+------+------+------------+
6 rows in set (0.00 sec)

4.修改年龄19到20岁之间的同学姓名为马春梅:

mysql> update student set name='马春梅' where age between 19 and 20;
Query OK, 2 rows affected (0.01 sec)
Rows matched: 2  Changed: 2  Warnings: 0mysql> select * from student;
+------+--------+------+------+------------+
| no   | name   | age  | sex  | birthday   |
+------+--------+------+------+------------+
| 1001 | 马冬梅 |   18 | 女   | 2007-10-10 |
| 1002 | 马春梅 |   19 | 女   | 2006-09-09 |
| 1003 | 马春梅 |   20 | 男   | 2005-08-06 |
| 1004 | 马冬梅 |   18 | 女   | 1990-12-12 |
| 1005 | 李四   |   21 | 男   | 1991-06-08 |
| 1006 | 陈聪   |   22 | 男   | 1992-10-10 |
+------+--------+------+------+------------+
6 rows in set (0.00 sec)

二、SQL

结构化查询语言(Structured Query Language)。操作数据库的。

DDL语言:数据定义语言(用于定义数据的表结构)Data Definition Language

​ 创建数据表:create table 表名

​ 修改数据表:alter table 表名

​ 删除数据表:drop table 表名

DML语言:数据操纵语言(用于操作数据表中的数据)DML - Data Mainpulation Language

​ 添加数据:insert

​ 修改数据:update

​ 删除数据:delete

DQL语言:数据查询语言(专门用于数据的查询)DQL - Data Query Language

​ 查询数据:select

DCL语言:

三、总结

数据库:

​ 安装和卸载(看文档)

​ 数据库的登录:

​ 1.dos窗口:mysql命令—>配置环境变量

​ -u 用户名

​ -p 密码

​ 2.mysql的命令行:直接输入密码即可

​ 3.通过一些可视化工具:比如navicat

1.show databases;

2.create database if not exists my1905 character set utf8;

​ default charset utf8 collate utf8_general_ci;

3.use my1905;

4.create table student(id int(4) primary key auto_increment,name varchar(30),sex varchar(2));

5.alter table 表名

​ add 列名 数据类型

​ modify 列名 数据类型

​ change 原列名 新列名 数据类型

​ drop 删除列

6.drop table 表名;

7.insert into 表名(列1,列2,列3.。。) values(值1,值2,值3.。。。)

​ 全列插入:

​ 同时插入多条:

8.update 表名 set 列1=新值,列2=新值 [where 修改条件];

​ where 后 的是表达式是boolean

​ =,!=,<>,>,<,>=,<=,between and, and , or ,not …

​ null—> is null ,is not null

9.delete from 表名 where 删除条件

约束:主键,外键

查询:简单查询,复杂,多表

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/624447.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3d云渲染用什么显卡比较好?3d云渲染显卡推荐

3D云渲染能加快渲染速度&#xff0c;是众多公司的首选方案&#xff0c;作为公司负责人&#xff0c;选择哪个平台值得思考&#xff0c;今天我就说下我的选择吧。 首先我们要了解云渲染的渲染方式&#xff0c;云渲染的渲染方式分两种&#xff0c;一种是CPU渲染&#xff0c;一种是…

linux下编译ffmpeg 以及交叉编译并引入Android

linux下编译ffmpeg 下载: http://ffmpeg.org/download.html 支持mp3编码&#xff1a;ffmpeg自身只支持mp3的解码但是不支持mp3的编码&#xff0c;如果希望格式转换为mp3&#xff0c;我们可以先安装支持库lame:(使用时: ffmpeg -i audio.wav -acodec libmp3lame audio.mp3) #…

openssl3.2 - 官方demo学习 - keyexch - x25519.c

文章目录 openssl3.2 - 官方demo学习 - keyexch - x25519.c概述笔记END openssl3.2 - 官方demo学习 - keyexch - x25519.c 概述 官方程序中演示了私钥2种key交换的情况: 产生X25519的key对(私钥/公钥), 并交换公钥给对方, 并分别产生会话密钥, 使双方都能持有相同的会话密钥 …

PHP AES加解密示例

以下是一个使用PHP的openssl扩展进行AES加密和解密的示例代码&#xff1a; php复制代码 <?php // 密钥和初始向量 $key your_secret_key; $iv your_initial_vector; // 加密函数 function encryptAES($data, $key, $iv) { $encrypted openssl_encrypt($data, AES-256-C…

解读Vue的原型及原型链

在 JavaScript 中&#xff0c;每个对象都有一个关联的原型&#xff08;prototype&#xff09;。原型是一个对象&#xff0c;其他对象可以通过原型实现属性和方法的继承。原型链是一种由对象组成的链式结构&#xff0c;它通过原型的引用连接了一系列对象&#xff0c;形成了一种继…

克服大模型(LLM)部署障碍,全面理解LLM当前状态

近日&#xff0c;CMU Catalyst 团队推出了一篇关于高效 LLM 推理的综述&#xff0c;覆盖了 300 余篇相关论文&#xff0c;从 MLSys 的研究视角介绍了算法创新和系统优化两个方面的相关进展。 在人工智能&#xff08;AI&#xff09;的快速发展背景下&#xff0c;大语言模型&…

从文本文件或 csv 文件读取信息的示例

如下表格说明文本文件或 csv 文件中的信息如何在 WinCC (TIA Portal) 中显示。 IO 域用作于显示&#xff0c;只有最有一个条目被输出。 注意 在此例中由于最后一条条目被搜索&#xff0c;脚本的运行系统会随着文件的尺寸增长而增长。先前示例中的配置在该示例中不是必须的。但是…

Linux 系统上,你可以使用 cron 定时任务来定期备份 MySQL 数据库

在 Linux 系统上&#xff0c;你可以使用 cron 定时任务来定期备份 MySQL 数据库。以下是一个基本的步骤&#xff0c;假设你已经安装了 MySQL 数据库和使用了 mysqldump 工具来进行备份。 步骤&#xff1a; 创建备份脚本&#xff1a; 创建一个包含备份命令的脚本。在这个例子中…

leetcode 1两数之和

题目 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 你可以按任意顺…

手把手教你使用Django如何连接Mysql

目录 一、引言 二、准备工作 三、配置Django连接MySQL 1、安装MySQL驱动&#xff1a; 2、配置数据库设置&#xff1a; 3、 创建数据库迁移&#xff1a; 四、编写Django模型和视图函数 1、编写模型&#xff1a; 2. 编写视图函数&#xff1a; 3. 编写模板&#xff1a; …

前端解析文件流

第一种方法&#xff0c;转blob对象 this.$axios({url: /md2api/attachment/c/${val.code},method: "GET",responseType: blob, //设置响应格式headers: {"Content-Type": "application/x-www-form-urlencoded",}, }) .then(function (respons…

软件测试感悟2

沟通 a.在测试前期与开发沟通&#xff0c;确认测试重点 &#xff0c;确认测试的优先级 b.了解开发人员技术和业务背景 业务水平 技术水平 代码质量 人员流动性 在测试结束后 对已发现的bug进行统计 ,知道高发概率bug ,在新项目中要进行重点测试 针对代码 代码复杂…

开关电源如何覆铜

开关电源如何覆铜 开关电源覆铜是一个很重要的技术方法&#xff0c;如果没有很好的覆铜&#xff0c;就有可能会造成开关电源芯片的损坏。先介绍常见的开关电源电路&#xff1a; 图 1开关电源电路 从左到右分别是非同步整流Buck电路和同步整流Buck电路&#xff0c;第二排从左到…

MIinW-W64交叉编译找不到‘mutex‘问题解决

问题 在linux下安装mingw-w64来交叉编译Windows的程序和库. 就像我之前的一篇博客提到的来进行mingw的交叉编译 这样默认安装的线程模型是win32模型.这个线程模型不支持mutex. 一般查找问题的过程: 线程模型通常包含互斥锁&#xff08;mutex&#xff09;作为线程同步的基本工…

Arduino快速上手esp8266方案开发

认识ESP8266 ESP8266 是 Espressif Systems 生产的 Wi-Fi 片上系统 (SoC)。它非常适合物联网和家庭自动化项目&#xff0c;目前有非常高的市场普及率&#xff0c;还有更加高端的同时支持wifi和蓝牙的双核心芯片ESP32&#xff0c;可以在乐鑫官网查看完整的芯片列表。 ESP8266芯…

Keepalived双机热备

学会构建双机热备系统学会构建LVSHA高可用群集 1.1 Keepalived概述及安装 Keepalived的官方网站位于http://www.keepalived.org/&#xff0c;本章将以yum方式讲解Keepalived的安装、配置和使用过程。在非LVS群集环境中使用时&#xff0c;Keepalived也可以作为热备软件使用 1.…

解决PS“暂存盘已满”错误

问题&#xff1a;PS“暂存盘已满”错误 原因&#xff1a; PS在运行时会将文件的相关数据参数保存到暂存区。当提醒暂存盘满时&#xff0c;说明你当前PS运行的使用盘符空间不足&#xff0c;所以在运行时一定要保留有足够的盘符空间来运行PS。 效果图 解决方案 注意: 我们在使用P…

光纤和光缆有何不同之处?

很多人会有这样的疑问&#xff0c;光纤和光缆有何不同之处&#xff1f;主要是因为光纤和光缆这两个名词容易引起混淆。在严格的定义下&#xff0c;光纤和光缆是两种不同的东西&#xff0c;然而在现实生活中&#xff0c;许多人仍然会混淆这两者。为了更好地理解光纤和光缆之间的…

C#基础:利用LINQ进行复杂排序

一、场景 请你写出linq对表格排序&#xff0c;CODE3排前面&#xff0c;其余按照CODE降序排序&#xff0c;CODE一样再按照字母升序排序 IDCODEVALUEA00011AA00021BA00031CA00042DA00052EA00062FA00073GA00083HA00093IA00104J 二、代码 using System; using System.Collectio…

进程 p.close和p.join的区别

p是指的进程 p.close()和p.join()是multiprocessing.Process类的两个方法&#xff0c;用于管理子进程的行为。 p.close(): 这个方法用于关闭子进程。当调用p.close()后&#xff0c;子进程将不再接受新的任务。在子进程执行完当前任务后&#xff0c;它将自动退出。这个方法通常…