用qt连接MySQL需要共享库 libqsqlmysql.so的驱动,路径在plugin/sqldrivers目录下,乍看已经可用了,其实不然。
用qt连接MySQL需要共享库 libqsqlmysql.so的驱动,路径在plugin/sqldrivers目录下,乍看已经可用了,其实不然。
用ldd命令分析一下,libmysqlclient_r.so.16 => not found ,后明显libmysqlclient_r.so.16 缺少另一个共享库,他们是依赖关系,解决了这个问题qt才能真的连接到mysql数据库。而我的/usr/lib64/下的共享库版本比较高是libmysqlclient.so.18,想到了一个比较投机的想法ln创建符号链接,然而这并没有什么卵用。
让我哭笑不得是QT5.5是我从官网下载的,居然依赖的是低版本,,你们编译的时候能不能不偷懒啊,估计他们直接从低版本拷贝的libqsqlmysql.so,没办法了吗?显然不是,打开qt官网下载源码,自己编译。下载过程略过,非常好找 (暂时没有qt5.5的源码),找到qtbase那个大概60M。MySql驱动的路径为qtbase/src/plugins/sqldrivers/mysql/。
•qmake
•make
然而这还没有完,make的过程中又找不到动态库了:
/usr/bin/ld: cannot find -lz
/usr/bin/ld: cannot find -lssl
/usr/bin/ld: cannot find -lcrypto
第一个是没有安装zlib-devel,直接yum install zlib-devel搞定。
第二第三项找不到是没有道理的,解决的方法:/usr/lib64/中创建符号链接
ln -s libssl.so.1.0.1e libssl.so
ln -s libcrypto.so.1.0.1e libcrypto.so
再次make,成功。当然这还没有完,用新的libqsqlmysql.so去替换旧的,这就全部完成了。
再次查看:
[sqldrivers]ldd libqsqlmysql.so
linux-vdso.so.1 => (0x00007fff2d5fe000)
libmysqlclient.so.18 => /usr/lib64/mysql/libmysqlclient.so.18 (0x00007feb4ea24000)
libz.so.1 => /lib64/libz.so.1 (0x00007feb4e80d000)
libcrypt.so.1 => /lib64/libcrypt.so.1 (0x00007feb4e5d6000)
libnsl.so.1 => /lib64/libnsl.so.1 (0x00007feb4e3bd000)
libssl.so.10 => /lib64/libssl.so.10 (0x00007feb4e150000)
libcrypto.so.10 => /lib64/libcrypto.so.10 (0x00007feb4dd6b000)
libQt5Sql.so.5 => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libQt5Sql.so.5 (0x00007feb4db2b000)
libQt5Core.so.5 => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libQt5Core.so.5 (0x00007feb4d3e3000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007feb4d1c7000)
libstdc++.so.6 => /lib64/libstdc++.so.6 (0x00007feb4cec0000)
libm.so.6 => /lib64/libm.so.6 (0x00007feb4cbbd000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007feb4c9a7000)
libc.so.6 => /lib64/libc.so.6 (0x00007feb4c5e6000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007feb4c3e1000)
libfreebl3.so => /lib64/libfreebl3.so (0x00007feb4c164000)
libgssapi_krb5.so.2 => /lib64/libgssapi_krb5.so.2 (0x00007feb4bf1a000)
libkrb5.so.3 => /lib64/libkrb5.so.3 (0x00007feb4bc39000)
libcom_err.so.2 => /lib64/libcom_err.so.2 (0x00007feb4ba35000)
libk5crypto.so.3 => /lib64/libk5crypto.so.3 (0x00007feb4b800000)
libicui18n.so.54 => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libicui18n.so.54 (0x00007feb4b391000)
libicuuc.so.54 => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libicuuc.so.54 (0x00007feb4afe3000)
libicudata.so.54 => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libicudata.so.54 (0x00007feb495b9000)
libgthread-2.0.so.0 => /lib64/libgthread-2.0.so.0 (0x00007feb493b6000)
librt.so.1 => /lib64/librt.so.1 (0x00007feb491ae000)
libglib-2.0.so.0 => /lib64/libglib-2.0.so.0 (0x00007feb48e85000)
/lib64/ld-linux-x86-64.so.2 (0x00007feb4f221000)
libkrb5support.so.0 => /lib64/libkrb5support.so.0 (0x00007feb48c76000)
libkeyutils.so.1 => /lib64/libkeyutils.so.1 (0x00007feb48a72000)
libresolv.so.2 => /lib64/libresolv.so.2 (0x00007feb48858000)
libselinux.so.1 => /lib64/libselinux.so.1 (0x00007feb48632000)
libpcre.so.1 => /lib64/libpcre.so.1 (0x00007feb483d1000)
liblzma.so.5 => /lib64/liblzma.so.5 (0x00007feb481ab000)
Ubuntu 环境下Gtk与QT编译环境安装与配置
Linux系统下QT环境搭建
Ubuntu下QT控制台程序无法运行的解决方案以及XTerm的配置方法
Ubuntu 10.04下QT4.7.4移植详解
Ubuntu 14.04下安装部署Qt5开发环境
Qt 的详细介绍:请点这里
Qt 的下载地址:请点这里
本文永久更新链接地址:

MySQLdiffersfromotherSQLdialectsinsyntaxforLIMIT,auto-increment,stringcomparison,subqueries,andperformanceanalysis.1)MySQLusesLIMIT,whileSQLServerusesTOPandOracleusesROWNUM.2)MySQL'sAUTO_INCREMENTcontrastswithPostgreSQL'sSERIALandOracle'ssequenceandt

MySQLパーティション化により、パフォーマンスが向上し、メンテナンスが簡素化されます。 1)大きなテーブルを特定の基準(日付範囲など)、2)物理的に独立したファイルに物理的に分割する、3)MySQLはクエリするときに関連するパーティションに焦点を合わせることができます。

mysqlで許可を許可および取り消す方法は? 1。grantallprivilegesondatabase_name.to'username'@'host 'などの許可を付与するために付与ステートメントを使用してください。 2。Revokeallprivilegesondatabase_name.from'username'@'host 'など、Revoke Statementを使用して、許可のタイムリーな通信を確保します。

INNODBは、トランザクションサポートと高い並行性を必要とするアプリケーションに適していますが、Myisamはより多くの読み取りとより少ない書き込みを必要とするアプリケーションに適しています。 1.INNODBは、eコマースおよび銀行システムに適したトランザクションおよび銀行レベルのロックをサポートしています。 2. Myisamは、ブログやコンテンツ管理システムに適した、迅速な読み取りとインデックス作成を提供します。

MySQLには4つのメイン結合タイプがあります:innerjoin、leftjoin、rightjoin、fullouterjoin。 1.InnerJoinは、結合条件を満たす2つのテーブルのすべての行を返します。 2.右のテーブルに一致する行がない場合でも、Leftjoinは左のテーブルのすべての行を返します。 3。右joinはleftjoinに反しており、右のテーブルのすべての行を返します。 4.fullouterjoinは、結合条件を満たしている、または満たさない2つのテーブルのすべての行を返します。

mysqloffersvariousstorageEngines、それぞれのfordifferentusecases:1)Innodbisidealforapplicationsingingidcomplianceanceandhighconcurrency、support transactions andforeignkeys.2)myisamisbestforread-havyworkloads、transactionsupptort.3)

MySQLの一般的なセキュリティの脆弱性には、SQLインジェクション、弱いパスワード、不適切な許可構成、および非合事ソフトウェアが含まれます。 1。SQL注射は、前処理ステートメントを使用することで防ぐことができます。 2。強力なパスワード戦略を強制的に使用することにより、弱いパスワードを回避できます。 3.不適切な許可構成は、ユーザー許可の定期的なレビューと調整を通じて解決できます。 4.未使用のソフトウェアは、MySQLバージョンを定期的にチェックして更新することでパッチを適用できます。

MySQLの遅いクエリを識別することは、遅いクエリログを有効にし、しきい値を設定することで実現できます。 1.スロークエリログを有効にし、しきい値を設定します。 2.スロークエリログファイルを表示および分析し、詳細な分析のためにMySQLDumpSlowやPT-Query-Digestなどのツールを使用します。 3.インデックスの最適化、クエリの書き換え、およびselect*の使用を回避することで、遅いクエリの最適化を実現できます。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール

WebStorm Mac版
便利なJavaScript開発ツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ホットトピック









