本节介绍MySQL支持的数据类型,提供关于每种类型的名称、作用、格式和范围的信息。TIMETIME数据类型负责存储时间信息,支持的范围相当大,不仅足以表示标准和军用时间格式,还可以表示扩展时间间隔。注意,对于MySQL版本4.1及更新版本,不可以指定该数据类型的大小。......
2023-10-29
MySQL绑定了很多客户端程序(从5.1.4-beta版以来总共有18个)。本节全面介绍了最重要的两个客户端(mysql和mysqladmin),最后会简单介绍其他的客户端。
1.mysql客户端
mysql客户端是一个特别有用的SQL shell,能够管理几乎MySQL的每个方面,包括创建、修改和删除表和数据库、设置用户访问权限、浏览和修改服务器配置,以及查询表数据。虽然大多数时间可能会通过GUI或API与MySQL交互,但总会发现这个客户端对于完成各种管理任务很有价值,特别是其在shell环境下的脚本功能。其一般用法语法如下:
Mysql客户端可以采用交互模式或非交互模式使用,这两种模式都将在本节介绍。无论使用何种模式,一般都需要提供连接选项。虽然所需的凭证取决于特定的服务器配置,但一般都需要主机名(- -host=.-h)、用户名(-user=.-u)和密码(-password=,-p)。通常会希望包括目标数据库名称(--database=.-D),这样在进入客户端后就不必再执行USE命令了。虽然顺序无关紧要,但一般有以下连接选项:
密码不包括在命令行中,按下Enter键,提示输入密码。
在提示的时候,就进入了enter。如果凭证有效,则将得到客户端界面的欢迎词。
通过mysql客户端连接之后,就可以开始执行SQL命令。例如,要查看所有现有数据库的列表,可以使用以下命令:
为了切换到(或使用)另一个数据库,例如“test”数据库,使用以下命令:
则可以切换到MySQL中创建的“test”数据库,或者创建一个新数据库。
切换到“test”数据库上下文后,就可以通过以下命令查看所有表:
还可以执行SQL查询,如INSERT、SELECT、UPDATE和DELETE。
总之,可以通过mysql客户端执行MySQL能够理解的任何查询。(www.chuimin.cn)
2.mysqladmin客户端
mysqladmin客户端用于完成大量管理任务,其中最突出的可能是创建和删除数据库、监视服务器状态和关闭MySQL服务器守护进程。与mysql一样,需要传入必要的访问凭证才能使用mysqladmin。
例如,可以执行如下命令查看所有服务器变量及其值:
如果提供了有效的凭证,就会看到滚动的参数及其相应值的长列表。如果希望分页显示结果,在Linux下可以将输出输送到more或less,在Windows下输送到more。
mysqladmin命令虽然mysql是一个免费形式的SQL shell,可以执行MySQL能识别的任何SQL查询,但mysqladmin的作用范围要有限得多,它只能识别一组预定义的命令。命令如下:
➢ create databasename
创建新数据库,名字由databasename指定。注意,每个数据库都必须有唯一的名。如果试图使用已存在数据库的名字来创建一个数据库,将导致一个错误。
➢ drop databasename
删除存在的数据库,名字由databasename指定。提交删除数据库的请求后,为了防止意外删除,会提示确认删除请求。
➢ extended-status
提供关于服务器状态的扩展信息。这与在mysql客户端中执行show status相同。
有关MySQL数据库设计与实现的文章
本节介绍MySQL支持的数据类型,提供关于每种类型的名称、作用、格式和范围的信息。TIMETIME数据类型负责存储时间信息,支持的范围相当大,不仅足以表示标准和军用时间格式,还可以表示扩展时间间隔。注意,对于MySQL版本4.1及更新版本,不可以指定该数据类型的大小。......
2023-10-29
向表中插入数据通过INSERT命令来完成,该命令的语法格式如下:“insert …values”这种格式是目前最常用的,下面是对该格式中各属性的介绍。table_name:要插入数据的表名。ON DUPLICATE KEY UPDATE:当插入的记录会引发主键冲突或者违反唯一约束时,就会对发生冲突的列进行更新操作,使用该条件的前提是要插入的表存在主键或唯一索引。图4.18使用ON DUPLICATE KEY UPDATE条件的例子2.使用“insert…set”插入数据使用“insert…set”格式的语句可根据明确指定的值插入数据。......
2023-10-29
创建多列索引的SQL代码如下:在提示符窗口中查看MySQL创建多列索引的操作效果,如图7.10所示。图7.11从上图中可以看出,name和sex字段上已经建立了一个名为index5_ns的多列索引。先在index5数据表中添加一些数据记录,然后使用EXPLAIN语句可以查看索引的使用情况。图7.12从上图中可以看出,possible_keys和key的值都是index5_ns。使用多列索引时一定要特别注意,只有使用了索引中的第一个字段时才会触发索引。因此,在优化查询速度时,可以考虑优化多列索引。......
2023-10-29
这一节将重点讨论促使MySQL风行的一些关键特性。接下来,还将提供有关MySQL产品两个主要里程碑版本的重要信息。庞大的开源社区:MySQL之所以如此流行和受欢迎,很大一部分功劳要归功于开源社区的积极支持。在开源社区中不仅能了解到MySQL的最新发展动态,还能快速地解决一些问题和难题。......
2023-10-29
由于不是所有的用户都习惯于用命令行程序,所以开发了GUI程序。下面就介绍一下SQLyog。SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库。图2.19SQLyog连接数据库进入管理界面,如图2.20所示。图2.22SQLyog查询视图结果视图,如图2.23所示。图2.23SQLyog结果视图数据库选择、常用工具栏,如图2.24所示。图2.25SQLyog菜单栏SQLyog常用技巧: Ctrl+Enter代码提示。......
2023-10-29
如下语法可用于创建存储过程:而如下语法用于创建存储函数:例如,来创建一个返回静态字符串的简单存储过程:仅此而已。请继续阅读,了解创建复杂的存储过程还有哪些选项。例如,能够使用PHP、Perl和Python语言创建存储过程,这意味着过程的功能只受所使用语言的限制。在编写本书时,此特点对存储过程的功能没有影响。......
2023-10-29
事务的隔离级别就是用来设置事务在读取数据时的隔离状态,提高数据并发使用效率的一种手段。事务的隔离级别由低到高可分为5个级别。MySQL默认级别,这种隔离级别可以避免“不可重复读取”,达到可重复读取。更改事务的隔离级别的语法代码如下:事务隔离级别的作用范围分为两种: 全局级:对所有的会话有效 会话级:只对当前的会话有效例如,设置会话级隔离级别为READ COMMITTED:或:设置全局级隔离级别为READ COMMITTED:......
2023-10-29
MySQL要求AUTO_INCREMENT属性用于作为主键的列。与之相反,忽略BINARY属性时,将使用不区分大小写的方式排序。否则,默认值将依赖于字段的数据类型。简言之,提供该属性是为了保证数据库兼容性。将不允许向该列插入NULL值。建议在重要情况下始终使用NOT NULL属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。PRIMARY KEYPRIMARY KEY属性用于确保指定行的唯一性。......
2023-10-29
相关推荐