您的位置:

mysql选定数据库,sql选中数据库

本文目录一览:

数据库(mysql)关键知识

Mysql是目前互联网使用最广的关系数据库,关系数据库的本质是将问题分解为多个分类然后通过关系来查询。 一个经典的问题是用户借书,三张表,一个用户,一个书,一个借书的关系表。当需要查询某个用户借书情况或者是书被那些人借了,就用关系查询来实现。

关系数据库范式

来自英文Normal form,简称NF。要想设计—个好的关系,必须使关系满足一定的约束条件,满足这些规范的数据库是简洁的、结构明晰的,同时,不会发生插入(insert)、删除(delete)和更新(update)操作异常。总共有六种范式:第一范式(1NF)、第二范式(2NF)、 第三范式 (3NF)、巴斯-科德范式(BCNF)、 第四范式 (4NF)和 第五范式 (5NF,又称完美范式)。

1NF是指数据库表的每一列都是不可分割的原子数据项。2NF必须满足1NF,要求数据库表中的每行记录必须可以被唯一地区分。3NF在2NF基础上,任何非主 属性 不依赖于其它非主属性(在2NF基础上消除传递依赖)。BCNF是在3NF基础上,任何非主属性不能对主键子集依赖(在3NF基础上消除对主码子集的依赖), 满足BCNF不再会有任何由于函数依赖导致的异常,但是我们还可能会遇到由于多值依赖导致的异常。4NF的定义很简单:已经是BC范式,并且不包含多值依赖关系。5NF处理的是无损连接问题,这个范式基本没有实际意义,因为无损连接很少出现,而且难以察觉。而域键范式试图定义一个终极范式,该范式考虑所有的依赖和约束类型,但是实用价值也是最小的,只存在理论研究中。

Catalog和Schema

是数据库对象命名空间中的层次,主要用来解决命名冲突的问题。从概念上说,一个数据库系统包含多个Catalog,每个Catalog又包含多个Schema,而每个Schema又包含多个数据库对象(表、视图、字段等)。但是Mysql的数据库名就是Schema,不支持Catalog。

Mysql的数据库引擎主要有两种MyISAM和InnoDB,MyISAM支持全文检索,InnoDB支持事务。

SQL中的通配符‘%’代表任意字符出现任意次数。‘_’代表任意字符出现一次。SQL与正则表达式结合查询一般用在WHERE table_name REGEXP '^12.34'。子查询是从里到外执行。

数据库联结(join)涉及到外键,外键是指一个表的列是另一个表的主键,那么它就是外键。笛卡尔积联结(不指定联结条件时)生成的记录条目是单纯的第一个表的行乘以第二个表的列数。用得最多的是等值联结也叫内部联结。

高级联结还有自连接,是指查询中的两张表是同一张表,它通常作为外部语句用来代替从相同表中检索数据时使用的子查询。自然联结使每个列只返回一次。外部联结是指联结包含了那些在相关表中没有关联行的行。例如列出所有产品及其订购数量,包括没有人订购的产品。LEFT OUTER JOIN指选择左边表的所有行。

组合查询是指采用UNION等将两个查询结果取并集。

视图是查看存储在别处的数据的一种工具,它本身并不包含数据,因此表的数据修改了,视图返回的数据也将随之修改,因此如果使用了复杂或嵌套视图会对性能有较大的影响。视图的作用之一是隐藏复杂的SQL通常会涉及到联结查询。

存储过程类似于批处理,包含了一条或多条SQL语句。语法:

CREATE PROCEDURE name()

BEGIN

SQL

END

-------------------------

CALL name()//来调用存储过程

游标有DECLARE定义,游标与存储过程是绑定的,存储过程处理完成,游标就会消失。游标被打开后可以使用FETCH语句访问每一行。

触发器是在某个时间发生时自动执行某条SQL语句。语法:

CREATE TRIGGER name AFTER INSERT ON talbe_name FOR EACH ROW

事务处理可以维护数据库的完整性,保证批量的操作要么完全执行,要么完全不执行。包括事务、回退、提交、保留点几个关键术语。ROLLBACK只能在一个事务处理内使用。他不能回退CREATE和DROP操作。使用COMMIT保证事务提交。复杂的事务处理需要部分提交或回退,因此我们需要使用保留点SAVEPOINT。可以使用ROLLBACK TO savepoint_name。保留点越多越好。保留点在事务执行完成后自动释放。

mysql怎么创建数据库表

01

MySql创建数据库指定字符集

创建数据库指定字符集:

UTF8

CREATE DATABASE xiaoyao_db DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci

GBK

CREATE DATABASE xiaoyao_db DEFAULT CHARACTER SET gbk COLLATE gbk_general_ci

02

MySql创建表并设定为主键自动增值

CREATE TABLE person

(

personID int NOT NULL AUTO_INCREMENT,

PRIMARY KEY(personID),

FirstName varchar(15),

LastName varchar(15),

Age int

)

//创建admin表

CREATE TABLE `admin`

(

`id` INT(11) NOT NULL AUTO_INCREMENT,

`username` CHAR(20) NOT NULL,

`password` CHAR(32) NOT NULL,

`email` CHAR(32) NOT NULL,

PRIMARY KEY(`id`)

)ENGINE=INNODB AUTO_INCREMENT=1;

03

MySql在PHP语句中insert into

INSERT INTO table_name (column1,column2,column3,...) VALUES (values1,values2,values3....);

04

Mysql在PHP语句中update语法

UPDATE table_name SET column_name = new_value WHERE column_name = some_value

05

Mysql在PHP语句中Delete from语法

DELETE FROM table_name WHERE column_name = some_values;

06

注意两点:

1、MySql在PHP语句中insert into常错点

mysql_query(“insert into admin(username,password,age) values(‘vaule’,’vaule’,’vaule’)”);

上面语句执行之前,应该先执行mysql_query(“set names utf8”);以防止数据插入数据之后出现乱码!

2、MySql在PHP语句中update常错点

update数据之前进行mysql_query(“set names utf8”)语句执行,这样才会成功更新数据

mysql如何在登录时指定连接的数据库?

MySQL数据库登录方法:要完成登录操作,首先要进入机器的命令行界面并输入如下所示的命令: mysql -h hostname -u username -p mysql命令将调用mySQL监视程序。这是一个可以将我们连接到mySQL服务器客户端的命令行公开。

MySql怎么插入和查询二进制数据

以PHP脚本为例。PHP一般只支持小于2M的文件,假如要存取大于2M的文件,那就要进系统方面的设置了。具体操作如下:

首先创建测试表testtable

CREATE TABLE testtable ( id INT(5) NOT NULL AUTO_INCREMENT PRIMARY KEY,filename CHAR(255),data LONGBLOB );

将文件存入表中使用如下PHP代码

?php

mysql_connect( "localhost", "root", "password"); //连接数据库

mysql_select_db( "database"); //选定数据库

$filename="" //这里填入二进制文件名

$data = addslashes(fread(fopen($filename, "r"), filesize($filename)));//打开文件并规范化数据存入变量$data中

$result=mysql_query( "INSERT INTO testtable (filename,data) VALUES ('$filename','$data')");//数据插入到数据库test表中

mysql_close();

?

从表中取回文件,使用如下PHP代码

?php

if($id) {

mysql_connect( "localhost", "root", "password");

mysql_select_db( "database");

$filename="" //这里填入二进制文件名

$query = "select data from testtable where filename=$filename";

$result = mysql_query($query);

$data = mysql_result($result,0, "data");

?

mysql 命令怎么选择数据库

如果你是在cmd命令行下:use 数据库名;

如果你是在PHP中选择数据库: mysqli_select_db(连接数据返回的资源变量,'数据库名');

mysql 怎么选择数据库 百度经验

mysql是数据库管理程序,你要选择数据库,可以使用sql语句中的use语法,比如 有数据库,a、b、c,你要操作数据库a,可以使用use a;来进行选择。

mysql选定数据库,sql选中数据库

2022-11-18
数据库的笔记mysql,数据库管理系统笔记

2022-11-24
mysql数据库完整笔记(mysql数据库数据)

2022-11-13
mysql数据库开发笔记(mysql数据库应用案例教程电子版

2022-11-14
连接mysql数据库笔记1(如何连接数据库mysql)

2022-11-10
mysql数据库笔记1000行,sql数据库查询最后1000

2022-11-23
想吧mysql数据库,MySQL数据库笔记

2022-11-21
我的mysql数据库学习笔记(mysql数据库菜鸟教程)

2022-11-11
mysql第1部分数据库简介(MySQL数据库笔记)

2022-11-14
mysql数据库番外篇之(MySQL数据库笔记)

2022-11-16
学习笔记之mysql数据库操作(mysql数据库怎么操作)

2022-11-16
jsp数据库笔记,jsp写入数据库

本文目录一览: 1、怎么用jsp连接mysql数据库 2、jsp中怎么使用数据库 3、JSP 从数据库中如何取得图片的路径? 怎么用jsp连接mysql数据库 一. 数据库的连接和操作笔记:1.初始化

2023-12-08
聊聊mysql数据库(sql数据库mysql)

2022-11-09
sql数据库到mysql数据库(sql导入mysql数据库)

2022-11-14
mysql没有数据库被选中(mysql提示没有选择数据库)

2022-11-12
mysql建数据库是选择gbk,在MySQL中创建数据库

2022-11-19
以mysql做数据库,mysql数据库怎么做

2022-11-18
操作mysql数据库总结,MySQL数据库笔记

2022-11-21
写mysql数据库(mysql编写数据库)

2022-11-13
基于mysql数据库和jsp,数据库sql和mysql

本文目录一览: 1、怎么用jsp连接mysql数据库 2、jsp怎么连接mysql数据库代码 3、jsp怎么连接mysql数据库 怎么用jsp连接mysql数据库 一. 数据库的连接和操作笔记:1.初

2023-12-08