草庐IT

mysql的安装,数据库的操作,创建数据库,修改表,创建表,删除表,插入数据

小胖子学编程 2023-03-28 原文

mysql是什么?

现在是甲骨文公司下的一款关系型数据库,
优点:免费,体量小,相对稳定,开源
关系型数据库还有:sql-server
非关系型数据库:redis
两者的区别:关系型存储位置是在磁盘,非关系型存储位置在内存

数据库的安装:

1.首先要安装mysql
注意:需要把 add to path 勾选上,默认端口: 3306 无必要不要更改,
安装时尽量把账号和密码设置成自己能记住的不要太复杂

2.再安装三方工具:navicat15
注意:本身需要收费需要自己去下载破解包
3.使用三方工具连接本机数据库
步骤:输入连接名--》如果是连接主机就不用改主机名--》端口也不用改--》输入用户名--》
输入密码--》点击测试连接--》点击确定

4.数据库:Database 可以简称 DB
Database system 简称 DBS 有电脑硬件和操作系统和数据库管理系统和DBA构成
DBA:database Adminstrator 作用:维护数据库及数据库的相关开发。
数据库管理系统:database management system 简称DBMS ,mysql,oracle都是数据库管理系统也是关系型数据库
上述关系中,在数据库领域中有哪些关系?
(1) 直接关系:同一张表中,不同的两张表有相同的字段
(2) 间接关系:同一个数据库中,不同的两张表之间没有直接关系,
但可以通过第三张表或其他表,建立联系
我们可以一个连接比喻成一个很大的物流园,
在物流园中有很多的厂房,厂房中有很多的货架,每个货架上又有很多行。
在我们抽象的理解中,我们可以把物流园看成一个链接,把厂房看成一个数据库,
把一个货架看成一张表,把一个个货物看成一条条数据。

在dos命令窗口常用的dos命令:

​ 进入dos窗口:win+R
​ 进入指定目录:CD目录名返回上级目录:CD ..
​ 回到根目录:CD /
​ 查看当前目录下的子目录和文件:DIR
​ 宽屏查看: dir /w
​ 分页查看: dir /p

mysql工作目录介绍

​ 应用程序位置:Xampp\mysql\bin----mysql.exe
​ mysql配置文件:windows平台:my.ini linux平台:my.inf
​ mysqld.exe:mysql服务端程序
​ 连接数据库的语法:
​ mysql -u root -p (根据提示输入密码即可,前提是将MySQL的bin目录添加至环境变量)
​ 如果没有添加环境变量那么需要进入到bin目录下

sql语句注意事项:

(1)编写SQL语句的时候所有的标点符号都需要英文
(2)sql语句在编写语句的时候需要小写
(3)sql语句以分号结尾
(4)所有的单词必须正确
(5)语法顺序必须正确

简单的的sql语句

(1)进入连接后需要查询有哪些数据库:
关键字:show
语句:show databases ;
(2)进入某个数据库:
关键字: use
语句:use test;
(3)查看数据库中有哪些表
show tables ;
(4)查看表结构:
关键字:desc
desc 表名;
describe 表名;
field:域,字段或列的意思
type:类型的意思
Null:为空,什么都没有,不确定内容的意思 '':空串
key:键,关键字的意思
default:默认,在数据库中多指默认值

(5)查询表中所有数据
	关键字:select    查询的意思   from   从哪里.....
		语法;select 列名 from 表名;
	在没有规定具体要显示那些列名的时候可以用*号代替查询所有
	如果规定了具体要显示哪些列则必须使用对应的列名
	如果我们需要显示多个列,那么需要使用逗号隔开即可
	Select ad_id,ad_name from esc_ad;
	注意:在三方工具编写查蔼语句时需要注意自己在哪个连接中在哪个数据库下在写sql语句。
	我们既然要查询数据那么就一定要精准。

(6)查看当前连接是哪个数据库
		select database();
(7)查看当前那个用户连接的数据库
		select user();
(8)dos命令窗口下退出mysql程序
		1.输入quit;
		2.输入exit;
		3.按ctrl + c
		注意事项:不要直接输入mysql后回车进入数据库

数据库的操作

(1)创建数据库的命名规则;
1.数据库名称可以支持大小写字母,特殊字符就是_,来组合
2.数据库名称一般以字母大头
3.数据库名称建议在1-30个字符
4.数据库名可以支持中文汉字,但是不推荐
5.创建数据库的语法:
关键字:create database
create database 库名;---创建数据库当没有指定字符集(以后在插入数据的时候遇到汉字可能会报错)
create database 库名 default character set utf8
collate utf8_general+_ci;---创建数据库时指定字符集utf8
create:创建
database:数据库
default:默认
character:字符集
set:设置
collate:校对
ci:大小写不敏感
cs:大小写敏感

练习:创建数据库 school , school1
create database school;
create database school1 default character set utf8 collate utf8_general_ci;

6.修改数据库的字符集
关键字:alter database
语法:alter database 库名 character set 字符集 collate 排序规则;
alter:修改
练习:修改school1使得字符集为utf16
alter database school1 character set utf16 collate utf16_general_ci;

alter database school1 character set utf8 collate utf8_general_ci;

7.删除数据库
关键字:drop
语法:drop database 库名;
练习:将school和school1删除

drop database school;

drop database school1;

create database student default character set utf8 collate utf8_general_ci;

create database teacher default character set utf8 collate utf8_general_ci;

drop database student;

drop database teacher;

数据库中的表的操作

1.创建表
(1)表名称的命名规则;
1.表名称可以支持大小写字母,特殊字符就是_,来组合
2.表名称一般以字母大头
3.数据库名称建议在1-30个字符
4.数据库名称可以支持中文汉字,但是不推荐
5.表名称尽量含有业务意义
(2)创建表语法:
create table [库名].表名(
列名1 数据类型1(长度),
列名2 数据类型2(长度),
列名3 数据类型3(长度)
);

create database school;
create table school.student(
id int(2),
name varchar(5),
age int(3)

);
create table school.teacher(
id int(2),
name varchar(5),
age int(3)

);
create table school.class(
id int(2),
name varchar(5),
age int(3)

);
2.修改表
关键字;alter table
(1)为一个表增加一个字段
语法:alter table [库名].表名 add [column] 列名 数据类型[长度];
add: 添加
column:列
练习:添加一个字段在每张表中
alter table school.class add column sex varchar(2);
alter table school.student add column sex varchar(2);
alter table school.teacher add column salary float(7);

(2)在一张表中删除一列
	语法:alter table [库名].表名 drop[column] 列名;
	alter table school.class drop sex;
	alter table school.class add sex varchar(2);
	alter table school.class add column card varchar(18);
	关键字:drop 删除

3.删除表
语法:
drop table [库名].表名;
练习:删除school下的class表;
drop table school.class;

复制表

​ (1)只复制表结构
​ 语法:create table [库名].新表名 like 被复制的表名;
​ create table school.student1 like school.student;
​ create table school.teacher1 like school.teacher;
​ (2)复制表结构加数据
​ 语法:create table [库名].新表名 as select * from 被复制的表名;
​ create table school.a as select * from school.student;
​ create table school.b select * from school.student;
​ create table school.c as select * from school.student;
​ create table school.d as select * from school.student;

插入数据:

​ (1)单条插入数据
​ insert into school.student values(1,"小白",20,"女");
(2)批量插入数据
​ insert into school.student values
(2,"小白",20,"女"),
(3,"小白",20,"女"),
(4,"小白",20,"女");

有关mysql的安装,数据库的操作,创建数据库,修改表,创建表,删除表,插入数据的更多相关文章

  1. ruby - 如何在 Ruby 中顺序创建 PI - 2

    出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits

  2. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  3. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  4. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  5. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  6. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

    我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

  7. ruby - 我可以使用 Ruby 从 CSV 中删除列吗? - 2

    查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html

  8. ruby-on-rails - 无法使用 Rails 3.2 创建插件? - 2

    我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby​​1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在

  9. ruby - 完全离线安装RVM - 2

    我打算为ruby​​脚本创建一个安装程序,但我希望能够确保机器安装了RVM。有没有一种方法可以完全离线安装RVM并且不引人注目(通过不引人注目,就像创建一个可以做所有事情的脚本而不是要求用户向他们的bash_profile或bashrc添加一些东西)我不是要脚本本身,只是一个关于如何走这条路的快速指针(如果可能的话)。我们还研究了这个很有帮助的问题:RVM-isthereawayforsimpleofflineinstall?但有点误导,因为答案只向我们展示了如何离线在RVM中安装ruby。我们需要能够离线安装RVM本身,并查看脚本https://raw.github.com/wayn

  10. ruby-on-rails - rails 目前在重启后没有安装 - 2

    我有一个奇怪的问题:我在rvm上安装了ruby​​onrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(

随机推荐