How to set oracle encoding in php
How to set Oracle encoding in php: 1. Get the character set of Oracle; 2. Run "select * from V$NLS_PARAMETERS;"; 3. Convert the encoding through the iconv function.
The operating environment of this article: windows7 system, PHP7.1 version, DELL G3 computer
How to set oracle encoding in php?
php connects to oracle to set the character set to avoid garbled characters
The database uses oracle. When php connects to oracle, it is best to specify the character set.
Check the PHP manual. The fourth parameter of oci_connect is charset, which is the key.
First get the character set of oracle and run "select * from V$NLS_PARAMETERS;". The variable NLS_CHARACTERSET corresponds to the character set we need. For example, here is "ZHS16GBK". Therefore, the final PHP code is:
$c1 = oci_connect("scott", "tiger", $db, 'zhs16gbk');
My local PHP files use utf-8, so the obtained code needs to undergo the following encoding conversion:
while ($dat = oci_fetch_row($cur)) { print_r(iconv('gb2312', 'utf-8', $dat[0])); }
Update:
Colleagues said that Oracle can provide data according to the character set specified by the client. In other words, if my local PHP file uses UTF-8, then when I use oci_connect, I can directly specify utf-8, and even the encoding conversion will be saved.
$c1 = oci_connect("scott", "tiger", $db, 'UTF8');
In addition, there is a strange problem: the iconv previously converted to the encoding worked normally in the test machine environment, but it could not be parsed properly when transmitted to the remote location. Later, it was replaced with mb_convert_encoding. The code is as follows:
$nickname = mb_convert_encoding($dat[0], 'utf-8', 'gbk');
The possible reason is whether "//IGNORE" is added to the second parameter in iconv. Please refer to http://cn2.php.net/manual/en/function.iconv.php. If you are interested, you can try it, but I won’t try it
In addition, I attach a self-packaged php method to query oracle data DingSql:
/** * 封装接入oracle 执行sql语句查询 * @param sql * @return false or string or array(array()) * @author xzz 2018年5月5日上午9:38:54 */ function DingSql($sql = ''){ header("Content-type: text/html; charset=utf-8"); if(!$sql) return false; $conn= oci_connect('name', 'passwd', 'IP:PORT/serverName','zhs16gbk'); if($conn) { $stid = oci_parse($conn, $sql); // 配置SQL语句,准备执行 if (!$stid) { $e = oci_error($conn); print htmlentities($e['message']); exit; } $r = oci_execute($stid, OCI_DEFAULT); // 执行SQL。OCI_DEFAULT表示不要自动commit if(!$r) { $e = oci_error($stid); echo htmlentities($e['message']); exit; } $kkk = []; $i = '-1'; while($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) {//返回关联数据并创建null $i++; foreach($row as $key => $item) { $kkk[$i][$key] = iconv("gb2312", "utf-8//TRANSLIT", $item); } } oci_close($conn); return $kkk; //二维关联数组 }else{ echo '连接oracle失败!';exit; } }
Recommended learning : "PHP Video Tutorial"
The above is the detailed content of How to set oracle encoding in php. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

PHP remains important in modern web development, especially in content management and e-commerce platforms. 1) PHP has a rich ecosystem and strong framework support, such as Laravel and Symfony. 2) Performance optimization can be achieved through OPcache and Nginx. 3) PHP8.0 introduces JIT compiler to improve performance. 4) Cloud-native applications are deployed through Docker and Kubernetes to improve flexibility and scalability.

PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

The reasons why PHP is the preferred technology stack for many websites include its ease of use, strong community support, and widespread use. 1) Easy to learn and use, suitable for beginners. 2) Have a huge developer community and rich resources. 3) Widely used in WordPress, Drupal and other platforms. 4) Integrate tightly with web servers to simplify development deployment.

PHP is still dynamic and still occupies an important position in the field of modern programming. 1) PHP's simplicity and powerful community support make it widely used in web development; 2) Its flexibility and stability make it outstanding in handling web forms, database operations and file processing; 3) PHP is constantly evolving and optimizing, suitable for beginners and experienced developers.

PHP and Python each have their own advantages and are suitable for different scenarios. 1.PHP is suitable for web development and provides built-in web servers and rich function libraries. 2. Python is suitable for data science and machine learning, with concise syntax and a powerful standard library. When choosing, it should be decided based on project requirements.

PHP is suitable for web development, especially in rapid development and processing dynamic content, but is not good at data science and enterprise-level applications. Compared with Python, PHP has more advantages in web development, but is not as good as Python in the field of data science; compared with Java, PHP performs worse in enterprise-level applications, but is more flexible in web development; compared with JavaScript, PHP is more concise in back-end development, but is not as good as JavaScript in front-end development.

PHP is used to build dynamic websites, and its core functions include: 1. Generate dynamic content and generate web pages in real time by connecting with the database; 2. Process user interaction and form submissions, verify inputs and respond to operations; 3. Manage sessions and user authentication to provide a personalized experience; 4. Optimize performance and follow best practices to improve website efficiency and security.
