首先,安装mysql-client和mysql-server。
一、Linux下的MYSQL相关命令操作:
1、以管理员身份进入mysql数据库
mysql -u root -p
2、创建数据库
create database 数据库名; (注意一定要写上分号)
3、显示已有的数据库
show datatbase;
4、删除数据库
drop database 数据库名;
5、使用哪个数据库
use 数据库名;
6、显示数据库中的表
show tables;
7、导入数据库到mysql数据库中
mysql -u root -p 数据库名 < 路径/数据库名称.sql
8、备份数据库
mysql dump -u root -p 数据库名 > 路径/数据库名称.sql
9、查看表结构
二、MYSQL的定义的结构体
1、MYSQL
Mysql提供的mysql.h头文件中,连接数据库前,必须先创建MYSQL变量,此变量在很多Mysql API函数会用到。它包含了一些连接信息等数据。
typedef struct st_mysql {
NET net; /* Communication parameters */
gptr connector_fd; /* ConnectorFd for SSL */
char *host,*user,*passwd,*unix_socket,
*server_version,*host_info,*info,*db;
unsigned int port,client_flag,server_capabilities;
unsigned int protocol_version;
unsigned int field_count;
unsigned int server_status;
unsigned long thread_id; /* Id for connection in server */
my_ulonglong affected_rows;
my_ulonglong insert_id; /* id if insert on table with NEXTNR */
my_ulonglong extra_info; /* Used by mysqlshow */
unsigned long packet_length;
enum mysql_status status;
MYSQL_FIELD *fields;
MEM_ROOT field_alloc;
my_bool free_me; /* If free in mysql_close */
my_bool reconnect; /* set to 1 if automatic reconnect */
struct st_mysql_options options;
char scramble_buff[9];
struct charset_info_st *charset;
unsigned int server_language;
} MYSQL;
2、MYSQL_RES
MYSQL_RES结构体中包含了查询结果集,也就是从数据库中查询到的数据。可以使用mysql_store_result或mysql_use_result函数获得。该结构代表返回行的查询结果(SELECT,SHOW,DESCRIBE,EXPLAIN)
typedef struct st_mysql_res {
my_ulonglong row_count;
unsigned int field_count, current_field;
MYSQL_FIELD *fields;
MYSQL_DATA *data;
MYSQL_ROWS *data_cursor;
MEM_ROOT field_alloc;
MYSQL_ROW row; /* If unbuffered read */
MYSQL_ROW current_row; /* buffer to current row */
unsigned long *lengths; /* column lengths of current row */
MYSQL *handle; /* for unbuffered reads */
my_bool eof; /* Used my mysql_fetch_row */
} MYSQL_RES;
3、MYSQL_ROW
typedef struct st_mysql_rows {
struct st_mysql_rows *next; /* list of rows链表 */
MYSQL_ROW data;
unsigned long length;
} MYSQL_ROWS;
typedef char **MYSQL_ROW;
指向一个字符串数组。可以通过mysql_fetch_row函数获得。
MYSQL_FIELD中包含了字段名、字段类型和大小等信息。可以重复调用mysql_fetch_field函数获得所有字段的信息。
typedef struct st_mysql_field {
char *name; /*列名 */
char *org_name; /* 列原来的名字,就是在指定表别名前的名字 */
char *table; /* 该字段所在的表名*/
char *org_table; /* 该表被指定别名前的名字 */
char *db; /* 列所在的数据库*/
char *catalog; /* Catalog for table难道是表所在的目录? */
char *def; /* 应该是该字段的默认值吧,没对这个问题调试过) */
unsigned long length; /* Width of column (create length) 列的宽度*/
unsigned long max_length; /* Max width for selected set 最大宽度*/
unsigned int name_length; /* 列名的宽度*/
unsigned int org_name_length; /* 原列名的宽度*/
unsigned int table_length; /* 表名的宽度*/
unsigned int org_table_length; /* 原表名的宽度*/
unsigned int db_length; /* 数据库名长度*/
unsigned int catalog_length; /*目录名长度*/
unsigned int def_length; /* 默认值的宽度*/
unsigned int flags; /* Div flags分隔符标志 ?*/
unsigned int decimals; /* Number of decimals in field小数点后的数 */
unsigned int charsetnr; /* Character set 字符集*/
enum enum_field_types type; /* Type of field. See mysql_com.h for types字段类型 */
void *extension; /* 用于扩展*/
} MYSQL_FIELD;
三、使用MYSQL一般步骤:
1、创建MYSQL变量
MYSQL mysql;
2、初始化MYSQL结构
mysql_init(&mysql);
3、连接MYSQL数据库
MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, cosnt char *db, unsigned int port, const char *NAME_socket, unsigned long client_flag);
mysql 是MYSQL连接句柄的指针。
host 既可以是主机名也可以是IP地址。如果连接的是本地机器,则其值为“localhost”
user 指定登录MySQL服务器的用户名
passwd 指定用户user的密码
db 是数据库名称
NAME_socket 默认为NULL,如不为NULL,则该字符串描述了应使用的套接字或命名管道
client_flag 通常为0
4、查询、添加、删除数据库等操作
int mysql_real_query(MYSQL *mysql, const char *query, unsigned long length);
执行指定为带计数的字符串query的SQL语句。查询成功返回0;
5、获取4中查询结果
将查询的全部结果读取到客户端,保存查询结果。查询成功后必须调用mysql_store_result()。
MYSQL_RES * mysql_store_result(MYSQL *mysql);
6、读取结果集数据
返回结果集中的列数
mysql_num_field(MYSQL_RES *result);
返回结果集中的行数
mysql_num_rows(MYSQL_RES *result);
检索结果集的下一行
结果集用完后,调用mysql_free_result函数释放结果集,以防内存泄露。
void mysql_free_result(MYSQL_RES *result);
9、关闭数据库
void mysql_close(MYSQL *mysql)
一、Linux下的MYSQL相关命令操作:
1、以管理员身份进入mysql数据库
mysql -u root -p
2、创建数据库
create database 数据库名; (注意一定要写上分号)
3、显示已有的数据库
show datatbase;
4、删除数据库
drop database 数据库名;
5、使用哪个数据库
use 数据库名;
6、显示数据库中的表
show tables;
7、导入数据库到mysql数据库中
mysql -u root -p 数据库名 < 路径/数据库名称.sql
8、备份数据库
mysql dump -u root -p 数据库名 > 路径/数据库名称.sql
9、查看表结构
describe 表名;
10、唯一查询
单表的唯一查询用:distinct
多表的唯一查询用:group by
select distinct 字段 from 表;
如果distinct后面跟了同一个表中的2个字段,必须是这个2个字段都相同的才会被排除。
11、多表查询
SELECT 字段名 FROM 表1,表2 … WHERE 表1.字段 = 表2.字段 AND 其它查询条件;
12、更新表
update 表名 set 字段=‘**’;
二、MYSQL的定义的结构体
1、MYSQL
Mysql提供的mysql.h头文件中,连接数据库前,必须先创建MYSQL变量,此变量在很多Mysql API函数会用到。它包含了一些连接信息等数据。
typedef struct st_mysql {
NET net; /* Communication parameters */
gptr connector_fd; /* ConnectorFd for SSL */
char *host,*user,*passwd,*unix_socket,
*server_version,*host_info,*info,*db;
unsigned int port,client_flag,server_capabilities;
unsigned int protocol_version;
unsigned int field_count;
unsigned int server_status;
unsigned long thread_id; /* Id for connection in server */
my_ulonglong affected_rows;
my_ulonglong insert_id; /* id if insert on table with NEXTNR */
my_ulonglong extra_info; /* Used by mysqlshow */
unsigned long packet_length;
enum mysql_status status;
MYSQL_FIELD *fields;
MEM_ROOT field_alloc;
my_bool free_me; /* If free in mysql_close */
my_bool reconnect; /* set to 1 if automatic reconnect */
struct st_mysql_options options;
char scramble_buff[9];
struct charset_info_st *charset;
unsigned int server_language;
} MYSQL;
2、MYSQL_RES
MYSQL_RES结构体中包含了查询结果集,也就是从数据库中查询到的数据。可以使用mysql_store_result或mysql_use_result函数获得。该结构代表返回行的查询结果(SELECT,SHOW,DESCRIBE,EXPLAIN)
typedef struct st_mysql_res {
my_ulonglong row_count;
unsigned int field_count, current_field;
MYSQL_FIELD *fields;
MYSQL_DATA *data;
MYSQL_ROWS *data_cursor;
MEM_ROOT field_alloc;
MYSQL_ROW row; /* If unbuffered read */
MYSQL_ROW current_row; /* buffer to current row */
unsigned long *lengths; /* column lengths of current row */
MYSQL *handle; /* for unbuffered reads */
my_bool eof; /* Used my mysql_fetch_row */
} MYSQL_RES;
3、MYSQL_ROW
typedef struct st_mysql_rows {
struct st_mysql_rows *next; /* list of rows链表 */
MYSQL_ROW data;
unsigned long length;
} MYSQL_ROWS;
typedef char **MYSQL_ROW;
指向一个字符串数组。可以通过mysql_fetch_row函数获得。
row[0]到row[mysql_num_fields(result)-1]来存取
MYSQL_FIELD中包含了字段名、字段类型和大小等信息。可以重复调用mysql_fetch_field函数获得所有字段的信息。
typedef struct st_mysql_field {
char *name; /*列名 */
char *org_name; /* 列原来的名字,就是在指定表别名前的名字 */
char *table; /* 该字段所在的表名*/
char *org_table; /* 该表被指定别名前的名字 */
char *db; /* 列所在的数据库*/
char *catalog; /* Catalog for table难道是表所在的目录? */
char *def; /* 应该是该字段的默认值吧,没对这个问题调试过) */
unsigned long length; /* Width of column (create length) 列的宽度*/
unsigned long max_length; /* Max width for selected set 最大宽度*/
unsigned int name_length; /* 列名的宽度*/
unsigned int org_name_length; /* 原列名的宽度*/
unsigned int table_length; /* 表名的宽度*/
unsigned int org_table_length; /* 原表名的宽度*/
unsigned int db_length; /* 数据库名长度*/
unsigned int catalog_length; /*目录名长度*/
unsigned int def_length; /* 默认值的宽度*/
unsigned int flags; /* Div flags分隔符标志 ?*/
unsigned int decimals; /* Number of decimals in field小数点后的数 */
unsigned int charsetnr; /* Character set 字符集*/
enum enum_field_types type; /* Type of field. See mysql_com.h for types字段类型 */
void *extension; /* 用于扩展*/
} MYSQL_FIELD;
三、使用MYSQL一般步骤:
1、创建MYSQL变量
MYSQL mysql;
2、初始化MYSQL结构
mysql_init(&mysql);
3、连接MYSQL数据库
MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, cosnt char *db, unsigned int port, const char *NAME_socket, unsigned long client_flag);
mysql 是MYSQL连接句柄的指针。
host 既可以是主机名也可以是IP地址。如果连接的是本地机器,则其值为“localhost”
user 指定登录MySQL服务器的用户名
passwd 指定用户user的密码
db 是数据库名称
NAME_socket 默认为NULL,如不为NULL,则该字符串描述了应使用的套接字或命名管道
client_flag 通常为0
4、查询、添加、删除数据库等操作
int mysql_real_query(MYSQL *mysql, const char *query, unsigned long length);
执行指定为带计数的字符串query的SQL语句。查询成功返回0;
5、获取4中查询结果
将查询的全部结果读取到客户端,保存查询结果。查询成功后必须调用mysql_store_result()。
MYSQL_RES * mysql_store_result(MYSQL *mysql);
6、读取结果集数据
返回结果集中的列数
mysql_num_field(MYSQL_RES *result);
返回结果集中的行数
mysql_num_rows(MYSQL_RES *result);
检索结果集的下一行
mysql_fetch_row(MYSQL_RES *result);
检索结果集的下一列
mysql_fetch_field(MYSQL_RES *result);
结果集用完后,调用mysql_free_result函数释放结果集,以防内存泄露。
void mysql_free_result(MYSQL_RES *result);
9、关闭数据库
void mysql_close(MYSQL *mysql)