MySQL数据库中MySQL_real_connect的基本设置

此文章主要向大家讲述的是MySQL数据库中的MySQL_real_connect 连接参数的基本设置,我们在前一篇文章讲述关于进行MySQL(和PHP搭配之***组合)源程序代码的编译链接,但是没有讲述运行情况,在按照上一篇文章代码下进行编译运行后。

发现无法链接数据库文件,显然是在MySQL(和PHP搭配之***组合)_real_connect()函数中出现了问题。在MySQL(和PHP搭配之***组合)的英文手册中找到关于MySQL(和PHP搭配之***组合)_real_connect()的如下描述:

函数原型描述 MySQL数据库*MySQL(和PHP搭配之***组合)_real_connect(MySQL(和PHP搭配之***组合) *MySQL(和PHP搭配之***组合), const char *host, const char

 
 
 
  1. *user, 
  2. const char *passwd, const char *db, unsigned int port, const char *unix_socket, 
  3. unsigned long client_flag)
  4. Description
  5. MySQL(和PHP搭配之***组合)_real_connect() attempts to establish a connection to a MySQL(和PHP搭配之***组合) database engine 
  6. running on host. MySQL(和PHP搭配之***组合)_real_connect() must complete successfully before you can 
  7. execute any other API functions that require a valid MySQL(和PHP搭配之***组合) connection handle structure.
  8. The parameters are specified as follows:
  9. *
  10. The first parameter should be the address of an existing MySQL(和PHP搭配之***组合) structure. Before
  11. calling MySQL(和PHP搭配之***组合)_real_connect() you must call MySQL(和PHP搭配之***组合)_init() to initialize the MySQL(和PHP搭配之***组合) 
  12. structure. You can change a lot of connect options with the MySQL(和PHP搭配之***组合)_options() call. 
  13. See Section 17.2.3.47, Â“MySQL(和PHP搭配之***组合)_options()”.
  14. *
  15. The value of host may be either a hostname or an IP address. If host is NULL or the 
  16. string "localhost", a connection to the local host is assumed. If the OS supports sockets 
  17. (Unix) or named pipes (Windows), they are used instead of TCP/IP to connect to the server.
  18. *
  19. The user parameter contains the user's MySQL(和PHP搭配之***组合) login ID. If user is NULL or the empty 
  20. string "", the current user is assumed. Under Unix, this is the current login name. Under
  21. Windows ODBC, the current username must be specified explicitly. See Section 18.1.9.2,
  22. “Configuring a MyODBC DSN on Windows”.
  23. *
  24. The passwd parameter contains the password for user. If passwd is NULL, only entries
  25. in the user table for the user that have a blank (empty) password field are checked for a 
  26. match. This allows the database administrator to set up the MySQL(和PHP搭配之***组合) privilege system in 
  27. such a way that users get different privileges depending on whether they have specified 
  28. a password.
  29. Note: Do not attempt to encrypt the password before calling MySQL(和PHP搭配之***组合)_real_connect();
  30. password encryption is handled automatically by the client API.
  31. *
  32. db is the database name. If db is not NULL, the connection sets the default database 
  33. to this value.
  34. *
  35. If port is not 0, the value is used as the port number for the TCP/IP connection. Note 
  36. that the host parameter determines the type of the connection.
  37. *
  38. If unix_socket is not NULL, the string specifies the socket or named pipe that should
  39. be used. Note that the host parameter determines the type of the connection.
  40. *
  41. The value of client_flag is usually 0, but can be set to a combination of the following 
  42. flags to enable certain features:

上面描述了五个参数的主要取值,MySQL数据库 *为MySQL(和PHP搭配之***组合)_init函数返回的指针,host为null或 // localhost时链接的是本地的计算机,当MySQL(和PHP搭配之***组合)默认安装在unix(或类unix)系统中,root账户是没// 有密码的,因此用户名使用root,密码为null,当db为空的时候,函数链接到默认数据库,在进行 // MySQL(和PHP搭配之***组合)安装时会存在默认的test数据库,因此此处可以使用test数据库名称,port端口为0,使用 // unix连接方式,unix_socket为null时,表明不使用socket或管道机制,***一个参数经常设置为0

 
 
 
  1. Flag Name Flag Description
  2. CLIENT_COMPRESS Use compression protocol.
  3. CLIENT_FOUND_ROWS Return the number of found (matched) rows, not the number of
  4. changed rows.
  5. CLIENT_IGNORE_SPACE Allow spaces after function names. Makes all functions names 
  6. reserved words.
  7. CLIENT_INTERACTIVE Allow interactive_timeout seconds (instead of wait_timeout 
  8. seconds) of inactivity before closing the connection. The client's session wait_timeout 
  9. variable is set to the value of the session interactive_timeout variable.
  10. CLIENT_LOCAL_FILES Enable LOAD DATA LOCAL handling.
  11. CLIENT_MULTI_STATEMENTS Tell the server that the client may send multiple 
  12. statements in a single string (separated by Â‘;Â’). If this flag is not set, 
  13. multiple-statement execution is disabled. Added in MySQL(和PHP搭配之***组合) 4.1.
  14. CLIENT_MULTI_RESULTS Tell the server that the client can handle multiple result 
  15. sets from multiple-statement executions or stored procedures. This is automatically 
  16. set if CLIENT_MULTI_STATEMENTS is set. Added in MySQL(和PHP搭配之***组合) 4.1.
  17. CLIENT_NO_SCHEMA Don't allow the db_name.tbl_name.col_name syntax. This is for 
  18. ODBC. It causes the parser to generate an error if you use that syntax, which is useful
  19. for trapping bugs in some ODBC programs.
  20. CLIENT_ODBC The client is an ODBC client. This changes MySQL(和PHP搭配之***组合)d to be more
  21. ODBC-friendly.
  22. CLIENT_SSL Use SSL (encrypted protocol). This option should not be set by 
  23. application programs; it is set internally in the client library. Instead, use 
  24. MySQL(和PHP搭配之***组合)_ssl_set() before calling MySQL(和PHP搭配之***组合)_real_connect().
  25. For some parameters, it is possible to have the value taken from an option file rather 
  26. than from an explicit value in the MySQL(和PHP搭配之***组合)_real_connect() call. To do this, call 
  27. MySQL(和PHP搭配之***组合)_options() with the MySQL(和PHP搭配之***组合)_READ_DEFAULT_FILE or MySQL(和PHP搭配之***组合)_READ_DEFAULT_GROUP option 
  28. before calling MySQL(和PHP搭配之***组合)_real_connect(). Then, in the MySQL(和PHP搭配之***组合)_real_connect() call, specify 
  29. the Â“no-value” value for each parameter to be read from an option file:
  30. *
  31. For host, specify a value of NULL or the empty string ("").
  32. *
  33. For user, specify a value of NULL or the empty string.
  34. *
  35. For passwd, specify a value of NULL. (For the password, a value of the empty string in
  36. the MySQL(和PHP搭配之***组合)_real_connect() call cannot be overridden in an option file, because the empty 
  37. string indicates explicitly that the MySQL(和PHP搭配之***组合) account must have an empty password.)
  38. *
  39. For db, specify a value of NULL or the empty string.
  40. *
  41. For port, specify a value of 0.
  42. *
  43. For unix_socket, specify a value of NULL. 
  44. If no value is found in an option file for a parameter, its default value is used as 
  45. indicated in the descriptions given earlier in this section.
  46. Return Values
  47. A MySQL(和PHP搭配之***组合)* connection handle if the connection was successful, NULL if the connection 
  48. was unsuccessful. For a successful connection, the return value is the same as the value 
  49. of the first parameter.

返回值:当连接成功时,返回MySQL数据库连接句柄,失败,返回NULL。当成功时,返回值与***个参数值是// 相同的。

 
 
 
  1. Errors
  2. *
  3. CR_CONN_HOST_ERROR
  4. Failed to connect to the MySQL(和PHP搭配之***组合) server.
  5. *
  6. CR_CONNECTION_ERROR
  7. Failed to connect to the local MySQL(和PHP搭配之***组合) server.
  8. *
  9. CR_IPSOCK_ERROR
  10. Failed to create an IP socket.
  11. *
  12. CR_OUT_OF_MEMORY
  13. Out of memory.
  14. *
  15. CR_SOCKET_CREATE_ERROR
  16. Failed to create a Unix socket.
  17. *
  18. CR_UNKNOWN_HOST
  19. Failed to find the IP address for the hostname.
  20. *
  21. CR_VERSION_ERROR
  22. A protocol mismatch resulted from attempting to connect to a server with a client 
  23. library that uses a different protocol version. This can happen if you use a very old 
  24. client library to connect to a new server that wasn't started with the --old-protocol 
  25. option.
  26. *
  27. CR_NAMEDPIPEOPEN_ERROR
  28. Failed to create a named pipe on Windows.
  29. *
  30. CR_NAMEDPIPEWAIT_ERROR
  31. Failed to wait for a named pipe on Windows.
  32. *
  33. CR_NAMEDPIPESETSTATE_ERROR
  34. Failed to get a pipe handler on Windows.
  35. *
  36. CR_SERVER_LOST
  37. If connect_timeout > 0 and it took longer than connect_timeout seconds to connect to 
  38. the server or if the server died while executing the init-command. 

因此MySQL(和PHP搭配之***组合)_real_connect()函数调用为:

MySQL(和PHP搭配之***组合)_real_connect(MySQL数据库,"localhost","root",NULL,"test",0,NULL,0);

判断是否出错,出错调用MySQL(和PHP搭配之***组合)_error()函数显示出错信息,或使用MySQL(和PHP搭配之***组合)_errno()函数获取出错代号。

分享文章:MySQL数据库中MySQL_real_connect的基本设置
本文链接:http://www.csdahua.cn/qtweb/news8/411558.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网